/*
Theme Name:   Welcart Basic Child
Description:  Welcart Basic Child is child theme for Welcart Basic.
Author:       Welcart Inc.
Author URI:   https://www.welcart.com/
Template:     welcart_basic
Version:      1.0.0
License:      GNU General Public License v2 or later
License URI:  http://www.gnu.org/licenses/gpl-2.0.html
Tags:         responsive-layout, basic-child, two-columns, right-sidebar, left-sidebar
*/

/* =========================================================
   Top page: New items grid
========================================================= */
.home-new-items{
  display: grid;
  grid-template-columns: repeat(var(--cols-sp, 3), 1fr);
  gap: var(--gap, 12px);
}
@media (min-width: 768px){
  .home-new-items{
    grid-template-columns: repeat(var(--cols-pc, 3), 1fr);
  }
}
.home-new-item__thumb img{ width:100%; height:auto; display:block; }
.home-new-item__name{ margin-top:8px; }
.home-new-item__price{ margin-top:4px; }


/* =========================================================
   Mobile Header (custom)
   - Left: hamburger (3 lines -> X)
   - Next: logo image
   - Right: search + cart only
   - Menu: 90% width, absolute under header line
   - Header: sticky
========================================================= */
@media (max-width: 767px){
  /* =====================================================
     Menu OPEN中：背景スクロールをロック（メニュー内スクロールを優先）
  ===================================================== */
  html:has(#site-navigation input#panel.on-off:checked),
  body:has(#site-navigation input#panel.on-off:checked){
    overflow: hidden;
    height: 100%;
    overscroll-behavior: none;
  }

  /* メニュー側はスクロールを確実に受ける */
  #site-navigation .nav-menu-open{
    overscroll-behavior: contain;
    touch-action: pan-y;
  }
/* =========================
   MENU: メンバーにアイコン追加
   ========================= */
#site-navigation .nav-menu-open li.menu-item-148 > a{
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px var(--menu-pad);
  font-weight: 700;
}

/* アイコン本体（SVG） */
#site-navigation .nav-menu-open li.menu-item-148 > a::before{
  content: "";
  width: 22px;
  height: 22px;
  flex: 0 0 22px;
  background: no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 21a8 8 0 0 0-16 0'/%3E%3Ccircle cx='12' cy='7' r='4'/%3E%3C/svg%3E");
}

  /* 重要：absoluteメニューの基準＆追従 */
  #masthead{
    position: sticky;
    top: 0;
    z-index: 1100;
    background: #fff; /* 透け防止 */
  }
  /* WP管理バー表示時（ログイン中）のズレ対策 */
  body.admin-bar #masthead{
    top: 46px; /* モバイル管理バー高さ */
  }

  /* スマホではユーザー（会員）を非表示 */
  #masthead .membership{
    display: none !important;
  }

  /* サブ説明は非表示 */
  #masthead .site-description{
    display: none;
  }

  /* ヘッダー内を1段横並びに */
  #masthead .inner.cf{
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 12px;
    padding: 16px 0px 12px;
  }

  /* ナビ（ハンバーガー）周り */
  #site-navigation{
    padding: 0;
    clear: none;
    background: transparent;
    width: auto;
    flex: 0 0 auto;
  }

  /* checkboxはトグルとして使うので非表示 */
  #site-navigation input#panel.on-off{
    display: none;
  }

  /* -----------------------------------------
     ハンバーガー表示（3本線）→ 開で×
     ※ Welcart側のアイコンフォント表示を上書きします
  ----------------------------------------- */
  #site-navigation label[for="panel"]{
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;   /* タップ領域 */
    height: 44px;  /* タップ領域 */
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
    z-index: 1103; /* メニューより上 */
  }

  /* span 1つで3本線（中央は背景、上下は疑似要素） */
  #site-navigation label[for="panel"] span{
    position: relative;
    width: 28px;
    height: 18px;
    display: block;

    /* 中央線 */
    background: linear-gradient(#000,#000) center/100% 3px no-repeat;

    /* テーマ側のフォントアイコン抑止 */
    font-size: 0;
    line-height: 0;
  }
  #site-navigation label[for="panel"] span::before,
  #site-navigation label[for="panel"] span::after{
    content: "";
    position: absolute;
    left: 0;
    width: 100%;
    height: 3px;
    background: #000;
    border-radius: 999px;
    transition: transform .18s ease, top .18s ease, bottom .18s ease, opacity .18s ease;
  }
  #site-navigation label[for="panel"] span::before{ top: 0; }
  #site-navigation label[for="panel"] span::after{ bottom: 0; }

  /* 開いている時は×（Chrome/Safariの現行は :has が効く想定） */
  #site-navigation:has(input#panel:checked) label[for="panel"] span{
    background: none; /* 中央線を消す */
  }
  #site-navigation:has(input#panel:checked) label[for="panel"] span::before{
    top: 50%;
    transform: translateY(-50%) rotate(45deg);
  }
  #site-navigation:has(input#panel:checked) label[for="panel"] span::after{
    bottom: auto;
    top: 50%;
    transform: translateY(-50%) rotate(-45deg);
  }

  /* -----------------------------------------
     「外側タップで閉じる」用オーバーレイ
     - ヘッダー部分も含めてタップで閉じる（= いったんヘッダー操作は無効）
     - メニュー本体はオーバーレイより上に出す
  ----------------------------------------- */
