@charset "UTF-8";/* 2025.12.26 */

/* =========================================
   Header base
========================================= */
header{
  position: relative; /* PC=relative, SPでfixedに上書き */
  top:0; left:0;
  width:100%;
  font-size:1.6rem; line-height:1.2;
  z-index:100;
  backface-visibility:hidden;
  transition:.5s;
}
.plus1 header{
  background:rgba(255,255,255,.5);
  backdrop-filter:blur(10px);
}
header .container-l{ padding-left:2vw; padding-right:2vw; }

@media (max-width:769px){ .plus1 header{ height:62px; } }
@media (min-width:768px){ header::after{ height:92px; } }
@media (min-width:1600px){ header .container-l{ padding-left:30px; padding-right:30px; } }

header .h_right_top{
  font-size:1.4rem; line-height:1.6rem; padding-bottom:.3rem; text-align:left;
}
header .h_right_top .txt_bold{ font-weight:bold; filter:contrast(.5); }

header .btn_link{ padding:0 .3rem; }
header .btn_link a{
  font-size:1.2rem; padding:5px; display:flex; justify-content:center; align-items:center;
  width:100%; height:100%; transition:.5s;
}
@media (min-width:900px){ header .btn_link a{ padding:10px; } }
header .btn_link a img{ margin:0 5px; max-width:50% !important; }

header .h_logo{
  margin-top:10px; width:300px; max-width:40%;
  text-align:left; position:relative; z-index:9999;
}
@media (min-width:600px){ header .h_logo{ max-width:30%; } }

@media (min-width:1081px){
  header{ position:fixed; font-size:1.6rem; }
  header .inner{ display:flex; justify-content:space-between; }
  header .h_logo{ margin-top:18px; }
  header .nav_top{ display:flex; justify-content:flex-end; align-items:center; padding:10px 10px 10px 0; }
}
@media (min-width:576px){
  header > .container{ max-width:1920px; position:relative; }
}
@media (min-width:768px){
  header .container .inner{ display:flex; justify-content:space-between; }
  header .h_right_top{ display:flex; justify-content:flex-end; align-items:stretch; }
}

