/*
Theme Name: DK Child (GeneratePress)
Template: generatepress
Version: 1.1.0
Author: DaiwaKasei
Description: baserCMSデザインを移植した GeneratePress 子テーマ。ヘッダー/フッター/トップをカスタム実装。
Text Domain: dk-child
*/

/* =========================================================
   Header: 2-row layout (CTA row + Global nav row)
   - 1段目：右上（検索 / カタログ請求 / お問い合わせ）
   - 2段目：ロゴ + ナビ
   ========================================================= */
.site-header .inside-header{
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:12px 16px;
}

.site-header .header-row{
  width:100%;
  display:flex;
  align-items:center;
}

.site-header .header-row--top{
  justify-content:flex-end;
}

.site-header .header-row--main{
  justify-content:space-between;
  gap:100px;
}

.site-header .header-cta{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
  flex-wrap:wrap;
}

.site-header .header-search form{
  display:flex;
  align-items:center;
  gap:6px;
}

.site-header .header-search input[type="text"],
.site-header .header-search input[type="search"]{
  width:220px;
  max-width:36vw;
}

.site-header .main-navigation{
  flex:1 1 auto;
  display:flex;
  justify-content:flex-end;
}

.site-header .main-navigation a{
  font-weight: 500;
}

.site-header .main-navigation .menu{
  display:flex;
  flex-wrap:wrap;
  gap:50px;
  margin:0;
  padding:0;
}
ul.sub-menu {
  padding:0.5em 0.5em  0em;
}
ul.sub-menu li{
  padding:0 0 0.5em ;
}

/* SP：CTAは2段目に押し込まず、詰まりを回避 */
@media (max-width: 767px){
  .site-header .inside-header{ gap:12px; padding:10px 12px; }

  .site-header .header-row--top{
    justify-content:flex-start;
  }

  .site-header .header-cta{
    width:100%;
    justify-content:flex-start;
  }

  .site-header .header-search{
    width:100%;
  }

  .site-header .header-search form{
    width:100%;
  }

  .site-header .header-search input[type="text"],
  .site-header .header-search input[type="search"]{
    width:100%;
    max-width:none;
  }

  .site-header .header-row--main{
    flex-wrap:wrap;
  }

  /* nav は header 行内に button サイズ分だけ残す。パネルは sp.css で fixed */
  .site-header .main-navigation{
    width:auto;
    flex:0 0 auto;
  }
  #site-navigation{
    display:flex;
    align-items:center;
  }
  #site-navigation .menu-toggle{
    display:flex;
  }
}

@media (min-width: 768px){
  .site-header .menu-toggle{ display:none; }
  #site-navigation{ display:block; }
  /* ドロワー内CTAはPCでは不要（DOMには常時存在するため明示的に非表示） */
  #site-navigation .drawer-cta{ display:none !important; }
}

/* =========================================================
   Header: base (sticky + underline)
   ========================================================= */
.site-header{
  position: sticky;
  top: 0;
  z-index: 1000;
  background: #fff;
  box-shadow: inset 0 -2px 0 0 #e24040;
}

.site-logo img{
  height: 42px;
  width: auto;
  display: block;
}
@media (max-width: 767px){
  .site-logo img{ height: 36px; }
}

:root{ --header-height: 70px; }
body{ scroll-padding-top: var(--header-height); }

/* =========================================================
   Mobile Drawer: overlay（JS が is-active を付与）
   ========================================================= */
#drawer-overlay{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.5);
  z-index:999;
  touch-action:none;
}
#drawer-overlay.is-active{ display:block; }

/* サブメニュー展開ボタン：PC では非表示 */
.submenu-toggle{ display:none; }

/* =========================================================
   Header: hamburger menu toggle
   ========================================================= */

/* スクリーンリーダー専用テキスト（視覚的に隠す） */
.screen-reader-text {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ハンバーガーボタン基本スタイル（GP の line-height:60px / width:100% を上書き） */
.menu-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: auto;
  min-width: 44px;
  min-height: 44px;
  padding: 8px 12px;
  line-height: 1;
  background: transparent;
  border: 0;
  cursor: pointer;
  color: inherit;
}

/* 三本線コンテナ */
.menu-toggle__bars {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  width: 24px;
  height: 18px;
}

/* 各バー */
.menu-toggle__bar {
  display: block;
  width: 100%;
  height: 2px;
  background: currentColor;
  border-radius: 2px;
  transition: transform 0.3s ease, opacity 0.3s ease;
  transform-origin: center;
}

/* 開いた状態：× 形に変形（#site-navigation.toggled を起点にする） */
#site-navigation.toggled .menu-toggle .menu-toggle__bar:nth-child(1) {
  transform: translateY(8px) rotate(45deg);
}
#site-navigation.toggled .menu-toggle .menu-toggle__bar:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}
#site-navigation.toggled .menu-toggle .menu-toggle__bar:nth-child(3) {
  transform: translateY(-8px) rotate(-45deg);
}

/* GeneratePress 本体の cite,dfn,em,i { font-style:italic } を打ち消す */
em,
i, 
address{
  font-style: normal !important;
}

.site-main,.inside-article{
  padding: 0 !important;
  margin: 0 !important;
}