/* OPEN時：メニュー領域を避けた“外側だけ”の透明オーバーレイ（タップで閉じる） */
#site-navigation label[for="panel"]::after{
  content: "";
  display: none;
  position: fixed;
  inset: 0;
  background: transparent;
  z-index: 1002; /* nav-menu-open(1003)より下でOK。重要なのは“くり抜き” */
}

/* チェック中だけ表示 */
#site-navigation:has(input#panel.on-off:checked) label[for="panel"]::after{
  display: block;

  /* ここが肝：
     ヘッダー下（=メニュー開始位置）より下の「左90%」を除外して
     右10%＋ヘッダー部分だけをタップ判定にする */
  clip-path: polygon(
    0 0,
    100% 0,
    100% 100%,
    90vw 100%,
    90vw 73px,  /* ←ヘッダー高さに合わせる（あなたの現状値） */
    0 73px,
    0 0
  );
}


  /* -----------------------------------------
     ★根治：閉じている時に nav-menu-open が幅を取らない
     （input と div.nav-menu-open は同階層で後ろにある前提）
  ----------------------------------------- */
  header #site-navigation input#panel.on-off ~ div.nav-menu-open{
    display: none !important;
  }
  header #site-navigation input#panel.on-off:checked ~ div.nav-menu-open{
    display: block !important;
  }

  /* -----------------------------------------
     ロゴ（site-title）…テキスト→画像ロゴに置換
  ----------------------------------------- */
  #masthead .site-title{
    margin: 0;
    padding: 0;
    line-height: 1;
    flex: 1 1 auto;
    min-width: 0;
    text-align: left;
    display: flex;
    align-items: center;
  }

  #masthead .site-title a{
    display: inline-block;

    /* 画像ロゴ */
    background-image: url("https://muddler-antique.com/wp-content/uploads/2025/12/MUDDLERANTIQUE.png");
    background-repeat: no-repeat;
    background-position: left center;
    background-size: contain;

    /* テキストは残して隠す（SEO/アクセシビリティ） */
    text-indent: -9999px;
    overflow: hidden;
    white-space: nowrap;

    /* 比率維持（933x303） */
    aspect-ratio: 933 / 303;

    /* ヘッダー高さ感を維持しつつ“ロゴだけ”適正サイズへ */
    height: clamp(26px, 10vw, 44px);
    width: auto;
    transform: translateY(4px);
  }

  /* 右側アイコン群（検索＋カート） */
  #masthead .snav{
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: 0px;
    flex: 0 0 auto;
    flex-wrap: nowrap;
    margin-right: 0 !important;
    padding-top: 0 !important;
  }

  /* テーマ側でfloat指定がある場合の打ち消し */
  #masthead .snav > div{
    float: none;
    margin: 0;
  }

  /* 念のため：ユーザー関連が残っていても非表示（保険） */
  #masthead .snav .membership{
    display: none !important;
  }

  /* -----------------------------------------
     メニュー展開（幅90%・ヘッダー直下）
     - absolute（あなたの指定どおり）
  ----------------------------------------- */
  #site-navigation .nav-menu-open{
    position: absolute;
    left: 0;
    top: calc(100% + 1px); /* ヘッダー下線の下から */
    width: 90vw;
    max-width: 90%;
    background: #fff;
    z-index: 1102; /* overlay(1101)より上 */
    box-shadow: 0 8px 24px rgba(0,0,0,.12);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;

    /* 高さは「画面高さ - ヘッダー高さ（概算）」 */
    max-height: calc(100vh - 73px);
  }
  /* =====================================================
     Mobile menu design: Category heading + cards grid
     ③ グレー背景をメニュー幅いっぱいにする（左右padding相殺）
  ===================================================== */

  /* まず：メニューの“内側左右余白”を変数化（今は10px想定） */
  #site-navigation .nav-menu-open{
    --menu-pad: 10px;      /* ←ここを変えるとメニュー内側余白が変わる */
    --cat-bg: #f3f3f3;
  }