/* SP：ヘッダー周りの細部 */
@media (max-width:767px){
  header .lead{ display:none; }
  header .h_logo > a > img{ max-width:100%; padding-top:0; }
  header .h_right_top{ max-width:calc(100% - 6rem); padding:1rem; border-radius:.5rem; }
  header .btn_link a{ border:1px solid #fff; }
  header .btn_link{
    position:absolute; bottom:20px; left:0; right:0; margin:auto; width:240px;
    padding:0; background:#222; z-index:991;
  }
}

/* =========================================
   Global Nav 共通
========================================= */
header #gnav a{ display:block; text-decoration:none; }
header #gnav a:hover,
#gnav a:focus{ text-decoration:none; }

/* =========================================
   PC Global Nav
========================================= */
@media (min-width:1081px){
  header .h_logo img{ max-width:100%; }
  header #gnavArea{ padding-top:40px; width:630px; }
  header #gnav_btn{ display:none !important; }
  header #gnav nav{ text-align:right; }

  header .gnav_menu{
    margin:20px 0 0; padding:0;
    display:inline-flex; justify-content:space-between; flex-wrap:nowrap; position:relative;
  }
  header .gnav_menu > li{
    margin:0; padding:0; position:relative; display:flex; align-items:center;
  }
  header .gnav_menu > li > a{
    padding:0 1rem; margin:0; display:block; white-space:nowrap;
    transition:.2s; position:relative; z-index:999; text-align:center; text-decoration:none;
  }
  header .gnav_menu > li .ac-btn{ padding-right:14px; margin-right:4px; }
  header .gnav_menu > li .ac-btn::after{
    content:''; position:absolute; right:0; bottom:0; width:10px; height:10px;
    background:url("../images/chevron-down.svg") no-repeat top left / contain;
  }

  header #h-nav > .h_btn{ position:absolute; top:-66px; right:0; }
  header #h-nav > .h_btn .btn{
    font-size:1.4rem; width:140px; height:50px; padding-bottom:6px; margin-left:6px;
    border-radius:0 0 5px 5px; display:flex; justify-content:center; align-items:flex-end;
  }
  header #h-nav > .h_btn .btn.h_btn_03{ width:106px; }
  header .h_btn_01{ background:var(--main); color:#fff; }
  header .h_btn_02{ background:var(--sub01); color:#fff; }
  header .h_btn_03{ color:var(--main); background:#fff; border:1px solid var(--main); }
  header .h_btn_01:hover, header .h_btn_02:hover{ color:#fff !important; }

  header #gnavArea{ width:auto; }
}

/* =========================================
   Dropdown 共通
========================================= */
#h-nav > li{ position:relative; }
#h-nav > li .dropdown__lists > li > a{ padding:20px; text-align:left; display:block; }
#h-nav .dropdown__lists{ display:none; width:200px; position:relative; }
#h-nav .dropdown__list{ display:block; padding:0; width:100%; height:auto; text-align:center; transition:.5s; }

/* SP ドロップダウン */
@media (max-width:1080px){
  #h-nav .dropdown__lists{ width:100%; }
  #h-nav .ac-btn.open + .dropdown__lists{
    width:auto; padding-bottom:10px; border-bottom:1px solid var(--light01);
  }
  #h-nav > li .dropdown__lists > li > .ttl_menu01{ padding:10px 0 5px 1em; }
  #h-nav > li .dropdown__lists > li > .ttl_menu01 span{ display:none; }
  #h-nav > li .dropdown__lists > li > .ttl_menu02{ padding:5px 0 5px 1.5em; font-size:1.3rem; font-weight:400; }
  #h-nav > li .dropdown__lists > li > .ttl_menu02.indent1{ margin-left:1.5em; }
}

/* PC ドロップダウン */
@media (min-width:1081px){
  #h-nav .dropdown__lists{ background:var(--main); opacity:.9; }
  #h-nav > li:hover .dropdown__lists{
    display:block; height:auto; position:absolute; top:130%; left:-35%; right:0;
    border-radius:5px; padding:10px 5px;
  }
  #h-nav > li .dropdown__lists > li > a{ color:#fff !important; padding:6px 10px; font-size:1.3rem; }
  #h-nav > li .dropdown__lists > li > .indent1{ margin-left:1em; }
  #h-nav > li .dropdown__lists > li > .ttl_menu01{ font-size:1.6rem; font-weight:500; }
  #h-nav > li .dropdown__lists > li > .ttl_menu01 span{ display:none; }
}

/* =========================================
   SP Global Nav（全画面オーバーレイ）
   - 初期：非表示
   - body.open：表示／操作可
   - 内側スクロールは #gnav > nav のみ
========================================= */
@media (max-width:1080px){

  /* 固定ヘッダー & 背景スクロール抑止 */
  header{ position:fixed; top:0; left:0; z-index:2000; }
  html.bk_fixed{ width:100%; height:100%; overflow:hidden; }

  /* ハンバーガー */
  header #gnav_btn{
    position:absolute; top:2rem; right:2rem;
    padding:0; margin:0; border:0; background:transparent; cursor:pointer; z-index:9999;
  }
  .open header #gnav_btn{ position:fixed; }
  header #gnav_btn > div{ width:24px; height:18px; position:relative; }
  header #gnav_btn > div::after{
    content:''; position:absolute; left:-13px; top:-16px; width:50px; height:50px;
    background:var(--main); border-radius:25px; z-index:-1; display:block;
  }
  header #gnav_btn > div > span{
    position:absolute; left:0; width:100%; height:3px; background:#fff; transition:all .5s;
  }
  header #gnav_btn > div > span:nth-of-type(1){ top:0; }
  header #gnav_btn > div > span:nth-of-type(2){ top:calc(50% - 2px); }
  header #gnav_btn > div > span:nth-of-type(3){ bottom:0; }
  .open header #gnav_btn > div > span:nth-of-type(1){ transform:translateY(7px) rotate(45deg); }
  .open header #gnav_btn > div > span:nth-of-type(2){ opacity:0; }
  .open header #gnav_btn > div > span:nth-of-type(3){ transform:translateY(-8px) rotate(-45deg); }

  /* オーバーレイ本体 */
  header #gnav{
    position:fixed; inset:0; z-index:1999;
    display:flex; flex-direction:column; align-items:stretch;
    height:100vh; height:100dvh; max-height:100dvh;
    background:#fff; color:#222; text-align:center;
    visibility:hidden; opacity:0; pointer-events:none;
    transition:opacity .3s ease;
  }
  body.open header #gnav{ visibility:visible; opacity:1; pointer-events:auto; }

  /* 内側スクロール領域（メニュー） */
  header #gnav > nav{
    width:100%; margin:0; padding:110px 20px 20px; /* 上部はロゴ/ボタン分 */
    flex:1 1 auto; overflow:auto; -webkit-overflow-scrolling:touch;
    max-width:720px; /* 見た目調整（不要なら削除） */
    margin-inline:auto;
  }
  header #gnav > nav::-webkit-scrollbar{ display:none; }

  /* メニュー（フラット・中央寄せ・仕切り線） */
  header .gnav_menu{ list-style:none; margin: 20px 0 0; padding:0; background:transparent; display:block; }
  header .gnav_menu > li > a{
    display:block; text-align:center; padding:18px 0;
    font-size:1.6rem; letter-spacing:.02em; color:#222 !important; text-decoration:none;
    border-bottom:1px solid rgba(0,0,0,.08);
  }
  header .gnav_menu > li:first-child > a{ border-top:1px solid rgba(0,0,0,.08); }
  /* 右側アイコン等は消す */
  header .gnav_menu > li > a::after{ content:none !important; }

  /* ドロップダウンを使わないページの余白抑制 */
  #h-nav .dropdown__lists{ padding:0 !important; }

  /* 表示制御の安全策（初期は確実に非表示、open時のみ表示） */
  header #gnav{ visibility:hidden !important; opacity:0 !important; pointer-events:none !important; }
  body.open header #gnav{ visibility:visible !important; opacity:1 !important; pointer-events:auto !important; }

  /* gnav_menu 初期は非表示 → openで表示（DOM位置の違いに対応） */
  header .gnav_menu{ display:none !important; }
  body.open header .gnav_menu{ display:block !important; }
}

