/* =====================================================
   チュラシマエネルギー SP専用オーバーライド
   対象: max-width 767px
   PC版（768px以上）には一切影響しない
   ===================================================== */

@media (max-width: 767px) {

  /* ===== BASE ===== */
  html { font-size: 62.5%; }
  body { overflow-x: hidden; }

  /* ===== HEADER ===== */
  .l-header {
    height: 56px !important;
    max-height: 56px !important;
    overflow: hidden !important;
    box-shadow: 0 2px 12px rgba(12,22,34,.1);
  }
  .l-header__inner {
    height: 56px;
    padding: 0 16px;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  .l-header-info {
    display: flex;
    align-items: center;
    width: 100%;
    justify-content: space-between;
  }
  .l-header-info__logo {
    padding: 0;
  }
  .l-header-info__logo-head-link {
    font-size: 1.5rem;
    letter-spacing: .04em;
  }
  .l-header-info__logo-head-link-ico {
    margin-right: 8px;
  }
  .l-header-info__logo-head-link-ico svg {
    width: 32px;
    height: auto;
  }
  /* ハンバーガーの「メニュー」テキスト非表示 */
  .l-nav-btn__txt,
  .js-nav-btn-txt {
    display: none !important;
  }

  /* ナビボタン（ハンバーガー）をコンパクトに */
  .l-nav-btn {
    position: static;
    width: 44px;
    height: 44px;
    background: transparent;
    flex-shrink: 0;
  }
  .l-nav-btn__line {
    left: 11px;
    width: 22px;
  }
  /* ヘッダーはロゴ＋ハンバーガーのみ（PCコンテンツ非表示） */
  .l-header-contact { display: none !important; }

  /* ===== HERO（l-main-img） ===== */
  .l-main-img {
    min-height: 100svh;
    min-height: calc(var(--vh, 1vh) * 100);
    padding-top: 56px;
    position: relative;
  }
  /* 補助金バッジ：画面内に収める */
  .l-main-img__img {
    right: 8px !important;
    top: 8px !important;
    width: 140px !important;
  }

  /* 背景画像を縦型に最適化・オーバーレイを濃く */
  .l-main-img:before {
    height: 100% !important;
    background-size: cover !important;
    background-position: center top !important;
    background-color: #1B2A3A;
  }
  /* 暗めオーバーレイ追加（コピー可読性UP） */
  .l-main-img:after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(
      180deg,
      rgba(12,22,34,.55) 0%,
      rgba(12,22,34,.35) 50%,
      rgba(12,22,34,.65) 100%
    );
    z-index: 1;
    pointer-events: none;
  }
  .l-main-img__inner {
    position: relative;
    z-index: 2;
    padding: 32px 20px 0;
    min-height: calc(100svh - 56px);
    min-height: calc(var(--vh, 1vh) * 100 - 56px);
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  /* コピー */
  .l-main-img__copy {
    margin-bottom: 24px;
    margin-left: 0 !important;
    margin-right: 0 !important;
    max-width: none !important;
    width: 100% !important;
  }
  .l-main-img__copy > p:first-child {
    font-size: 1.25rem !important;
    letter-spacing: .18em;
    margin-bottom: 10px !important;
    color: #C9A86A !important;
  }
  .l-main-img__copy h2 {
    font-size: clamp(2.8rem, 7.5vw, 4.2rem) !important;
    line-height: 1.48 !important;
    color: #FBF9F4 !important;
    text-shadow: 0 2px 16px rgba(12,22,34,.6) !important;
    margin-bottom: 16px !important;
  }
  .l-main-img__copy > p:last-of-type {
    font-size: 1.35rem !important;
    color: rgba(251,249,244,.88) !important;
    line-height: 1.7 !important;
  }
  /* CTA ボタン群：縦並び全幅 */
  .cse-hero-cta {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    margin-top: 24px !important;
    width: 100% !important;
  }
  .cse-hero-cta > a:first-child {
    display: flex !important;
    width: 100% !important;
    padding: 18px 20px !important;
    font-size: 1.7rem !important;
    justify-content: center !important;
    border-radius: 4px !important;
    box-sizing: border-box !important;
  }
  .cse-hero-line-wrap {
    display: block !important;
    width: 100% !important;
    position: relative !important;
  }
  .cse-pop {
    font-size: 1.25rem !important;
    padding: 7px 14px !important;
    top: -36px !important;
  }
  .cse-line-cta {
    display: flex !important;
    width: 100% !important;
    padding: 18px 20px !important;
    font-size: 1.7rem !important;
    justify-content: center !important;
    border-radius: 4px !important;
    box-sizing: border-box !important;
  }
  /* 3バッジ（安心ポイント） */
  .l-main-img__point {
    display: flex !important;
    flex-direction: row !important;
    justify-content: center !important;
    gap: 10px !important;
    margin-top: 28px !important;
    padding-bottom: 32px !important;
  }
  .l-main-img__point-item {
    flex: 1 !important;
    max-width: 106px !important;
  }
  .l-main-img__point-item .a-badge {
    width: 100% !important;
    aspect-ratio: 1 !important;
    font-size: 1.2rem !important;
    padding: 8px 4px !important;
    border-radius: 50% !important;
    border-width: 1.5px !important;
  }
  .l-main-img__point-item .a-badge__main span {
    font-size: 1.2rem !important;
  }
  .l-main-img__point-item .a-badge__sub {
    font-size: .9rem !important;
  }
  .l-main-img__point-item .a-badge__big {
    font-size: 2.4rem !important;
  }

  /* ===== おすすめ製品スライダー ===== */
  .home-recommend {
    padding: 48px 0 32px;
  }
  .home-recommend__head {
    padding: 0 20px 24px;
    text-align: center;
  }
  /* スライダーカードを全幅ぎりぎりに */
  .home-recommend .slick-list {
    padding: 0 20px !important;
  }
  .home-recommend .slick-slide {
    width: 280px !important;
    margin: 0 8px !important;
  }
  /* スライダー上のドット */
  .home-recommend .slick-dots {
    bottom: -24px;
  }

  /* ===== お悩みセクション ===== */
  .home-worries {
    padding: 52px 20px;
  }
  .home-worries [class*="head"] h2,
  .home-worries h2 {
    font-size: 2.4rem !important;
    line-height: 1.5 !important;
  }
  .home-worries [class*="list"] {
    gap: 20px;
  }
  .home-worries [class*="item"] {
    padding: 20px 16px;
  }

  /* ===== セクション共通 ===== */
  .co-sec {
    padding: 52px 20px !important;
  }
  .co-sec .u-inner,
  .co-sec [class*="inner"] {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .co-head,
  .c-head01,
  .c-head02,
  .c-head03 {
    margin-bottom: 28px !important;
  }
  .co-head h2 {
    font-size: 2.2rem !important;
    line-height: 1.5 !important;
  }

  /* ===== 蓄電池のメリット ===== */
  .home-merit {
    padding: 52px 20px;
  }
  .home-merit [class*="head"] h2 {
    font-size: 2.2rem !important;
  }

  /* ===== 料金比較セクション ===== */
  #compare {
    padding: 52px 20px !important;
  }
  #compare table {
    font-size: 1.3rem !important;
  }
  #compare th, #compare td {
    padding: 10px 8px !important;
  }

  /* ===== 選ばれる理由 ===== */
  .home-feature {
    padding: 52px 20px;
  }
  .home-feature [class*="head"] h2 {
    font-size: 2.2rem !important;
  }

  /* ===== お客様の声 ===== */
  .home-voice {
    padding: 52px 20px;
  }
  .home-voice [class*="head"] h2 {
    font-size: 2.2rem !important;
  }
  /* 声カードをリスト表示 */
  .home-voice [class*="list"] {
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
  }
  .home-voice [class*="item"] {
    width: 100% !important;
  }

  /* ===== 取扱メーカー ===== */
  #makers {
    padding: 40px 20px !important;
  }
  #makers [class*="list"] {
    gap: 16px !important;
    justify-content: center !important;
  }
  #makers [class*="item"] img {
    max-height: 32px !important;
  }

  /* ===== 製品一覧 ===== */
  .home-products {
    padding: 52px 20px;
  }
  .home-products [class*="head"] h2 {
    font-size: 2.2rem !important;
  }
  .home-products [class*="list"] {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  /* ===== シミュレーター ===== */
  .cse-simulator-section {
    padding: 48px 16px !important;
  }

  /* ===== お問い合わせフォーム ===== */
  .home-contact {
    padding: 52px 20px;
  }
  .home-contact [class*="head"] h2 {
    font-size: 2.2rem !important;
  }
  .home-contact [class*="form"] input,
  .home-contact [class*="form"] textarea,
  .home-contact [class*="form"] select {
    font-size: 1.6rem !important;
    padding: 14px 16px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    -webkit-appearance: none !important;
    border-radius: 6px !important;
  }
  .home-contact [class*="form"] button[type="submit"],
  .home-contact [class*="submit"] {
    width: 100% !important;
    padding: 18px 20px !important;
    font-size: 1.8rem !important;
    border-radius: 4px !important;
    letter-spacing: .06em !important;
  }

  /* ===== CVセクション ===== */
  .c-cv01 {
    padding: 48px 20px !important;
  }
  .c-cv01 [class*="btn"],
  .c-cv01 a[class*="btn"],
  .c-cv01 a {
    display: block !important;
    width: 100% !important;
    padding: 18px 16px !important;
    font-size: 1.7rem !important;
    text-align: center !important;
    box-sizing: border-box !important;
    border-radius: 4px !important;
    margin: 0 0 12px 0 !important;
  }

  /* ===== 導入の流れ ===== */
  .home-flow {
    padding: 52px 20px;
  }
  .home-flow [class*="head"] h2 {
    font-size: 2.2rem !important;
  }
  .home-flow [class*="list"] {
    flex-direction: column !important;
    gap: 0 !important;
  }
  .home-flow [class*="item"] {
    width: 100% !important;
    padding: 20px 0 !important;
    border-bottom: 1px solid rgba(12,22,34,.08) !important;
  }

  /* ===== FAQ ===== */
  .home-faq {
    padding: 52px 20px;
  }
  .home-faq [class*="head"] h2 {
    font-size: 2.2rem !important;
  }
  .home-faq [class*="question"],
  .home-faq [class*="q-head"],
  .home-faq dt {
    font-size: 1.6rem !important;
    padding: 16px 44px 16px 16px !important;
    line-height: 1.55 !important;
  }
  .home-faq [class*="answer"],
  .home-faq dd {
    font-size: 1.5rem !important;
    padding: 16px !important;
    line-height: 1.7 !important;
  }

  /* ===== フッター固定CTA（l-footer-fix） ===== */
  .l-footer-fix {
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 100 !important;
    background: #fff !important;
    box-shadow: 0 -3px 16px rgba(12,22,34,.14) !important;
    padding-bottom: env(safe-area-inset-bottom) !important;
  }
  .l-footer-fix__list {
    display: flex !important;
    align-items: stretch !important;
    height: 64px !important;
    padding: 0 !important;
    margin: 0 !important;
    list-style: none !important;
  }
  /* ハンバーガーエリア：コンパクト */
  .l-footer-fix__area-btn {
    flex: 0 0 52px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-right: 1px solid rgba(12,22,34,.08) !important;
  }
  .l-footer-fix__btn {
    width: 44px !important;
    height: 44px !important;
    background: transparent !important;
    border: none !important;
    cursor: pointer !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 5px !important;
    padding: 0 !important;
  }
  .l-footer-fix__btn-line {
    display: block !important;
    width: 20px !important;
    height: 2px !important;
    background: #1B2A3A !important;
    border-radius: 2px !important;
  }
  .l-footer-fix__btn-txt {
    font-size: 1rem !important;
    color: #1B2A3A !important;
    font-weight: 600 !important;
    letter-spacing: .03em !important;
    margin-top: 2px !important;
  }
  /* TEL：中央 */
  .l-footer-fix__list-item.is-tel {
    flex: 1 !important;
    border-right: 1px solid rgba(12,22,34,.08) !important;
  }
  .l-footer-fix__list-item.is-tel .l-footer-fix__list-item-link {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    height: 100% !important;
    padding: 6px 4px !important;
    text-decoration: none !important;
    color: #1B2A3A !important;
    gap: 2px !important;
  }
  .l-footer-fix__list-item-tel01 { display: none !important; }
  .l-footer-fix__list-item-tel02 {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 2px !important;
  }
  .l-footer-fix__list-item-tel02-head {
    font-size: 1.25rem !important;
    font-weight: 700 !important;
    color: #1B2A3A !important;
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
  }
  .l-footer-fix__list-item-tel02-ico {
    width: 14px !important;
    height: 14px !important;
  }
  .l-footer-fix__list-item-tel02-info {
    font-size: .95rem !important;
    color: rgba(12,22,34,.55) !important;
    white-space: nowrap !important;
  }
  /* 無料相談：緑ベース */
  .l-footer-fix__list-item.is-contact {
    flex: 1.3 !important;
    background: #1B2A3A !important;
  }
  .l-footer-fix__list-item.is-contact .l-footer-fix__list-item-link {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    height: 100% !important;
    padding: 6px 4px !important;
    text-decoration: none !important;
    gap: 2px !important;
  }
  .l-footer-fix__list-item-contact {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 2px !important;
  }
  .l-footer-fix__list-item-contact-head {
    font-size: 1.15rem !important;
    font-weight: 700 !important;
    color: #FBF9F4 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 3px !important;
  }
  .l-footer-fix__list-item-contact-ico {
    width: 20px !important;
    height: auto !important;
    color: #C9A86A !important;
    fill: #C9A86A !important;
  }
  .l-footer-fix__list-item-contact-info {
    font-size: .95rem !important;
    color: rgba(251,249,244,.7) !important;
  }
  /* LINE：緑 */
  .l-footer-fix__list-item.is-line {
    flex: 1 !important;
    background: #06C755 !important;
  }
  .l-footer-fix__list-item.is-line .l-footer-fix__list-item-link {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    height: 100% !important;
    padding: 6px 4px !important;
    text-decoration: none !important;
    gap: 2px !important;
  }
  .l-footer-fix__list-item-line {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 3px !important;
  }
  .l-footer-fix__list-item-line img {
    width: 26px !important;
    height: 26px !important;
    object-fit: contain !important;
  }
  /* LINE テキスト追加（JSで注入か :after で） */
  .l-footer-fix__list-item.is-line:after {
    display: none !important;
  }

  /* フッター本体に底余白（固定CTAの高さ分） */
  .l-footer {
    padding-bottom: calc(64px + env(safe-area-inset-bottom)) !important;
  }

  /* ===== フッターナビ（ドロワー展開時） ===== */
  .l-nav {
    top: 56px !important;
  }

  /* ===== 全体：セクション下部のページコンテンツ余白 ===== */
  main, #wrapper, .l-main {
    padding-top: 56px !important;
  }

  /* ===== スクロールアニメーション対応 ===== */
  .js-c-anime-elem {
    opacity: 1 !important;
    transform: none !important;
  }

  /* ===== LINE浮遊ボタン非表示（固定CTAと重複） ===== */
  .cse-line-float,
  .js-line-fab,
  [class*="line-float"],
  [class*="float-line"] {
    display: none !important;
  }
}

