@charset "UTF-8";
/*
Theme Name: Original_style
Theme URI: kawakami-kenki.com
Description: オリジナルリセット
Version: 1.5
Author: 川上建基
Author URI: kawakami-kenki.com
*/
/* html5 reset*/
html {
  overflow-y: scroll;
}

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, dialog, figure, footer, header,
hgroup, menu, nav, section,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

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

fieldset, img {
  border: 0;
}

h1, h2, h3, h4, h5, h6, address, caption, cite, code, dfn, em, strong, th, var, span {
  font-style: normal;
  font-weight: normal;
}

li {
  list-style: none;
}

article, aside, dialog, figure, footer, header, hgroup, nav, section {
  display: block;
}

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

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

sup {
  vertical-align: text-top;
}

sub {
  vertical-align: text-bottom;
}

img {
  vertical-align: bottom;
}

.inb {
  display: inline-block;
  font-weight: inherit;
}

a.--fax {
  pointer-events: none;
}

/*sass用　ブレイクポイント定義*/
/* スクロール時・PCナビ非表示時・下層ページで共通の「白背景ヘッダー」状態 */
:root {
  --font-weight-Regular: 400;
  --font-weight-Medium: 500;
  --font-weight-SemiBold: 600;
  --font-weight-Bold: 700;
  --font-weight-Black: 900;
  /* ブランドカラー */
  --color-primary: #4EC7D8;
  --color-primary-light: #4EC7D8;
  --color-grad: linear-gradient(to right, #078282, #0abab5);
  --color-text: #333;
  --color-bg: #f5f5f5;
  --color-white: #ffffff;
  /* フォント */
  --font-en: 'Montserrat', sans-serif;
  --font-ja: 'Noto Sans JP', sans-serif;
  /* レイアウト */
  --container-width: 1120px;
  --section-pad-v: 100px;
  --section-pad-h: 20px;
  /* ヘッダー高さ */
  --header-height: 80px;
}
@media (width <= 768px) {
  :root {
    --header-height: 60px;
  }
}
:root {
  /* ハンバーガメニューボタン */
  --width-hm-menu-btn: 80px;
}
@media (width <= 768px) {
  :root {
    --width-hm-menu-btn: 60px;
  }
}
:root {
  /* z-index */
  --z-index-header: 300;
  --z-index-hamburgermenu: 350;
  --z-index-hamburger: 400;
}

/* グラデーションテキスト共通 */
.grad-text {
  background: var(--color-primary);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* セクション内幅コンテナ */
.sec-inner {
  max-width: var(--container-width);
  margin-inline: auto;
  padding-inline: var(--section-pad-h);
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

/* セクション見出し（英語大＋日本語サブ）共通 */
.sec-heading {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  gap: 16px;
}
@media (width <= 768px) {
  .sec-heading {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 10px;
  }
}
.sec-heading .en-heading {
  font-family: var(--font-en);
  font-size: clamp(40px, 4.4444444444vw, 48px);
  font-weight: var(--font-weight-SemiBold);
  line-height: 1;
  letter-spacing: 0.04em;
}
@media (width <= 768px) {
  .sec-heading .en-heading {
    font-size: clamp(28px, 8vw, 40px);
  }
}
.sec-heading .ja-sub {
  font-family: var(--font-ja);
  font-size: clamp(14px, 1.4814814815vw, 16px);
  font-weight: var(--font-weight-Bold);
  color: var(--color-text);
}
@media (width <= 768px) {
  .sec-heading .ja-sub {
    font-size: clamp(12px, 3.2vw, 14px);
  }
}

/* ティール背景セクション共通（about / works / contact） */
.sec-teal {
  background: var(--color-primary);
  margin-inline: 18px;
  border-radius: 10px;
}

.js-scroll-trigger,
.js-scroll-fadeup {
  --scroll-duration: 1.20s;
  --scroll-delay: 0s;
  --scroll-easing: cubic-bezier(0.22, 1, 0.36, 1);
  -webkit-transition: opacity var(--scroll-duration) ease var(--scroll-delay), -webkit-transform var(--scroll-duration) var(--scroll-easing) var(--scroll-delay);
  transition: opacity var(--scroll-duration) ease var(--scroll-delay), -webkit-transform var(--scroll-duration) var(--scroll-easing) var(--scroll-delay);
  transition: opacity var(--scroll-duration) ease var(--scroll-delay), transform var(--scroll-duration) var(--scroll-easing) var(--scroll-delay);
  transition: opacity var(--scroll-duration) ease var(--scroll-delay), transform var(--scroll-duration) var(--scroll-easing) var(--scroll-delay), -webkit-transform var(--scroll-duration) var(--scroll-easing) var(--scroll-delay);
  will-change: opacity, transform;
}

.js-scroll-trigger.is-scroll-in,
.js-scroll-fadeup.is-scroll-in {
  opacity: 1;
  -webkit-transform: translate(0, 0) scale(1);
          transform: translate(0, 0) scale(1);
}

.scroll-fadeup,
.js-scroll-fadeup {
  opacity: 0;
  -webkit-transform: translateY(48px);
          transform: translateY(48px);
}

@media (prefers-reduced-motion: reduce) {
  .js-scroll-trigger,
  .js-scroll-fadeup {
    opacity: 1;
    -webkit-transform: none;
            transform: none;
    -webkit-transition: none;
    transition: none;
  }
}
/* original reset */
li {
  list-style: none;
}

a {
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

/* html5 reset +alpha */
html {
  font-size: 62.5%; /* (14px) */
  line-height: 1;
}

#main {
  line-height: 1.4;
}

/* common item */
.clrfx:after {
  content: ".";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
  overflow: hidden;
  font-size: 0.1em;
  line-height: 0;
}

.clrfx {
  zoom: 1;
}

.clr {
  clear: both;
}

.fltl {
  float: left;
}

.fltr {
  float: right;
}

.leftAdjust {
  text-align: left;
}

.rightAdjust {
  text-align: right;
}

.centerAdjust {
  text-align: center;
}

.topAdjust {
  vertical-align: top;
}

.middleAdjust {
  vertical-align: middle;
}

.bottomAdjust {
  vertical-align: bottom;
}

.rlt {
  position: relative;
}

.abs {
  position: absolute;
}

strong {
  font-weight: bold;
}

em {
  font-style: italic;
}

del {
  -webkit-text-decoration: line-though;
          text-decoration: line-though;
}

.text-inherit {
  font-weight: inherit;
}

/* items */
img {
  max-width: 100%;
  height: auto;
  image-rendering: -webkit-optimize-contrast;
}

a img {
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}

a:hover img {
  opacity: 0.7;
  filter: alpha(opacity=70);
  -ms-filter: alpha(opacity=70);
}

a:hover img.opa100 {
  opacity: 1;
  filter: alpha(opacity=100);
  -ms-filter: alpha(opacity=100);
}

.container {
  margin: 0 auto;
}

.f_mincho {
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

/* body style */
body {
  font-size: 14px;
  font-family: "游ゴシック", YuGothic, "Lucida Grande", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", Meiryo, メイリオ, sans-serif;
  background: #fff;
  -webkit-text-size-adjust: 100%;
}

/* common */
@media (width > 768px) {
  .sp_v {
    display: none !important;
  }
}

@media (width <= 768px) {
  .pc_v {
    display: none !important;
  }
}

/*==============================
	ホバーアニメーション
===============================*/
a .hover_abs_anim_01 {
  position: relative;
  overflow: hidden;
}

a .hover_abs_anim_01 img {
  position: absolute;
  top: 50%;
  left: 50%;
  height: 100%;
  -webkit-transform: translate(-50%, -50%) scale(1, 1); /* Safari用 */
  transform: translate(-50%, -50%) scale(1, 1);
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}

a:hover .hover_abs_anim_01 img {
  -webkit-transform: translate(-50%, -50%) scale(1.2, 1.2); /* Safari用 */
  transform: translate(-50%, -50%) scale(1.2, 1.2);
}

a .hover_anim_01 {
  overflow: hidden;
}

a .hover_anim_01 img {
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}

a:hover .hover_anim_01 img {
  -webkit-transform: scale(1.2, 1.2);
          transform: scale(1.2, 1.2);
}

/*==============================
	SPナビ
===============================*/
.navBtn {
  position: fixed;
  top: 0;
  right: 18px;
  width: var(--width-hm-menu-btn);
  height: var(--header-height);
  margin: 5px 0;
  padding-left: 2px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  z-index: var(--z-index-hamburger);
  cursor: pointer;
}
@media (min-width: 1201px) {
  .navBtn {
    display: none;
  }
}
.navBtn .navIcon {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 100%;
  padding: 0;
  cursor: pointer;
  background: transparent;
  background-size: cover;
  border: none;
  outline: none;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  /*
  border-radius: 10px;
  box-shadow: 0 4px 4px rgba(0,0,0,0.25);
  */
}
.navBtn .navbar {
  position: relative;
  display: block;
  width: 28px;
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
  margin-inline: auto;
  aspect-ratio: 1/1;
}
@media (width <= 768px) {
  .navBtn .navbar {
    width: 22px;
  }
}
.navBtn .navbar .menu-btn-bar {
  position: absolute;
  left: 0%;
  top: 50%;
  width: 100%;
  height: 2px;
  margin-top: 0;
  margin-left: 0%;
  border-radius: 3px;
  display: block;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  -webkit-transform: rotate(0deg);
          transform: rotate(0deg);
}
.navBtn .navbar .menu-btn-top {
  background-color: var(--color-primary);
  -webkit-transform: translateY(-8px);
          transform: translateY(-8px);
}
.navBtn .navbar .menu-btn-middle {
  background-color: var(--color-primary);
}
.navBtn .navbar .menu-btn-bottom {
  background-color: var(--color-primary);
  -webkit-transform: translateY(8px);
          transform: translateY(8px);
}
.navBtn .navIcon.btn_on .menu-btn-middle {
  opacity: 0;
}
.navBtn .navIcon.btn_on .menu-btn-top {
  width: 100%;
  -webkit-transform: rotate(-45deg) translateY(0px);
          transform: rotate(-45deg) translateY(0px);
}
.navBtn .navIcon.btn_on .menu-btn-bottom {
  width: 100%;
  -webkit-transform: rotate(45deg) translateY(0px);
          transform: rotate(45deg) translateY(0px);
}

.menu-wrap {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  padding: 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
@media (min-width: 1201px) {
  .menu-wrap {
    display: none;
  }
}
.menu-wrap {
  background-color: #ffffff;
  -webkit-transition: opacity 0.3s ease, visibility 0.3s ease;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  z-index: var(--z-index-hamburgermenu);
  overflow-y: auto;
  overflow-x: hidden;
}
.menu-wrap .menu-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  min-height: 100vh;
  padding: calc(var(--header-height) + 32px) 40px 60px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
.menu-wrap .menu-inner .menu_logo_01 {
  margin-bottom: 32px;
}
.menu-wrap .menu-inner .menu_logo_01 .site-logo {
  display: inline-block;
  text-decoration: none;
}
.menu-wrap .menu-inner .menu_logo_01 .site-logo img {
  max-width: 180px;
  width: 100%;
  height: auto;
}
.menu-wrap .global_nav_block_01 {
  width: 100%;
  max-width: 400px;
  margin-inline: auto;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}

.global-nav-menu-01 .nav_item_01 a.p_menu_01 {
  display: block;
  position: relative;
  padding: 22px 48px 22px 20px;
  font-family: var(--font-ja);
  font-size: clamp(18px, 4.8vw, 22px);
  font-weight: var(--font-weight-Bold);
  color: var(--color-primary);
  letter-spacing: 0.06em;
  text-decoration: none;
  -webkit-transition: 0.2s opacity ease-out;
  transition: 0.2s opacity ease-out;
}
.global-nav-menu-01 .nav_item_01 a.p_menu_01::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 12px;
  width: 8px;
  height: 8px;
  border-top: 2px solid var(--color-primary-light);
  border-right: 2px solid var(--color-primary-light);
  -webkit-transform: translateY(-50%) rotate(45deg);
          transform: translateY(-50%) rotate(45deg);
}
.global-nav-menu-01 .nav_item_01 a.p_menu_01:hover {
  opacity: 0.6;
  text-decoration: none;
}

.nav_contact_block_01 {
  margin-top: 32px;
  max-width: 320px;
  margin-inline: auto;
}
.nav_contact_block_01 .contact_mail_parts_01 .btn-menu-contact {
  width: 100%;
  height: 50px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.nav_contact_block_01 .contact_tel_parts_01 {
  margin-top: 24px;
}
.nav_contact_block_01 .contact_tel_parts_01 .contact-tel-label {
  font-size: 16px;
  font-weight: var(--font-weight-Bold);
  color: var(--color-text);
  margin-bottom: 16px;
  letter-spacing: 0.04em;
  text-align: center;
}
.nav_contact_block_01 .contact_tel_parts_01 .contact-tel-wrap {
  gap: 12px 20px;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
.nav_contact_block_01 .contact_tel_parts_01 .tel-item {
  gap: 10px;
}
.nav_contact_block_01 .contact_tel_parts_01 .tel-item .tel-icon {
  width: 38px;
}
.nav_contact_block_01 .contact_tel_parts_01 .tel-item .tel-num {
  font-size: clamp(28px, 7.4666666667vw, 32px);
  color: var(--color-primary);
}
.nav_contact_block_01 .contact_tel_parts_01 .header-tel-label {
  margin-top: 12px;
  font-size: clamp(16px, 4.2666666667vw, 16px);
  color: var(--color-primary);
  letter-spacing: 0.03em;
  text-align: center;
}

.menuOff {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.menuOn {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.smenu_wrap {
  padding: 0;
}

/*==============================
	サイトヘッダー
===============================*/
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: var(--z-index-header);
  /* ヘッダー文字色：初期は白、スクロールで通常色に切替 */
  --header-nav-color: #fff;
  --header-tel-color: #fff;
}
.site-header .header-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  height: var(--header-height);
  padding-inline: 30px 20px;
  background: transparent;
  border-radius: 10px;
  margin: 5px 18px;
  -webkit-box-shadow: 0 4px 4px rgba(0, 0, 0, 0);
          box-shadow: 0 4px 4px rgba(0, 0, 0, 0);
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: calc(100% - 36px);
  -webkit-transition: background-color 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: background-color 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: background-color 0.3s ease, box-shadow 0.3s ease;
  transition: background-color 0.3s ease, box-shadow 0.3s ease, -webkit-box-shadow 0.3s ease;
}
@media (max-width: 1200px) {
  .site-header .header-inner {
    padding-inline: 20px calc(20px + var(--width-hm-menu-btn));
  }
}
.site-header {
  /* 少しスクロールしたら白背景＋濃色に切替 */
}
.site-header.is-scrolled {
  --header-nav-color: var(--color-text);
  --header-tel-color: #000;
}
.site-header.is-scrolled .header-inner {
  background: #fff;
  -webkit-box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
          box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
}
.site-header.is-scrolled {
  /* ロゴ・電話アイコンを濃色版に切替 */
}
.site-header.is-scrolled .site-logo .site-logo-img--default,
.site-header.is-scrolled .header-tel-icon--default {
  display: none;
}
.site-header.is-scrolled .site-logo .site-logo-img--scrolled,
.site-header.is-scrolled .header-tel-icon--scrolled {
  display: block;
}
.site-header {
  /* PCナビ非表示（1200px以下）時も白背景に固定 */
}
@media (max-width: 1200px) {
  .site-header {
    --header-nav-color: var(--color-text);
    --header-tel-color: #000;
  }
  .site-header .header-inner {
    background: #fff;
    -webkit-box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
            box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
  }
  .site-header {
    /* ロゴ・電話アイコンを濃色版に切替 */
  }
  .site-header .site-logo .site-logo-img--default,
  .site-header .header-tel-icon--default {
    display: none;
  }
  .site-header .site-logo .site-logo-img--scrolled,
  .site-header .header-tel-icon--scrolled {
    display: block;
  }
}

/* 下層ページ（TOP以外）は常に白背景ヘッダー */
.page .site-header {
  --header-nav-color: var(--color-text);
  --header-tel-color: #000;
}
.page .site-header .header-inner {
  background: #fff;
  -webkit-box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
          box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
}
.page .site-header {
  /* ロゴ・電話アイコンを濃色版に切替 */
}
.page .site-header .site-logo .site-logo-img--default,
.page .site-header .header-tel-icon--default {
  display: none;
}
.page .site-header .site-logo .site-logo-img--scrolled,
.page .site-header .header-tel-icon--scrolled {
  display: block;
}

/* ロゴ */
.site-logo-heading {
  margin: 0;
  line-height: 1;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.site-logo {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-decoration: none;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.site-logo img {
  height: 52px;
  width: auto;
  display: block;
}
@media (width <= 768px) {
  .site-logo img {
    height: 42px;
  }
}
.site-logo {
  /* スクロール前はデフォルト(白)ロゴのみ表示 */
}
.site-logo .site-logo-img--scrolled {
  display: none;
}
.site-logo:hover {
  text-decoration: none;
  opacity: 0.85;
}

/* PCナビ */
@media (max-width: 1200px) {
  .pc-nav {
    display: none;
  }
}
.pc-nav .pc-nav-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: clamp(14px, 1.6666666667vw, 24px);
}
.pc-nav .pc-nav-list .pc-nav-item a {
  display: block;
  padding: 8px 0;
  font-family: var(--font-ja);
  font-size: clamp(13px, 1.1111111111vw, 16px);
  font-weight: var(--font-weight-Bold);
  color: var(--header-nav-color);
  letter-spacing: 0.08em;
  text-decoration: none;
  white-space: nowrap;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}
.pc-nav .pc-nav-list .pc-nav-item a.is-current {
  position: relative;
  color: var(--color-primary);
}
.pc-nav .pc-nav-list .pc-nav-item a.is-current::after {
  content: "";
  position: absolute;
  left: 10px;
  right: 10px;
  bottom: 2px;
  height: 2px;
  background: var(--color-primary);
}
.pc-nav .pc-nav-list .pc-nav-item a:hover {
  color: var(--color-primary);
  text-decoration: none;
}

/* ヘッダー右側 */
.header-contact {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 21px;
}
@media (width <= 768px) {
  .header-contact {
    display: none;
  }
}

/* 電話ブロック：丸アイコン + 番号/ラベル */
.header-tel-block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 10px;
}

.header-tel-icon {
  display: block;
  width: 28px;
  height: 28px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

/* スクロール前はデフォルト(白)アイコンのみ表示 */
.header-tel-icon--scrolled {
  display: none;
}

.header-tel-info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  line-height: 1.2;
}

.header-tel {
  font-family: var(--font-en);
  font-size: 20px;
  font-weight: var(--font-weight-SemiBold);
  color: var(--header-tel-color);
  letter-spacing: 0.02em;
  white-space: nowrap;
  text-decoration: none;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}
.header-tel:hover {
  opacity: 0.7;
  text-decoration: none;
}

.header-tel-label {
  font-family: var(--font-ja);
  font-weight: var(--font-weight-Medium);
  font-size: 13px;
  color: var(--header-tel-color);
  letter-spacing: 0.01em;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}

/* お問い合わせCTAボタン（封筒アイコン付き） */
.btn-contact {
  position: relative;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 8px;
  height: 50px;
  padding-inline: 20px;
  overflow: hidden;
  background: var(--color-primary);
  border-radius: 10px;
  font-family: var(--font-ja);
  font-size: 16px;
  font-weight: var(--font-weight-Bold);
  color: #fff;
  text-decoration: none;
  white-space: nowrap;
  -webkit-transition: opacity 0.25s ease, -webkit-transform 0.25s ease, -webkit-box-shadow 0.25s ease;
  transition: opacity 0.25s ease, -webkit-transform 0.25s ease, -webkit-box-shadow 0.25s ease;
  transition: transform 0.25s ease, box-shadow 0.25s ease, opacity 0.25s ease;
  transition: transform 0.25s ease, box-shadow 0.25s ease, opacity 0.25s ease, -webkit-transform 0.25s ease, -webkit-box-shadow 0.25s ease;
}
.btn-contact::before {
  content: "";
  position: absolute;
  top: 0;
  left: -120%;
  width: 80%;
  height: 100%;
  background: linear-gradient(120deg, transparent 0%, rgba(255, 255, 255, 0.35) 50%, transparent 100%);
  -webkit-transform: skewX(-20deg);
          transform: skewX(-20deg);
  -webkit-transition: left 0.45s ease;
  transition: left 0.45s ease;
}
.btn-contact:hover {
  opacity: 1;
  text-decoration: none;
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
  -webkit-box-shadow: 0 8px 18px rgba(7, 130, 130, 0.16);
          box-shadow: 0 8px 18px rgba(7, 130, 130, 0.16);
}
.btn-contact:hover::before {
  left: 120%;
}
.btn-contact:hover .btn-contact-icon {
  -webkit-transform: translateX(-3px);
          transform: translateX(-3px);
}
.btn-contact .btn-contact-icon {
  position: relative;
  z-index: 1;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -webkit-transition: -webkit-transform 0.25s ease;
  transition: -webkit-transform 0.25s ease;
  transition: transform 0.25s ease;
  transition: transform 0.25s ease, -webkit-transform 0.25s ease;
}

/* ヒーローはheaderの下から始まるため wrapper の padding-top は不要 */
#wrapper {
  padding-top: 0;
}

/*==============================
	Hero
===============================*/
.sec-hero {
  position: relative;
  /* headerの高さ+マージン分だけ上に伸ばしてheaderの後ろへ回り込む */
  height: calc(100vh - 0px);
  min-height: 560px;
  background-color: #1a4040;
  overflow: hidden;
  /* テキストを左下に配置 */
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  /*&::after {
  	content: "";
  	position: absolute;
  	inset: 0;
  	background: rgba(0,0,0,0.2);
  	pointer-events: none;
  }*/
  /* ヒーロー画像のフェード切替 — フェード時間は transition: opacity の値で調整 */
}
.sec-hero .hero-slides {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.sec-hero .hero-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  -webkit-transition: opacity 1s ease-in-out;
  transition: opacity 1s ease-in-out;
}
.sec-hero .hero-slide.is-active {
  opacity: 1;
}
.sec-hero .hero-slide picture {
  display: block;
  width: 100%;
  height: 100%;
}
.sec-hero .hero-slide img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center center;
     object-position: center center;
}
@media (width <= 768px) {
  .sec-hero .hero-slide img {
    -o-object-position: 64.5% 50%;
       object-position: 64.5% 50%;
  }
}
.sec-hero .hero-inner {
  position: relative;
  z-index: 1;
  width: 100%;
  padding: 0 clamp(24px, 12.5vw, 180px) 60px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
@media (width <= 768px) {
  .sec-hero .hero-inner {
    padding: 0 clamp(20px, 5.3333333333vw, 24px) 60px;
  }
}
.sec-hero .hero-catch {
  font-family: var(--font-ja);
  font-size: clamp(54px, 7.4074074074vw, 80px);
  font-weight: var(--font-weight-Bold);
  color: #fff;
  line-height: 1.3;
  letter-spacing: 0.06em;
  margin-bottom: 16px;
}
@media (width <= 768px) {
  .sec-hero .hero-catch {
    font-size: clamp(45px, 12vw, 56px);
  }
}
.sec-hero .hero-catch .hero-catch-word {
  font-size: 112.5%;
  font-weight: inherit;
}
.sec-hero .hero-en {
  font-family: var(--font-en);
  font-size: clamp(14px, 1.8518518519vw, 20px);
  font-weight: var(--font-weight-SemiBold);
  color: #fff;
  letter-spacing: 0.06em;
}
@media (width <= 768px) {
  .sec-hero .hero-en {
    font-size: clamp(18px, 4.8vw, 18px);
  }
}

/*==============================
	NEWS
===============================*/
.sec-news {
  background: var(--color-bg);
}
.sec-news .sec-inner {
  padding-top: 50px;
  padding-bottom: 50px;
}
.sec-news .sec-heading {
  margin-bottom: 20px;
}
.sec-news .sec-heading .en-heading {
  font-size: clamp(24px, 2.962962963vw, 32px);
}

.news-list {
  margin-top: 16px;
}

.news-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 12px;
  padding: 16px 0;
}

.news-icon {
  width: 20px;
  height: 20px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  margin-top: 3px;
}

.news-body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 4px;
}

.news-date {
  display: block;
  font-family: var(--font-en);
  font-size: 14px;
  font-weight: var(--font-weight-SemiBold);
  color: var(--color-primary);
  letter-spacing: 0.1em;
}

.news-text {
  font-family: var(--font-ja);
  font-size: 16px;
  color: var(--color-text);
  line-height: 1.6;
}

/*==============================
	ABOUT
===============================*/
.sec-about .sec-inner {
  padding-top: 70px;
  padding-bottom: 70px;
}
.sec-about .about-heading .en-heading {
  font-size: clamp(40px, 4.4444444444vw, 48px);
  color: #fff;
  -webkit-text-fill-color: #fff;
  background: none;
}
@media (width <= 768px) {
  .sec-about .about-heading .en-heading {
    font-size: clamp(28px, 8vw, 40px);
  }
}
.sec-about .about-heading .ja-sub {
  color: #fff;
}

/* テキスト（上段）＋stats（下段）の縦並び */
.about-body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 40px;
  max-width: 800px;
  margin-inline: auto;
}

.about-main {
  min-width: 0;
}

/* リード文と説明文を左右2カラム */
.about-text-block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 56px;
  margin-top: 40px;
}
@media (width <= 768px) {
  .about-text-block {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 20px;
    margin-top: 28px;
  }
}

.about-lead {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  font-family: var(--font-ja);
  font-size: clamp(20px, 2.2222222222vw, 24px);
  font-weight: var(--font-weight-Bold);
  color: #fff;
  line-height: 1.75;
  margin-bottom: 0;
}

.about-desc {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 0px;
          flex: 1 1 0;
  min-width: 0;
  font-family: var(--font-ja);
  font-size: 15px;
  color: #fff;
  line-height: 2;
}

/* stats：横1列（3項目）、上に点線の区切り */
.about-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 2px dotted rgb(255, 255, 255);
  gap: 10px;
}
@media (width <= 768px) {
  .about-stats {
    gap: 6px;
  }
}
.stat-item {
  color: #fff;
  padding-top: 28px;
}