/* 親テーマの #site-navigation li a の “余白と下線” だけを、展開メニュー内では無効化 */
#site-navigation .nav-menu-open li > a{
  margin-bottom: 0 !important;
  border-bottom: 0 !important;
  /* padding-bottom は触らない（カードの縦位置がズレるため） */
}
  /* ヘッダーの ul に入っている左右paddingをここで明示（スクショの10pxに合わせる） */
  #site-navigation .nav-menu-open > ul.header-nav-container{
    padding-left: var(--menu-pad);
    padding-right: var(--menu-pad);
  }

  /* 「カテゴリ」（親）を見出し扱い：クリック不可 */
  #site-navigation .nav-menu-open li.menu-item-82 > a{
    pointer-events: none;
    cursor: default;
    display: block;

    /* 背景を“メニュー幅いっぱい”に：左右をマイナスして相殺 */
    margin-left: calc(var(--menu-pad) * -1);
    margin-right: calc(var(--menu-pad) * -1);
    padding: 16px var(--menu-pad);

    font-weight: 700;
    color: #111;
    background: var(--cat-bg);
    border-bottom: 1px solid #e6e6e6;
  }

  /* 子カテゴリ群（sub-menu）を2列カードに */
  #site-navigation .nav-menu-open li.menu-item-82 > ul.sub-menu{
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 3px;
    list-style: none;

    /* 背景を“メニュー幅いっぱい”に：左右をマイナスして相殺 */
    margin: 0 calc(var(--menu-pad) * -1);
    padding: 12px var(--menu-pad) 16px;

    background: var(--cat-bg);
  }

  /* 子カテゴリ li の線や余白をリセット */
  #site-navigation .nav-menu-open li.menu-item-82 > ul.sub-menu > li{
    margin: 0;
    padding: 0;
    border: 0;
  }

  /* 子カテゴリ a をカード化 */
  #site-navigation .nav-menu-open li.menu-item-82 > ul.sub-menu > li > a{
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 56px;
    padding: 12px 10px;
    background: #fff;
    margin-bottom: 0 !important;
    border: 1px solid #e6e6e6;
    border-radius: 5px;
    text-decoration: none;
    color: #111;
    line-height: 1.2;
    text-align: center;
  }

  /* 「すべての商品」だけ1列（2列をまたぐ） */
  #site-navigation .nav-menu-open li#menu-item-89{
    grid-column: 1 / -1;
  }
  #site-navigation .nav-menu-open li#menu-item-89 > a{
    min-height: 52px;
    font-weight: 700;
  }

  /* タップ時の軽い反応（任意） */
  #site-navigation .nav-menu-open li.menu-item-82 > ul.sub-menu > li > a:active{
    transform: translateY(1px);
  }

}

/* =========================================================
   Extra narrow phones: tighten spacing slightly
========================================================= */
@media (max-width: 360px){
  #masthead .inner.cf{
    gap: 10px;
    padding: 14px 12px 10px;
  }
  #masthead .snav{
    gap: 12px;
  }
  /* ロゴだけ少し下げる（極小幅での詰まり回避） */
  #masthead .site-title a{
    height: clamp(24px, 6.0vw, 40px);
  }
}


/* =========================================================
   PC側のロゴ高さ（必要な場合のみ）
   ※ ヘッダーの“形”を変えたくなければ消してください
========================================================= */
@media (min-width: 768px){
  #masthead .site-title a{
    height: 48px;
  }
}