@media (max-width:1080px) {
  body.open header::after {
    width: 100vw;
    height: 100vh;
    inset:0;
    background: #fff;
    content: '';
    position: absolute;
    z-index: -1;
  }
}






/* =================================== 
Footer
 =================================== */

.pageTop a {
  opacity: .6;
  position: fixed;
  bottom: 20px;
  right: 15px;
  z-index: 8;
}
.pageTop a:hover {
  opacity: .7;
}

#footer_conts {
  margin-top: 0;
}
footer {
  position: relative;
}
footer .f_info {
  padding-top: 30px;
  padding-bottom: 30px;
  background:url("../images/bg_footer.jpg") no-repeat center center / cover;
}
footer .f-logo {
  padding: 15px 0 0;
  text-align: center;
}
footer .f-nav ul {
  display: flex;
justify-content: space-between;
  flex-wrap: wrap;
}
footer .f-nav li {
  flex: 0 1 48%;
  width: 48%;
  line-height: 1.2;
}
footer .f-nav li a {
  font-size: 1.2rem;
  font-feature-settings: "palt";
}
footer .f_btn {
  height: 100px;
  padding: 15px;
  margin: 0 auto 0;
  font-size: clamp(2rem, 0.892rem + 2.31vw, 3.2rem);
  border-radius: 5px;
  background-color: rgba(255,255,255,.7);
}
footer .f_btn::after {
  bottom: 17%;
  right: 10px;
}

footer .f_btn,footer .f_ttl, footer .f_address  {
  width: 510px;
  max-width: 90vw;
}
footer .f_ttl {
  padding-bottom: 5px;
  margin-left: auto;
  margin-right: auto;
  border-bottom: solid 1px;
}
footer .f_address {
  letter-spacing: 0.05em;
  font-size: clamp(1.3rem, 0.838rem + 0.96vw, 1.8rem);
  margin: 20px auto 0;
}
footer a[href^="tel:"],
footer .f_ttl,
footer .f_address {
  color: #fff!important;
}
footer .f_address dd {
  padding-bottom: 10px;
}
footer .f-box {
}
footer .copyright {
  padding-top: 15px;
  padding-bottom: 15px;
  font-size: 1.2rem;
  line-height: 1.4;
  background-color: #fff;
}
footer .copyright p {
  text-align: center;
  font-feature-settings: 'palt';
}

@media (min-width: 600px) {
  footer .f-nav li {
    flex: 0 1 32%;
    width: 32%;
  }
}
@media (min-width: 768px) {
  footer .f-nav li {
    flex: 0 1 14%;
    width: 14%;
  }
  footer .f_info {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  footer .f_btn, footer .f_ttl, footer .f_address  {
    max-width: 40vw;
  }
  footer .f_btn {
    padding-left: 50px;
  }
  footer .f_btn::after {
    bottom: 28%;
    right: 20px;
    width: 50px;
    height: 50px;
  }
  footer .f_ttl {
    width: 100%;
    max-width: 100%;
    margin-bottom: 30px;
  }
  footer .f_address {
    margin: 0;
  }
  footer .f_address dd {
    text-align: left;
  }
}
@media (min-width: 1000px) {
  footer .f-box {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: space-between;
  }
  footer .f-logo {
    flex: 0 1 20%;
    width: 20%;
  }
  footer .f-nav {
    flex: 0 1 78%;
    width: 78%;
    display: flex;
    align-items: center;
  }
  footer .f-nav ul {
    width: 100%;
    max-width: 90%;
    margin: 0 0 0 auto;
    display: flex;
    justify-content: space-between;
  }
  footer .f-nav li {
    flex: auto;
    width: auto;
    text-align: right;
  }
  footer .f-nav li a {
    font-size: 1.4rem;
  }
}