.stat-label {
  display: block;
  font-family: var(--font-ja);
  font-size: clamp(18px, 2.2222222222vw, 20px);
  font-weight: var(--font-weight-Bold);
  margin-bottom: 4px;
}
@media (width <= 768px) {
  .stat-label {
    font-size: clamp(15px, 4.2666666667vw, 20px);
  }
}
@media (width <= 400px) {
  .stat-label {
    font-size: clamp(12px, 3.4666666667vw, 20px);
  }
}

.stat-num-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  gap: 6px;
  line-height: 1;
}

.stat-num {
  font-family: var(--font-en);
  font-size: clamp(70px, 8.7037037037vw, 110px);
  font-weight: var(--font-weight-SemiBold);
  line-height: 1;
  color: #fff;
}
@media (width <= 768px) {
  .stat-num {
    font-size: clamp(40px, 12vw, 70px);
  }
}
@media (width <= 400px) {
  .stat-num {
    font-size: clamp(36px, 10.9333333333vw, 70px);
  }
}

.js-slot-number {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  font-variant-numeric: tabular-nums;
}
.js-slot-number .slot-digit {
  display: inline-block;
  height: 1em;
  overflow: hidden;
  line-height: 1;
}
.js-slot-number .slot-digit-reel {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-transform: translateY(0);
          transform: translateY(0);
  -webkit-transition: -webkit-transform var(--slot-duration, 1s) cubic-bezier(0.18, 0.8, 0.22, 1) var(--slot-delay, 0s);
  transition: -webkit-transform var(--slot-duration, 1s) cubic-bezier(0.18, 0.8, 0.22, 1) var(--slot-delay, 0s);
  transition: transform var(--slot-duration, 1s) cubic-bezier(0.18, 0.8, 0.22, 1) var(--slot-delay, 0s);
  transition: transform var(--slot-duration, 1s) cubic-bezier(0.18, 0.8, 0.22, 1) var(--slot-delay, 0s), -webkit-transform var(--slot-duration, 1s) cubic-bezier(0.18, 0.8, 0.22, 1) var(--slot-delay, 0s);
  will-change: transform;
}
.js-slot-number .slot-digit-num {
  display: block;
  height: 1em;
  line-height: 1;
  font-family: var(--font-en);
  font-weight: var(--font-weight-SemiBold);
}
.js-slot-number.is-slot-started .slot-digit-reel, .js-slot-number.is-scroll-in .slot-digit-reel {
  -webkit-transform: translateY(calc(var(--slot-steps) * -1em));
          transform: translateY(calc(var(--slot-steps) * -1em));
}