/* =====================================================
   全ページ共通：ヘッダーSEOテキスト非表示
   ===================================================== */
@media (max-width: 767px) {
  /* h1 SEOテキスト（ロゴの上に露出する非表示前提テキスト） */
  .l-header-info__logo-txt {
    display: none !important;
  }

  /* ===== パンくずリスト ===== */
  .products-breadcrumb {
    padding: 12px 16px !important;
    font-size: 1.1rem !important;
  }
}

/* =====================================================
   製品一覧ページ SP専用
   ===================================================== */
@media (max-width: 767px) {

  /* ページタイトルエリア */
  .products-archive {
    padding: 0 0 80px !important;
  }
  .products-archive__inner {
    padding: 0 16px !important;
  }

  /* フィルター（絞り込み）ボタン */
  .c-category01-btns__item-in {
    font-size: 1.2rem !important;
    padding: 6px 10px !important;
  }

  /* カード一覧：2列グリッド */
  .c-archive01 {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 12px !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  .c-archive01__item {
    width: 100% !important;
    margin: 0 !important;
  }
  .c-archive01__item + .c-archive01__item {
    margin-top: 0 !important;
  }
  .c-archive01__item-link {
    display: block !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    background: #fff !important;
    box-shadow: 0 2px 8px rgba(0,0,0,.08) !important;
  }
  .c-archive01__item-link img {
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 1 / 1 !important;
    object-fit: contain !important;
    padding: 8px !important;
    box-sizing: border-box !important;
  }

  /* タブ切り替え（全負荷/特定負荷等） */
  .c-category01-tab-parent {
    display: flex !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    gap: 8px !important;
    padding-bottom: 4px !important;
    scrollbar-width: none !important;
  }
  .c-category01-tab-parent::-webkit-scrollbar { display: none !important; }
  .c-category01-tab-parent__item {
    flex-shrink: 0 !important;
  }
  .c-category01-tab-parent__item-in {
    font-size: 1.2rem !important;
    white-space: nowrap !important;
    padding: 6px 14px !important;
  }
}

/* =====================================================
   製品詳細ページ SP専用
   ===================================================== */
@media (max-width: 767px) {

  /* 製品詳細コンテナ */
  .c-single01__inner {
    padding: 0 16px 80px !important;
  }

  /* イントロ（ギャラリー + 情報）：縦積み */
  .c-single01-intro {
    display: flex !important;
    flex-direction: column !important;
    gap: 20px !important;
  }

  /* ギャラリー */
  .c-single01-intro-gallery {
    width: 100% !important;
    margin: 0 !important;
  }
  .c-single01-intro-gallery__area-display {
    border-radius: 8px !important;
    overflow: hidden !important;
  }
  .c-single01-intro-gallery__display-img img {
    width: 100% !important;
    height: auto !important;
    max-height: 280px !important;
    object-fit: contain !important;
  }
  .c-single01-intro-gallery__area-thumb {
    margin-top: 8px !important;
  }
  .c-single01-intro-gallery__thumb-img img {
    width: 64px !important;
    height: 64px !important;
    object-fit: contain !important;
  }

  /* 製品情報テキスト */
  .c-single01-intro-info {
    width: 100% !important;
    margin: 0 !important;
  }
  .c-single01-intro-info__cat {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
    margin-bottom: 12px !important;
  }
  .c-single01-intro-info__cat-item {
    font-size: 1.1rem !important;
    padding: 4px 10px !important;
    border-radius: 4px !important;
  }
  .c-single01-intro-info__head {
    font-size: clamp(2rem, 5.5vw, 2.8rem) !important;
    line-height: 1.4 !important;
    margin-bottom: 12px !important;
  }
  .c-single01-intro-info__txt {
    font-size: 1.3rem !important;
    line-height: 1.8 !important;
  }

  /* 特長リスト */
  .c-single01-intro-info__feature-head {
    font-size: 1.3rem !important;
  }

  /* スペック表：横スクロール対応 */
  .c-single01-detail {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    margin: 0 -16px !important;
    padding: 0 16px !important;
  }
  .c-table02 {
    min-width: 560px !important;
    font-size: 1.2rem !important;
  }
  .c-table02 th,
  .c-table02 td {
    padding: 10px 12px !important;
    font-size: 1.2rem !important;
  }

  /* 特徴セクション */
  .c-single01-feature-list {
    padding: 0 !important;
  }
  .c-single01-feature-list__item {
    padding: 12px 0 !important;
  }
  .c-single01-feature-list__txt {
    font-size: 1.3rem !important;
    line-height: 1.7 !important;
  }

  /* メーカーリスト */
  .c-single01-maker__list {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
  }

  /* 戻るボタン */
  .c-single01__btn {
    margin: 20px 0 !important;
  }
  .c-btn03__link {
    font-size: 1.4rem !important;
    padding: 14px 20px !important;
  }
}

/* ===== SMALL SP（320px〜374px） ===== */
@media (max-width: 374px) {
  .l-main-img__copy h2 {
    font-size: 2.5rem !important;
  }
  .l-footer-fix__list {
    height: 60px !important;
  }
  .l-footer-fix__list-item-tel02-head {
    font-size: 1.1rem !important;
  }
  .l-footer-fix__list-item-contact-head {
    font-size: 1.05rem !important;
  }
}