@media (prefers-reduced-motion: reduce) {
  .js-slot-number .slot-digit-reel {
    -webkit-transform: translateY(calc(var(--slot-steps) * -1em));
            transform: translateY(calc(var(--slot-steps) * -1em));
    -webkit-transition: none;
    transition: none;
  }
}
.stat-unit {
  font-family: var(--font-ja);
  font-size: clamp(18px, 1.8518518519vw, 20px);
  font-weight: var(--font-weight-Bold);
  padding-bottom: 8px;
  color: #fff;
}
@media (width <= 768px) {
  .stat-unit {
    font-size: clamp(14px, 1.3888888889vw, 18px);
  }
}

/*==============================
	SERVICE
===============================*/
.sec-service {
  padding-top: 115px;
  background: var(--color-bg);
}
.sec-service .sec-inner {
  padding-bottom: 130px;
}
.sec-service .sec-heading {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 8px 16px;
  margin-bottom: 40px;
}

.sec-heading-desc {
  font-family: var(--font-ja);
  font-size: clamp(15px, 1.7777777778vw, 16px);
  font-weight: var(--font-weight-Bold);
  color: var(--color-text);
  text-align: right;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  letter-spacing: 0.04em;
}
@media (width <= 768px) {
  .sec-heading-desc {
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
    text-align: left;
  }
}

.service-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(20px, 2.7777777778vw, 30px);
  margin-top: 60px;
}
@media (width <= 768px) {
  .service-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (width <= 400px) {
  .service-grid {
    grid-template-columns: 1fr;
  }
}

.service-card {
  background: #fff;
  border-radius: 10px;
  -webkit-box-shadow: 0 2px 10px rgba(133, 133, 133, 0.25);
          box-shadow: 0 2px 10px rgba(133, 133, 133, 0.25);
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.service-card .card-img {
  aspect-ratio: 340/220;
  overflow: hidden;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.service-card .card-img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: -webkit-transform 0.3s ease-out;
  transition: -webkit-transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
}
.service-card {
  /*
  &:hover .card-img img {
  	transform: scale(1.05);
  }*/
}
.service-card .card-title {
  font-family: var(--font-ja);
  font-size: clamp(18px, 1.8518518519vw, 20px);
  font-weight: var(--font-weight-Bold);
  color: #000;
  text-align: center;
  padding: 16px 0;
  line-height: 1.6;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media (width <= 768px) {
  .service-card .card-title {
    font-size: clamp(16px, 4.2666666667vw, 16px);
  }
}
.service-card {
  /* ロゴカード（サイレントパイラー）：画像をobject-containで表示 */
}
.service-card--logo .card-img--logo {
  background: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 32px 40px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
.service-card--logo .card-img--logo img {
  -o-object-fit: contain;
     object-fit: contain;
}

/*==============================
	MACHINE
===============================*/
.sec-machine {
  padding-bottom: 150px;
  background: var(--color-bg);
}
.sec-machine .machine-heading-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 24px 32px;
  margin-bottom: 32px;
}
@media (width <= 768px) {
  .sec-machine .machine-heading-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.machine-heading-main {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 22px;
}
@media (width <= 768px) {
  .machine-heading-main {
    width: 100%;
  }
}

.machine-heading {
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  gap: 8px 16px;
}

.machine-note {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 12px;
  margin-block: 40px;
  font-family: var(--font-ja);
  font-size: 1.4rem;
  font-weight: var(--font-weight-Bold);
  color: var(--color-text);
  line-height: 1.4;
}
@media (width <= 768px) {
  .machine-note {
    margin-block: 24px 12px;
    margin-inline: auto;
  }
}

.machine-note-icon {
  width: 28px;
  height: 28px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

/* 見出し右の「保有機材数 32台」 */
.machine-total-label {
  font-family: var(--font-ja);
  font-size: clamp(15px, 1.7777777778vw, 16px);
  font-weight: var(--font-weight-Bold);
  color: var(--color-text);
  margin-left: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  gap: 4px;
  line-height: 1;
  white-space: nowrap;
}
@media (width <= 768px) {
  .machine-total-label {
    margin-left: 0;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-inline: auto;
  }
}
.machine-total-label .machine-total-num {
  display: inline-block;
  margin-inline: 5px;
  font-family: var(--font-en);
  font-size: clamp(70px, 8.8888888889vw, 96px);
  font-weight: var(--font-weight-Bold);
  line-height: 1;
  -webkit-transform: translate(0, 16%);
          transform: translate(0, 16%);
}

/* 3カラムグリッド */
.machine-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (width <= 768px) {
  .machine-grid {
    max-width: 480px;
    margin-inline: auto;
    grid-template-columns: 1fr;
  }
}

.machine-col {
  background: #fff;
  border-radius: 10px;
  -webkit-box-shadow: 0 2px 10px rgba(133, 133, 133, 0.25);
          box-shadow: 0 2px 10px rgba(133, 133, 133, 0.25);
  padding: 32px 28px 28px;
}

/* カードヘッダー：アイコン→タイトル→台数 縦中央揃え */
.machine-col-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 10px;
  margin-bottom: 16px;
  text-align: center;
}

.machine-col-icon {
  width: 52px;
  height: 52px;
  -o-object-fit: contain;
     object-fit: contain;
}
.machine-col-icon.--crane {
  width: 34px;
}
.machine-col-icon.--pile {
  width: 40px;
}
.machine-col-icon.--trac {
  width: 65px;
}

.machine-col-title {
  font-family: var(--font-ja);
  font-size: 18px;
  font-weight: var(--font-weight-Bold);
  color: var(--color-text);
}

.machine-col-count {
  margin-top: 5px;
  font-family: var(--font-ja);
  font-size: 16px;
  font-weight: var(--font-weight-Bold);
  color: var(--color-text);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  gap: 2px;
  line-height: 1;
}
.machine-col-count .count-num {
  display: inline-block;
  margin-inline: 4px;
  font-family: var(--font-en);
  font-size: 32px;
  font-weight: var(--font-weight-Bold);
  line-height: 1;
  letter-spacing: 0.02em;
}

/* 点線ディバイダー */
.machine-divider {
  border: none;
  border-top: 1.5px dotted var(--color-primary);
  margin: 0 0 16px;
}

/* 機材リスト */
.machine-list .machine-item {
  padding: 7px 0;
  font-family: var(--font-ja);
  font-size: clamp(15px, 1.6666666667vw, 18px);
  line-height: 1.25;
  color: #000;
}
.machine-list .machine-item-link,
.machine-list .machine-item-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 20px 2em;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 8px;
  color: inherit;
  text-decoration: none;
  width: 100%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
.machine-list .machine-item-link:hover {
  text-decoration: none;
  opacity: 0.8;
}
.machine-list .item-name {
  min-width: 0;
  font-weight: var(--font-weight-Bold);
}
.machine-list .machine-pdf-badge {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 20px;
  height: 20px;
}
.machine-list .machine-pdf-placeholder {
  display: block;
  width: 20px;
  height: 20px;
}
.machine-list .machine-pdf-icon {
  width: 20px;
  height: 20px;
  display: block;
}
.machine-list .item-count {
  display: block;
  width: 100%;
  justify-self: end;
  text-align: right;
  font-family: var(--font-en);
  font-size: 1.6rem;
  font-weight: var(--font-weight-Bold);
  color: var(--color-primary);
  white-space: nowrap;
}

/*==============================
	WORKS
===============================*/
.sec-works {
  overflow: hidden;
  border-radius: 8px;
}

/* 左右2分割レイアウト（sec-inner不使用） */
.works-layout {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-width: 1180px;
  margin-inline: auto;
}
@media (width <= 768px) {
  .works-layout {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

/* 左：テキストエリア */
.works-content {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 auto;
          flex: 1 1 auto;
  min-width: 0;
  padding: 10px clamp(20px, 4.5vw, 90px) 10px clamp(20px, 6vw, 130px);
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.works-content .works-heading .en-heading {
  font-size: clamp(36px, 5vw, 72px);
  color: #fff;
  -webkit-text-fill-color: #fff;
  background: none;
}
.works-content .works-heading .ja-sub {
  color: #fff;
}
@media (width <= 768px) {
  .works-content {
    padding: 30px 28px 30px;
  }
}

/* 500件以上 横並びstat */
.works-stat {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 18px;
  margin-top: 50px;
  color: #fff;
  line-height: 1;
}
@media (width <= 400px) {
  .works-stat {
    gap: 10px;
  }
}

.works-stat-label {
  font-family: var(--font-ja);
  font-size: clamp(18px, 2.2222222222vw, 24px);
  font-weight: var(--font-weight-Bold);
  line-height: 1.5;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.works-stat-num {
  font-family: var(--font-en);
  font-size: clamp(80px, 8.7037037037vw, 110px);
  font-weight: var(--font-weight-SemiBold);
  line-height: 1;
  color: #fff;
}
@media (width <= 768px) {
  .works-stat-num {
    font-size: clamp(60px, 17.0666666667vw, 80px);
  }
}

.works-stat-unit {
  font-family: var(--font-ja);
  font-size: clamp(18px, 2.2222222222vw, 24px);
  font-weight: var(--font-weight-Bold);
  line-height: 1.5;
  -ms-flex-item-align: end;
      align-self: flex-end;
  padding-bottom: 12px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media (width <= 768px) {
  .works-stat-unit {
    font-size: clamp(16px, 4.2666666667vw, 18px);
    padding-bottom: 8px;
    line-height: 1.2;
  }
}

.works-desc {
  font-family: var(--font-ja);
  font-size: 15px;
  color: #fff;
  line-height: 2;
  margin-top: 38px;
  max-width: 520px;
}

.works-cta {
  margin-top: 54px;
  max-width: 300px;
}
@media (width <= 768px) {
  .works-cta {
    width: 100%;
  }
}

.btn-works {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: relative;
  gap: 20px;
  height: 56px;
  padding-inline: 26px;
  border-radius: 28px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border: 1px solid var(--color-white);
  background: #fff;
  font-family: var(--font-ja);
  font-size: 1.8rem;
  font-weight: var(--font-weight-Bold);
  color: var(--color-primary);
  -webkit-box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
          box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
  text-decoration: none;
  -webkit-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
}
.btn-works::after {
  content: "▶";
  position: absolute;
  top: 50%;
  right: 16px;
  width: 14px;
  height: 14px;
  font-size: 1.2rem;
  line-height: 1;
  content: "";
  background: url("images/arw-01-r-green.svg") center/contain no-repeat;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
  -webkit-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
}
.btn-works:hover {
  opacity: 0.85;
  text-decoration: none;
  background-color: var(--color-primary);
  color: var(--color-white);
}
.btn-works:hover::after {
  right: 6px;
  background-image: url("images/arw-01-r-white.svg");
}
@media (width <= 400px) {
  .btn-works {
    width: 100%;
    padding-inline: 44px 24px;
  }
}

/* 右：縦スライダー画像（モバイルでは横スライド） */
.works-gallery {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 clamp(340px, 40vw, 450px);
          flex: 0 0 clamp(340px, 40vw, 450px);
  overflow: hidden;
  position: relative;
  width: clamp(340px, 40vw, 450px);
  visibility: visible;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
@media (width <= 768px) {
  .works-gallery {
    -ms-flex-preferred-size: auto;
        flex-basis: auto;
    width: 100%;
  }
}
.works-gallery .splide__track {
  width: 100%;
}
.works-gallery .splide__list {
  width: 100%;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
}
.works-gallery .splide__slide {
  display: block;
  overflow: hidden;
  max-width: 100%;
  width: 100% !important;
  height: auto !important;
}
@media (width <= 768px) {
  .works-gallery .splide__slide {
    height: auto !important;
    aspect-ratio: 856/436;
  }
  .works-gallery .splide__slide img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
}

.works-img {
  display: block;
  width: 100%;
  height: auto;
  max-width: 100%;
}
.works-img img {
  inline-size: 100%;
  width: 100%;
  height: auto;
  display: block;
}

/*==============================
	ARCHIVE WORKS
===============================*/
.archive-works-page {
  background: var(--color-bg);
}

.archive-main {
  padding: 150px var(--section-pad-h) 130px;
}

.archive-breadcrumb {
  max-width: 960px;
  margin-inline: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 14px;
  font-family: var(--font-ja);
  font-size: 1.2rem;
  font-weight: var(--font-weight-Bold);
  color: #8f8f8f;
}
.archive-breadcrumb a {
  color: var(--color-primary);
  font-family: var(--font-en);
  text-decoration: underline;
  text-underline-offset: 4px;
}
.archive-breadcrumb a::after {
  content: "▶";
  display: inline-block;
  margin-left: 12px;
  font-size: 0.9rem;
  text-decoration: none;
}
.archive-breadcrumb a:hover {
  opacity: 0.75;
  text-decoration: underline;
}

.archive-works {
  max-width: 960px;
  margin: 112px auto 0;
}

.archive-page-heading {
  text-align: center;
}
.archive-page-heading h1 {
  font-family: var(--font-en);
  font-size: clamp(5.6rem, 5.7vw, 8rem);
  font-weight: var(--font-weight-SemiBold);
  color: var(--color-primary);
  letter-spacing: 0.1em;
  line-height: 1;
}
.archive-page-heading p {
  position: relative;
  margin-top: 34px;
  padding-bottom: 28px;
  font-family: var(--font-ja);
  font-size: 2.4rem;
  font-weight: var(--font-weight-Bold);
  color: var(--color-text);
  letter-spacing: 0.1em;
}
.archive-page-heading p::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 42px;
  height: 3px;
  background: var(--color-primary);
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}

.archive-works-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  -webkit-column-gap: 32px;
     -moz-column-gap: 32px;
          column-gap: 32px;
  row-gap: 54px;
  margin-top: 72px;
}
@media (width <= 768px) {
  .archive-works-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (width <= 400px) {
  .archive-works-grid {
    grid-template-columns: 1fr;
  }
}

.archive-work-card a {
  display: block;
  color: #000;
  text-decoration: none;
}
.archive-work-card a:hover {
  text-decoration: none;
}
.archive-work-card a:hover figure img {
  -webkit-transform: scale(1.04);
          transform: scale(1.04);
}
.archive-work-card a:hover h2::after {
  -webkit-transform: translateX(4px);
          transform: translateX(4px);
}
.archive-work-card figure {
  overflow: hidden;
  border-radius: 5px;
  aspect-ratio: 312/170;
  background: #e5e5e5;
}
.archive-work-card figure img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  -webkit-transition: -webkit-transform 0.3s ease-out;
  transition: -webkit-transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
}
.archive-work-card h2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 16px;
  margin-top: 22px;
  font-family: var(--font-ja);
  font-size: 1.6rem;
  font-weight: var(--font-weight-Bold);
  line-height: 1.5;
  color: #000;
}
.archive-work-card h2::after {
  content: "▶";
  font-size: 1rem;
  color: var(--color-primary);
  -webkit-transition: -webkit-transform 0.2s ease-out;
  transition: -webkit-transform 0.2s ease-out;
  transition: transform 0.2s ease-out;
  transition: transform 0.2s ease-out, -webkit-transform 0.2s ease-out;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.archive-pagination {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 84px;
  font-family: var(--font-en);
  font-weight: var(--font-weight-Bold);
}
.archive-pagination .wp-pagenavi {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 8px;
}
.archive-pagination .page,
.archive-pagination .current,
.archive-pagination .nextpostslink,
.archive-pagination .previouspostslink,
.archive-pagination .first,
.archive-pagination .last,
.archive-pagination .extend {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  min-width: 28px;
  height: 28px;
  font-size: 1.4rem;
  text-decoration: none;
}
.archive-pagination .page,
.archive-pagination .nextpostslink,
.archive-pagination .previouspostslink,
.archive-pagination .first,
.archive-pagination .last {
  background: var(--color-primary);
  color: #fff;
}
.archive-pagination .page:hover,
.archive-pagination .nextpostslink:hover,
.archive-pagination .previouspostslink:hover,
.archive-pagination .first:hover,
.archive-pagination .last:hover {
  opacity: 0.8;
}
.archive-pagination .current {
  background: #e6eeee;
  color: var(--color-primary);
}
.archive-pagination .extend {
  color: var(--color-primary);
}

.archive-works-page .site-footer {
  border-top: 1px solid #ddd;
}

.single-works-page {
  background: var(--color-bg);
}

.single-works-main {
  padding: 150px var(--section-pad-h) 120px;
}

.single-breadcrumb a + a {
  color: var(--color-primary);
  font-family: var(--font-ja);
}
.single-breadcrumb a + a::after {
  content: "▶";
}

.single-works-detail {
  max-width: 760px;
  margin: 90px auto 0;
}

.single-works-title {
  font-family: var(--font-ja);
  font-size: 2.4rem;
  font-weight: var(--font-weight-Bold);
  color: #000;
  line-height: 1.5;
  margin-bottom: 28px;
}

.single-works-viewer {
  position: relative;
}

.single-works-main-image {
  overflow: hidden;
  border-radius: 5px;
  aspect-ratio: 760/438;
  background: #e5e5e5;
}
.single-works-main-image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}

.single-works-arrow {
  position: absolute;
  top: 50%;
  z-index: 1;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 58px;
  height: auto;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: var(--color-primary);
  color: #fff;
  font-size: 1.6rem;
  opacity: 1;
  text-decoration: none;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  border: none;
}
@media (width <= 768px) {
  .single-works-arrow {
    width: clamp(30px, 9.0666666667vw, 50px);
  }
}
.single-works-arrow:hover {
  opacity: 0.85;
  text-decoration: none;
}
.single-works-arrow svg {
  width: 16px;
  height: 16px;
  fill: #fff;
}

.single-works-arrow-prev {
  left: -29px;
}

.single-works-arrow-next {
  right: -29px;
}

.single-works-caption {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  gap: 22px;
  margin-top: 22px;
  font-family: var(--font-ja);
  font-size: 1.6rem;
  font-weight: var(--font-weight-Bold);
  color: var(--color-text);
  line-height: 1.6;
}

.caption-count {
  font-family: var(--font-en);
  color: #aaa;
  white-space: nowrap;
}
.caption-count span {
  color: var(--color-primary);
}

.single-works-content-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  min-height: 430px;
  margin-top: 68px;
  background: #f00;
  color: #fff;
  text-align: center;
}
.single-works-content-box p {
  font-family: var(--font-ja);
  font-size: clamp(3.2rem, 4vw, 5rem);
  font-weight: var(--font-weight-Bold);
  letter-spacing: 0.08em;
}

.single-works-back {
  margin-top: 64px;
  text-align: center;
}

.btn-works-list {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: relative;
  gap: 56px;
  width: min(100%, 280px);
  height: 58px;
  padding-inline: 24px 62px;
  border: 1px solid var(--color-primary);
  background: var(--color-primary);
  border-radius: 999px;
  -webkit-box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
          box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
  font-family: var(--font-ja);
  font-size: 1.6rem;
  font-weight: var(--font-weight-Bold);
  color: #fff;
  text-decoration: none;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
}
.btn-works-list::before {
  content: "◀";
  font-size: 1.2rem;
  -webkit-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
}
.btn-works-list:hover {
  opacity: 0.85;
  text-decoration: none;
  background: #fff;
  color: var(--color-primary);
}
.btn-works-list:hover::before {
  -webkit-transform: translateX(-8px);
          transform: translateX(-8px);
}

.single-works-page .site-footer {
  border-top: 1px solid #ddd;
}

@media (width <= 768px) {
  .archive-main {
    padding-top: 120px;
    padding-bottom: 90px;
  }
  .archive-works {
    margin-top: 70px;
  }
  .archive-works-grid {
    margin-top: 54px;
  }
  .single-works-main {
    padding-top: 120px;
    padding-bottom: 90px;
  }
  .single-works-detail {
    margin-top: 70px;
  }
  .single-works-arrow-prev {
    left: -12px;
  }
  .single-works-arrow-next {
    right: -12px;
  }
  .single-works-content-box {
    min-height: 300px;
  }
}
@media (width <= 400px) {
  .single-works-caption {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 6px;
  }
}
/*==============================
	COMPANY + MESSAGE
===============================*/
.sec-company {
  padding-top: 110px;
  padding-bottom: 160px;
  background: var(--color-bg);
}
.sec-company .company-heading {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
}

.company-body {
  margin-top: 80px;
}

.message-block {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 clamp(60px, 11.1111111111vw, 120px);
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
  max-width: 1040px;
  margin-inline: auto;
  margin-bottom: 64px;
}
@media (width <= 768px) {
  .message-block {
    grid-template-columns: 1fr;
    gap: 28px;
    margin-bottom: 48px;
  }
}

.message-content {
  grid-row: 2/3;
  grid-column: 2/3;
  font-family: var(--font-ja);
}
@media (width <= 768px) {
  .message-content {
    grid-row: 3/4;
    grid-column: 1/2;
    padding-inline: 20px;
  }
}

.company-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}
.company-table th, .company-table td {
  padding: 15px 28px;
  font-family: var(--font-ja);
  font-size: clamp(15px, 1.7777777778vw, 16px);
  line-height: 2;
  vertical-align: top;
  text-align: left;
  color: #000;
}
.company-table th {
  width: 210px;
  font-weight: var(--font-weight-Medium);
  white-space: nowrap;
  border-radius: 8px 0 0 8px;
}
.company-table td {
  font-weight: var(--font-weight-Bold);
  border-radius: 0 8px 8px 0;
}
.company-table td .gmap {
  display: inline-block;
  text-decoration: none;
  -webkit-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
}
.company-table td .gmap:hover {
  color: var(--color-primary);
}
.company-table tr:nth-child(odd) th,
.company-table tr:nth-child(odd) td {
  background: #fff;
}
.company-table tr:nth-child(even) th,
.company-table tr:nth-child(even) td {
  background: transparent;
}
@media (width <= 768px) {
  .company-table th, .company-table td {
    display: block;
    width: 100%;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    padding: 12px 18px;
    font-size: 1.4rem;
  }
  .company-table th {
    font-size: 1.5rem;
    font-weight: var(--font-weight-Bold);
    letter-spacing: 0.1em;
    border-radius: 8px 8px 0 0;
    padding-bottom: 4px;
  }
  .company-table td {
    border-radius: 0 0 8px 8px;
    padding-top: 4px;
  }
}

.company-table-wrap {
  max-width: 900px;
  margin-inline: auto;
}
.company-table-wrap tr td a {
  color: #1f2bff;
  text-decoration: underline;
}

/* 会社概要：会社パンフレット（PDF）ダウンロードボタン */
.btn-pamphlet {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 14px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  max-width: 100%;
  min-width: 280px;
  height: 56px;
  padding-inline: 32px;
  margin: 40px auto 0;
  background: #fff;
  border: 2px solid var(--color-primary);
  border-radius: 8px;
  font-family: var(--font-ja);
  font-size: 15px;
  font-weight: var(--font-weight-Bold);
  color: var(--color-primary);
  text-decoration: none;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-transition: -webkit-transform 0.25s ease, -webkit-box-shadow 0.25s ease;
  transition: -webkit-transform 0.25s ease, -webkit-box-shadow 0.25s ease;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  transition: transform 0.25s ease, box-shadow 0.25s ease, -webkit-transform 0.25s ease, -webkit-box-shadow 0.25s ease;
}
.btn-pamphlet img {
  width: 24px;
  height: auto;
  display: block;
}
.btn-pamphlet:hover {
  text-decoration: none;
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
  -webkit-box-shadow: 0 8px 18px rgba(7, 130, 130, 0.16);
          box-shadow: 0 8px 18px rgba(7, 130, 130, 0.16);
}

.message-heading {
  grid-row: 1/2;
  grid-column: 2/3;
  margin-bottom: 50px;
}
@media (width <= 768px) {
  .message-heading {
    grid-column: 1/2;
    margin-bottom: 0px;
  }
}
.message-heading .en-heading {
  font-size: clamp(2.4rem, 2.5vw, 3.2rem);
  letter-spacing: 0.1em;
}
.message-heading .ja-sub {
  font-size: 1.3rem;
}

.message-catch {
  font-family: var(--font-ja);
  font-size: clamp(20px, 2.5925925926vw, 28px);
  font-weight: var(--font-weight-Bold);
  line-height: 1.7;
  margin-bottom: 24px;
}

.message-photo {
  grid-row: 2/3;
  grid-column: 1/2;
  margin: 0;
  width: 100%;
  text-align: right;
}
@media (width <= 768px) {
  .message-photo {
    text-align: center;
  }
}
.message-photo img {
  width: 100%;
  max-width: 360px;
  margin-left: auto;
  border-radius: 10px;
  aspect-ratio: 720/1000;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
@media (width <= 768px) {
  .message-photo img {
    max-width: 300px;
    margin-inline: auto;
  }
}

.message-text {
  font-family: var(--font-ja);
  font-size: 15px;
  color: var(--color-text);
  line-height: 2;
  margin-bottom: 24px;
}

.message-name {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  gap: 16px;
  font-family: var(--font-ja);
  font-weight: var(--font-weight-Bold);
  font-size: clamp(14px, 1.4814814815vw, 16px);
  color: var(--color-text);
  letter-spacing: 0.08em;
  margin: 40px 0 0;
}
.message-name .message-name-title {
  font-weight: inherit;
}
.message-name .message-name-sign {
  width: clamp(120px, 13.1481481481vw, 142px);
  height: auto;
  display: block;
}

/*==============================
	CONTACT
===============================*/
.sec-contact {
  margin-top: 0;
  margin-bottom: 0;
  border-radius: 8px;
}
.sec-contact .sec-inner {
  padding-top: 105px;
  padding-bottom: 105px;
}
.sec-contact .contact-heading {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-bottom: 70px;
}
.sec-contact .contact-heading .en-heading {
  color: #fff;
  -webkit-text-fill-color: #fff;
  background: none;
}
.sec-contact .contact-heading .ja-sub {
  color: #fff;
}

.contact-body {
  display: grid;
  grid-template-columns: clamp(165px, 24.537037037vw, 265px) 1fr;
  gap: 20px;
  /*
  padding-left:clamp(165px,pxtovw(265,xl),265px);
  */
}
@media (width <= 768px) {
  .contact-body {
    padding-inline: 0px;
    display: block;
  }
}
.contact-body .contact-dog {
  position: sticky;
  top: 100px;
  left: 0;
  width: clamp(120px, 16.8518518519vw, 182px);
}

.contact-tel-block {
  position: relative;
  text-align: left;
}
@media (width <= 768px) {
  .contact-tel-block {
    text-align: center;
  }
}
.contact-tel-block .contact-dog {
  width: clamp(120px, 16.8518518519vw, 182px);
}
@media (width <= 768px) {
  .contact-tel-block .contact-dog {
    position: static;
    display: block;
    margin-top: 40px;
    margin-inline: auto;
    -webkit-transform: translate(0%, 0%);
            transform: translate(0%, 0%);
  }
}

.contact-tel-label {
  font-family: var(--font-ja);
  font-size: clamp(24px, 2.962962963vw, 32px);
  font-weight: var(--font-weight-Bold);
  color: #fff;
  margin-bottom: 55px;
  letter-spacing: 0.04em;
}
@media (width <= 768px) {
  .contact-tel-label {
    font-size: clamp(22px, 5.8666666667vw, 28px);
    letter-spacing: 0.1em;
  }
}

.contact-tel-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 24px;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media (width <= 768px) {
  .contact-tel-wrap {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 18px 30px;
  }
}

.tel-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 14px;
  text-decoration: none;
}
.tel-item:hover {
  opacity: 0.8;
  text-decoration: none;
}
.tel-item .tel-icon {
  width: clamp(34px, 4.2592592593vw, 46px);
  aspect-ratio: 1/1;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.tel-item .tel-num {
  font-family: var(--font-en);
  font-size: clamp(34px, 3.5185185185vw, 38px);
  font-weight: var(--font-weight-SemiBold);
  color: #fff;
  letter-spacing: 0.08em;
  line-height: 1;
  white-space: nowrap;
}
@media (width <= 768px) {
  .tel-item .tel-num {
    font-size: clamp(27px, 7.4666666667vw, 36px);
  }
}

.contact-hours {
  font-family: var(--font-ja);
  font-size: clamp(14px, 1.6666666667vw, 18px);
  font-weight: var(--font-weight-Bold);
  color: #fff;
  letter-spacing: 0.06em;
  margin-top: 14px;
  padding-left: calc(14px + clamp(36px, 4.6296296296vw, 50px));
}
@media (width <= 768px) {
  .contact-hours {
    padding-left: 0;
  }
}

.contact-divider {
  border: none;
  border-top: 1px solid rgba(255, 255, 255, 0.5);
  margin: 58px auto 58px;
}
@media (width <= 768px) {
  .contact-divider {
    margin-top: 32px;
  }
}

.contact-form-title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 14px;
  font-family: var(--font-ja);
  font-size: clamp(24px, 2.962962963vw, 32px);
  font-weight: var(--font-weight-Bold);
  color: #fff;
  margin-bottom: 28px;
  letter-spacing: 0.04em;
}
@media (width <= 768px) {
  .contact-form-title {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin-inline: auto;
    font-size: clamp(22px, 5.8666666667vw, 28px);
    gap: 10px;
  }
}
.contact-form-title img {
  width: clamp(34px, 4.2592592593vw, 46px);
  aspect-ratio: 1/1;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.contact-form-desc {
  font-family: var(--font-ja);
  font-size: clamp(16px, 1.6666666667vw, 18px);
  font-weight: var(--font-weight-Bold);
  color: #fff;
  line-height: 1.6;
  margin-bottom: 70px;
  letter-spacing: 0.06em;
}
@media (width <= 768px) {
  .contact-form-desc {
    text-align: center;
  }
}

@media (width <= 768px) {
  .contact-form {
    max-width: 400px;
    width: 100%;
    margin-inline: auto;
  }
}
.contact-form .form-row {
  display: grid;
  grid-template-columns: 180px 1fr;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 26px;
  margin-bottom: 26px;
}
@media (width <= 768px) {
  .contact-form .form-row {
    grid-template-columns: 1fr;
    gap: 8px;
  }
}
.contact-form .form-row-textarea {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
}
.contact-form .form-row-textarea .form-label {
  padding-top: 10px;
}

.wpcf7 {
  width: 100%;
}
.wpcf7 .wpcf7-form-control-wrap {
  display: block;
  width: 100%;
}
.wpcf7 .wpcf7-not-valid-tip {
  font-family: var(--font-ja);
  font-size: 1.2rem;
  color: #ff0000;
  margin-top: 4px;
  display: block;
}
.wpcf7 .wpcf7-response-output {
  font-family: var(--font-ja);
  font-size: 1.4rem;
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.6);
  border-radius: 6px;
  padding: 12px 20px;
  margin-top: 24px;
  text-align: center;
}

.privacy-check .wpcf7-form-control-wrap {
  display: contents;
}
.privacy-check .wpcf7-acceptance {
  display: contents;
}
.privacy-check .wpcf7-acceptance label {
  display: contents;
}
.privacy-check .wpcf7-acceptance .wpcf7-list-item-label {
  display: none;
}

.form-label {
  font-family: var(--font-ja);
  font-size: clamp(15px, 1.7777777778vw, 16px);
  font-weight: var(--font-weight-Bold);
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  gap: 8px;
}

.form-required {
  display: inline-block;
  padding: 2px 8px;
  background: #11558F;
  color: #ffffff;
  font-size: clamp(12px, 1.5555555556vw, 14px);
  font-weight: var(--font-weight-Bold);
  border-radius: 2px;
  line-height: 1.2;
  white-space: nowrap;
}

.form-input,
.form-textarea {
  max-width: 400px;
  width: 100%;
  height: 42px;
  padding: 0 16px;
  background: #fff;
  border: none;
  border-radius: 6px;
  font-family: var(--font-ja);
  font-size: 1.5rem;
  color: var(--color-text);
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  outline: none;
}
.form-input:focus,
.form-textarea:focus {
  -webkit-box-shadow: 0 0 0 2px var(--color-primary-light);
          box-shadow: 0 0 0 2px var(--color-primary-light);
}

.form-textarea {
  height: 185px;
  padding: 12px 16px;
  resize: vertical;
}

.form-privacy {
  margin-top: 42px;
}
@media (width <= 768px) {
  .form-privacy {
    margin-left: 0;
  }
}
.form-privacy .privacy-note {
  font-family: var(--font-ja);
  font-size: 16px;
  font-weight: var(--font-weight-Bold);
  color: #fff;
  line-height: 2;
  margin-top: 18px;
}
@media (width <= 768px) {
  .form-privacy .privacy-note {
    font-size: 12px;
    letter-spacing: 0.08em;
  }
}

.privacy-check {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 14px;
  cursor: pointer;
}
@media (width <= 768px) {
  .privacy-check {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 8px;
  }
}
.privacy-check input[type=checkbox] {
  width: 20px;
  height: 20px;
  accent-color: #fff;
  cursor: pointer;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.privacy-check .privacy-check-label {
  font-family: var(--font-ja);
  font-size: 16px;
  font-weight: var(--font-weight-Bold);
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 12px;
}
@media (width <= 768px) {
  .privacy-check .privacy-check-label {
    font-size: 14px;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    letter-spacing: 0.08em;
    gap: 6px;
  }
}
.privacy-check .privacy-check-label a.policy {
  font-weight: inherit;
  color: var(--color-white);
  text-decoration: underline;
}
.privacy-check .privacy-check-label a.policy:hover {
  text-decoration: none;
}

.form-submit {
  margin-top: 48px;
  text-align: center;
}

.btn-submit {
  position: relative;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 80px;
  width: min(100%, 300px);
  height: 54px;
  padding-inline: 40px;
  background: #fff;
  border: none;
  border-radius: 6px;
  -webkit-box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
          box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
  font-family: var(--font-ja);
  font-size: clamp(16px, 2vw, 18px);
  font-weight: var(--font-weight-Bold);
  color: var(--color-primary);
  cursor: pointer;
  -webkit-transition: opacity 0.2s;
  transition: opacity 0.2s;
}
.btn-submit:hover {
  opacity: 0.85;
}
.btn-submit img {
  position: absolute;
  top: 50%;
  right: 20px;
  width: 22px;
  height: 22px;
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}

.wpcf7-submit {
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  background-color: #fff;
  background-image: url("images/i_send_btn_skyblue.svg");
  background-repeat: no-repeat;
  background-position: right 20px center;
  background-size: 22px auto;
  padding-right: 52px;
}

/*==============================
	CONTACT CONFIRM
===============================*/
.confirm-table {
  width: 100%;
  margin-bottom: 40px;
}

.confirm-row {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 16px 26px;
  padding: 16px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  font-family: var(--font-ja);
}
.confirm-row:first-child {
  border-top: 1px solid rgba(255, 255, 255, 0.2);
}
@media (width <= 768px) {
  .confirm-row {
    grid-template-columns: 1fr;
    gap: 6px;
  }
}

.confirm-label {
  font-size: clamp(14px, 1.3888888889vw, 15px);
  font-weight: var(--font-weight-Bold);
  color: rgba(255, 255, 255, 0.7);
}

.confirm-value {
  font-size: clamp(14px, 1.4814814815vw, 16px);
  font-weight: var(--font-weight-Bold);
  color: #fff;
  white-space: pre-wrap;
  word-break: break-all;
}

.confirm-actions {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 24px;
  margin-top: 48px;
}
@media (width <= 768px) {
  .confirm-actions {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    gap: 16px;
  }
}

.btn-back {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: min(100%, 300px);
  height: 54px;
  padding-inline: 40px;
  background: transparent;
  border: 2px solid rgba(255, 255, 255, 0.6);
  border-radius: 6px;
  font-family: var(--font-ja);
  font-size: clamp(16px, 2vw, 18px);
  font-weight: var(--font-weight-Bold);
  color: #fff;
  cursor: pointer;
  -webkit-transition: opacity 0.2s;
  transition: opacity 0.2s;
}
.btn-back:hover {
  opacity: 0.7;
}

.confirm_button:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.wpcf7-response-output {
  display: none !important;
}

/*==============================
	THANKS
===============================*/
.thanks-main {
  min-height: 70vh;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background: var(--color-primary);
}

.thanks-section {
  width: 100%;
  padding-block: 120px;
}

.thanks-body {
  max-width: 640px;
  margin-inline: auto;
  text-align: center;
}

.thanks-icon {
  margin-bottom: 32px;
}
.thanks-icon img {
  width: 64px;
  height: auto;
}

.thanks-heading {
  font-family: var(--font-ja);
  font-size: clamp(2rem, 2.5vw, 2.8rem);
  font-weight: var(--font-weight-Bold);
  color: #fff;
  line-height: 1.5;
  margin-bottom: 32px;
}

.thanks-text {
  font-family: var(--font-ja);
  font-size: clamp(1.4rem, 1.6vw, 1.6rem);
  color: #fff;
  line-height: 2;
  margin-bottom: 24px;
}

.thanks-note {
  font-family: var(--font-ja);
  font-size: clamp(1.2rem, 1.4vw, 1.4rem);
  color: rgba(255, 255, 255, 0.8);
  line-height: 1.8;
  margin-bottom: 48px;
}

.btn-thanks-top {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: min(100%, 280px);
  height: 54px;
  padding-inline: 32px;
  background: #fff;
  border-radius: 6px;
  -webkit-box-shadow: 0 4px 4px rgba(0, 0, 0, 0.2);
          box-shadow: 0 4px 4px rgba(0, 0, 0, 0.2);
  font-family: var(--font-ja);
  font-size: clamp(15px, 1.4814814815vw, 16px);
  font-weight: var(--font-weight-Bold);
  color: var(--color-primary);
  text-decoration: none;
  -webkit-transition: opacity 0.2s;
  transition: opacity 0.2s;
}
.btn-thanks-top:hover {
  opacity: 0.85;
  text-decoration: none;
}

/*==============================
	PRIVACY
===============================*/
.privacy-main {
  padding: 150px var(--section-pad-h) 120px;
}
@media (width <= 768px) {
  .privacy-main {
    padding-top: 120px;
    padding-bottom: 90px;
  }
}

.privacy-section {
  max-width: 800px;
  margin-top: 100px;
  margin-inline: auto;
}

.privacy-heading {
  font-family: var(--font-en);
  font-size: clamp(2.4rem, 3vw, 3.6rem);
  font-weight: var(--font-weight-Bold);
  color: var(--color-primary);
  letter-spacing: 0.06em;
  padding-bottom: 20px;
  border-bottom: 2px solid var(--color-primary);
  margin-bottom: 56px;
}

.privacy-body {
  font-family: var(--font-ja);
  font-size: clamp(1.4rem, 1.5vw, 1.6rem);
  color: var(--color-text);
  line-height: 1.9;
}
.privacy-body > p {
  margin-bottom: 28px;
}
.privacy-body h2 {
  font-size: clamp(1.5rem, 1.6vw, 1.8rem);
  font-weight: var(--font-weight-Bold);
  color: var(--color-primary);
  border-left: 4px solid var(--color-primary);
  padding-left: 14px;
  margin-top: 48px;
  margin-bottom: 18px;
  line-height: 1.5;
}
.privacy-body ul {
  padding-left: 1.4em;
  margin-bottom: 24px;
}
.privacy-body ul li {
  list-style: disc;
  margin-bottom: 8px;
}
.privacy-body ul li ul {
  margin-top: 8px;
  margin-bottom: 0;
}
.privacy-body ul li ul li {
  list-style: circle;
}
.privacy-body .privacy-contact-list {
  list-style: none;
  padding-left: 0;
  background: var(--color-bg);
  border-radius: 8px;
  padding: 28px 32px;
  margin-top: 16px;
}
.privacy-body .privacy-contact-list li {
  list-style: none;
  margin-bottom: 10px;
  padding-left: 0;
}
.privacy-body .privacy-contact-list li:last-child {
  margin-bottom: 0;
}

/*==============================
	フッター
===============================*/
.site-footer {
  background: var(--color-bg);
  padding: 125px 20px 78px;
}

.footer-inner {
  max-width: var(--container-width);
  margin-inline: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  gap: 80px;
}
@media (width <= 768px) {
  .footer-inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    text-align: center;
    gap: 48px;
  }
}

.footer-left {
  width: min(100%, 800px);
}

.footer-logo {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-decoration: none;
  margin-bottom: 24px;
}
.footer-logo img {
  width: 210px;
  height: auto;
  display: block;
}
.footer-logo:hover {
  opacity: 0.8;
  text-decoration: none;
}

.footer-name {
  font-family: var(--font-ja);
  font-size: 15px;
  font-weight: var(--font-weight-Bold);
  color: #000;
  letter-spacing: 0.06em;
  margin-bottom: 8px;
}

.footer-address {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 8px 18px;
  font-family: var(--font-ja);
  font-size: 15px;
  font-weight: var(--font-weight-Bold);
  color: #000;
  line-height: 1.8;
  font-style: normal;
  margin-bottom: 28px;
}
.footer-address a {
  color: var(--color-text);
  font-family: var(--font-en);
  font-weight: var(--font-weight-Bold);
  text-decoration: none;
}
.footer-address a:hover {
  text-decoration: underline;
}
@media (width <= 768px) {
  .footer-address {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

.footer-tel-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 20px;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-bottom: 4px;
}
@media (width <= 768px) {
  .footer-tel-wrap {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

.footer-tel {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 7px;
  font-family: var(--font-en);
  font-size: clamp(24px, 2.962962963vw, 32px);
  font-weight: var(--font-weight-SemiBold);
  color: var(--color-primary);
  letter-spacing: 0.06em;
  text-decoration: none;
  line-height: 1;
  white-space: nowrap;
}
.footer-tel img {
  width: clamp(28px, 3.3333333333vw, 36px);
  aspect-ratio: 1/1;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.footer-tel:hover {
  opacity: 0.75;
  text-decoration: none;
}

.footer-hours {
  font-family: var(--font-ja);
  font-size: 15px;
  font-weight: var(--font-weight-Bold);
  color: var(--color-primary);
  letter-spacing: 0.06em;
  margin-left: calc(7px + clamp(28px, 3.3333333333vw, 36px));
  margin-bottom: 30px;
}
@media (width <= 768px) {
  .footer-hours {
    margin-left: 0;
  }
}

.btn-footer-contact {
  position: relative;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 18px;
  width: min(100%, 290px);
  height: 50px;
  padding-inline: 22px;
  overflow: hidden;
  background: var(--color-primary);
  border-radius: 6px;
  font-family: var(--font-ja);
  font-size: 14px;
  font-weight: var(--font-weight-Bold);
  color: #fff;
  text-decoration: none;
  -webkit-transition: opacity 0.25s ease, -webkit-transform 0.25s ease, -webkit-box-shadow 0.25s ease;
  transition: opacity 0.25s ease, -webkit-transform 0.25s ease, -webkit-box-shadow 0.25s ease;
  transition: transform 0.25s ease, box-shadow 0.25s ease, opacity 0.25s ease;
  transition: transform 0.25s ease, box-shadow 0.25s ease, opacity 0.25s ease, -webkit-transform 0.25s ease, -webkit-box-shadow 0.25s ease;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
.btn-footer-contact::before {
  content: "";
  position: absolute;
  top: 0;
  left: -120%;
  width: 80%;
  height: 100%;
  background: linear-gradient(120deg, transparent 0%, rgba(255, 255, 255, 0.35) 50%, transparent 100%);
  -webkit-transform: skewX(-20deg);
          transform: skewX(-20deg);
  -webkit-transition: left 0.45s ease;
  transition: left 0.45s ease;
}
.btn-footer-contact img {
  position: relative;
  z-index: 1;
  width: 22px;
  height: auto;
  -webkit-transition: -webkit-transform 0.25s ease;
  transition: -webkit-transform 0.25s ease;
  transition: transform 0.25s ease;
  transition: transform 0.25s ease, -webkit-transform 0.25s ease;
}
.btn-footer-contact:hover {
  opacity: 1;
  text-decoration: none;
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
  -webkit-box-shadow: 0 8px 18px rgba(7, 130, 130, 0.16);
          box-shadow: 0 8px 18px rgba(7, 130, 130, 0.16);
}
.btn-footer-contact:hover::before {
  left: 120%;
}
.btn-footer-contact:hover img {
  -webkit-transform: translateX(-3px);
          transform: translateX(-3px);
}

.footer-right {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  width: min(100%, 300px);
}

.footer-top-link {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
}

.footer-top-dog {
  width: 130px;
  height: auto;
  margin-bottom: 16px;
}

.fix_foot {
  position: fixed;
  right: clamp(16px, 3vw, 40px);
  bottom: clamp(16px, 3vw, 40px);
  z-index: 250;
  pointer-events: none;
}
.fix_foot .footer-top-link {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: clamp(80px, 11.1111111111vw, 120px);
  pointer-events: auto;
  -webkit-transition: opacity 0.2s ease, -webkit-transform 0.2s ease;
  transition: opacity 0.2s ease, -webkit-transform 0.2s ease;
  transition: transform 0.2s ease, opacity 0.2s ease;
  transition: transform 0.2s ease, opacity 0.2s ease, -webkit-transform 0.2s ease;
}
.fix_foot .footer-top-link:hover {
  opacity: 0.85;
  text-decoration: none;
  -webkit-transform: translateY(-4px);
          transform: translateY(-4px);
}
.fix_foot .footer-top-dog {
  width: 100%;
  margin-bottom: 0;
}
@media (width <= 768px) {
  .fix_foot {
    right: max(10px, env(safe-area-inset-right));
    bottom: max(12px, env(safe-area-inset-bottom));
  }
  .fix_foot .footer-top-link {
    width: clamp(72px, 20vw, 96px);
  }
}

.copyright {
  display: block;
  margin-top: 40px;
  font-family: var(--font-en);
  font-size: 14px;
  font-weight: var(--font-weight-SemiBold);
  color: var(--color-text);
  letter-spacing: 0.1em;
  white-space: nowrap;
}

.privacy-link,
.pamphlet-link {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-top: 20px;
  font-family: var(--font-ja);
  font-size: 14px;
  font-weight: var(--font-weight-Bold);
  color: var(--color-text);
  text-decoration: none;
}
@media (width <= 768px) {
  .privacy-link,
  .pamphlet-link {
    margin-inline: auto;
  }
}
.privacy-link:hover,
.pamphlet-link:hover {
  text-decoration: underline;
}/*# sourceMappingURL=style.css.map */