@charset "UTF-8";

/*!
Theme Name: Cocoon Child
Description: Cocoon専用の子テーマ
Theme URI: https://wp-cocoon.com/
Author: わいひら
Author URI: https://nelog.jp/
Template:   cocoon-master
Version:    1.1.3
*/

/************************************
** 子テーマ用のスタイルを書く
************************************/
/*必要ならばここにコードを書く*/

/************************************
** レスポンシブデザイン用のメディアクエリ
************************************/
/*1023px以下*/
@media screen and (max-width: 1023px){
  /*必要ならばここにコードを書く*/
}

/*834px以下*/
@media screen and (max-width: 834px){
  /*必要ならばここにコードを書く*/
}

/*480px以下*/
@media screen and (max-width: 480px){
  /*必要ならばここにコードを書く*/
}

/*
 * ============================================================
 * MPL スタイル
 * ============================================================
 */

/* ===== 外部URLブログカード ===== */
.mpl-extcard {
  display: flex;
  align-items: stretch;
  gap: 0;
  border: 1px solid var(--border, #dde2ea);
  border-radius: var(--r, 8px);
  overflow: hidden;
  text-decoration: none !important;
  color: var(--text, #1a1f2e) !important;
  background: var(--bg, #fff);
  box-shadow: var(--shadow-s, 0 2px 8px rgba(0,0,0,.07));
  transition: box-shadow .2s, transform .2s;
  margin: 1.2em 0;
  max-width: 100%;
}
.mpl-extcard:hover {
  box-shadow: var(--shadow, 0 4px 20px rgba(0,0,0,.10));
  transform: translateY(-2px);
}
.mpl-extcard__thumb {
  flex: 0 0 180px;
  width: 180px;
  overflow: hidden;
  background: var(--bg2, #f5f7fa);
}
.mpl-extcard__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.mpl-extcard__body {
  flex: 1;
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 6px;
  min-width: 0;
}
.mpl-extcard__title {
  font-size: .95rem;
  font-weight: 700;
  line-height: 1.45;
  color: var(--text, #1a1f2e);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.mpl-extcard__desc {
  font-size: .8rem;
  color: var(--muted, #6b7280);
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.mpl-extcard__site {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: .75rem;
  color: var(--muted, #6b7280);
  margin-top: 2px;
}
.mpl-extcard__site svg {
  flex-shrink: 0;
  opacity: .6;
}
/* 画像なしの場合 */
.mpl-extcard:not(:has(.mpl-extcard__thumb)) .mpl-extcard__body {
  padding: 16px 20px;
}
/* モバイル */
@media (max-width: 480px) {
  .mpl-extcard {
    flex-direction: column;
  }
  .mpl-extcard__thumb {
    flex: none;
    width: 100%;
    height: 160px;
  }
}

/* ===== CSS変数 ===== */
:root {
  --blue:#1565C0; --blue-l:#1E88E5; --blue-d:#0D47A1;
  --bg:#ffffff; --bg2:#f5f7fa; --bg3:#eef1f6;
  --border:#dde2ea; --text:#1a1f2e; --muted:#6b7280;
  --shadow:0 4px 20px rgba(0,0,0,.10); --shadow-s:0 2px 8px rgba(0,0,0,.07);
  --r:8px; --rl:14px;
  --fja:'Noto Sans JP',sans-serif; --fen:'Oswald',sans-serif;
}

/* ===== HEADER ===== */
#mpl-header { background:#fff; border-bottom:1px solid var(--border); padding:0 24px; }
.mpl-header-inner { max-width:1200px; margin:0 auto; display:flex; align-items:center; gap:16px; height:56px; }
.mpl-header-logo img { height:40px; width:auto; }
.mpl-header-tagline { font-size:11px; color:var(--muted); line-height:1.5; }

/* ===== CAT NAV ===== */
#mpl-cat-nav { background:var(--bg2); border-bottom:1px solid var(--border); position:relative; z-index:100; }
.mpl-cat-nav-inner { max-width:1200px; margin:0 auto; padding:0 24px; display:flex; }
.mpl-cat-nav-item { flex:1; position:relative; display:flex; align-items:center; justify-content:center; padding:12px 6px; text-align:center; font-size:13px; font-weight:700; border-bottom:3px solid transparent; color:var(--muted); transition:color .2s,background .2s,border-color .2s; white-space:nowrap; }
.mpl-cat-nav-item:hover { color:var(--blue); border-bottom-color:var(--blue-l); background:var(--bg3); }
.mpl-cat-nav-item.active { color:var(--blue-d); border-bottom-color:var(--blue); }
.mpl-cat-nav-item.has-dropdown > a { color:inherit; display:flex; align-items:center; justify-content:center; width:100%; height:100%; font-size:13px; font-weight:700; }
.mpl-cat-nav-item.has-dropdown > a::after { content:' ▾'; font-size:10px; margin-left:3px; opacity:.6; }
.mpl-dropdown { display:none; position:absolute; top:100%; left:0; width:100%; background:#fff; border:1px solid var(--border); border-top:2px solid var(--blue); border-radius:0 0 var(--r) var(--r); box-shadow:var(--shadow); z-index:200; padding:4px 0; text-align:left; }
.mpl-cat-nav-item:hover .mpl-dropdown { display:block; }
.mpl-dropdown a { display:block; padding:9px 16px; font-size:13px; font-weight:400; color:var(--text); white-space:nowrap; transition:background .15s; }
.mpl-dropdown a:hover { background:var(--bg2); color:var(--blue); }

/* ===== SIDEBAR ===== */
.mpl-sb-section { margin-bottom:22px; }
.mpl-sb-title { font-family:var(--fen); font-size:14px; font-weight:600; padding:8px 14px; background:var(--bg2); border-left:4px solid var(--blue); border-radius:0 var(--r) var(--r) 0; margin-bottom:12px; color:var(--text); }
.mpl-ranking { display:flex; flex-direction:column; gap:3px; }
.mpl-rank-item { display:flex; align-items:flex-start; gap:10px; background:var(--bg); border:1px solid var(--border); border-radius:var(--r); padding:10px 12px; transition:all .2s; }
.mpl-rank-item:hover { background:var(--bg2); border-color:var(--blue-l); }
.mpl-rank-num { font-family:var(--fen); font-size:20px; font-weight:700; width:24px; text-align:center; flex-shrink:0; }
.r1 { color:#e6ac00; } .r2 { color:#9e9e9e; } .r3 { color:#a1672a; } .rn { color:var(--muted); font-size:15px; }
.mpl-rank-thumb { width:64px; height:42px; border-radius:5px; background:var(--bg3); overflow:hidden; flex-shrink:0; }
.mpl-rank-thumb img { width:100%; height:100%; object-fit:cover; }
.mpl-rank-info { flex:1; min-width:0; }
.mpl-rank-title { font-size:12px; font-weight:700; line-height:1.5; color:var(--text); }
.mpl-rank-cat { font-size:10px; color:var(--muted); margin-top:2px; }
.mpl-tags { display:flex; flex-wrap:wrap; gap:7px; }
.mpl-tag-item { font-size:11px; background:var(--bg2); border:1px solid var(--border); padding:5px 12px; border-radius:20px; color:var(--muted); transition:all .2s; }
.mpl-tag-item:hover { background:var(--blue); border-color:var(--blue); color:#fff; }
.mpl-tag-count { color:var(--blue); font-weight:700; margin-left:3px; }
.mpl-sb-cards { display:flex; flex-direction:column; gap:8px; }
.mpl-sb-card { display:flex; gap:10px; padding:10px; background:var(--bg); border:1px solid var(--border); border-radius:var(--r); transition:all .2s; }
.mpl-sb-card:hover { background:var(--bg2); border-color:var(--blue-l); }
.mpl-sb-thumb { width:72px; height:46px; border-radius:5px; flex-shrink:0; overflow:hidden; background:var(--bg3); }
.mpl-sb-thumb img { width:100%; height:100%; object-fit:cover; }
.mpl-sb-info { flex:1; min-width:0; }
.mpl-sb-card-title { font-size:12px; font-weight:700; line-height:1.45; color:var(--text); display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.mpl-sb-card-date { font-size:11px; color:var(--muted); margin-top:3px; }
.mpl-new-card { background:var(--bg); border:1px solid var(--border); border-radius:var(--r); overflow:hidden; display:block; transition:all .22s; }
.mpl-new-card:hover { border-color:var(--blue-l); transform:translateY(-3px); box-shadow:var(--shadow); }
.mpl-new-thumb { height:140px; overflow:hidden; background:var(--bg3); }
.mpl-new-thumb img { width:100%; height:100%; object-fit:cover; }
.mpl-new-body { padding:11px 12px 12px; }
.mpl-new-title { font-size:13px; font-weight:700; line-height:1.5; color:var(--text); display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.mpl-new-date { font-size:11px; color:var(--muted); margin-top:6px; }
.mpl-tag { display:inline-block; font-size:10px; font-weight:700; padding:2px 8px; border-radius:3px; margin-bottom:6px; background:rgba(21,101,192,.1); color:var(--blue); border:1px solid rgba(21,101,192,.2); }
.mpl-tag.review { background:rgba(0,150,136,.1); color:#00796b; border-color:rgba(0,150,136,.2); }
.mpl-tag.gadget { background:rgba(123,31,162,.1); color:#7b1fa2; border-color:rgba(123,31,162,.2); }

/* ===== 投稿ページ レイアウト ===== */
.single #content {
    max-width: 1200px;
    margin: 0 auto;
    padding: 28px 24px 60px;
    box-sizing: border-box;
}
.single #content-in {
    display: flex;
    gap: 28px;
    align-items: flex-start;
    padding: 0 !important;
    margin: 0 !important;
    width: 100%;
    box-sizing: border-box;
}
.single #main {
    flex: 1;
    min-width: 0;
    padding: 28px 32px !important;
    background: #ffffff;
    border: 1px solid var(--border);
    border-radius: var(--r);
    box-shadow: var(--shadow-s);
    box-sizing: border-box;
}

@media (max-width: 1024px) {
    .single #main {
        border: none !important;
        border-radius: 0 !important;
        box-shadow: none !important;
        padding: 16px !important;
    }
}
#mpl-sidebar {
    width: 300px;
    flex-shrink: 0;
}

/* 投稿ページ：背景を白に */
body.single {
    background: #ffffff !important;
}

/* ============================================================
 * 記事本文スタイル
 * ※ WP管理画面「追加CSS」から移行。追加CSSは空にしてください。
 * ============================================================ */

/* 本文の読みやすさ改善 */
.entry-content {
    line-height: 1.9;
    letter-spacing: 0.02em;
}
.entry-content p {
    margin-bottom: 1.4em;
}
.entry-content h2 {
    border-left: 4px solid #ff2a2a;
    padding-left: 12px;
    margin-top: 2em;
    margin-bottom: 1em;
}
.entry-content h3 {
    border-bottom: 1px solid #ddd;
    padding-bottom: 6px;
}
.entry-content img {
    height: auto;
    max-width: 100%;
    border-radius: 6px;
}
@media (max-width: 767px) {
    .entry-content {
        font-size: 15px;
        line-height: 1.8;
    }
}

/* 吹き出しアイコン */
.speech-icon img {
    border-radius: 50% !important;
}

/* ブログカード */
.blogcard-wrap:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 22px rgba(0,0,0,0.18);
}
.blogcard-thumbnail img {
    transition: transform 0.3s ease;
}
.blogcard-wrap:hover .blogcard-thumbnail img {
    transform: scale(1.05);
}
.blogcard-title {
    font-weight: 700;
    font-size: 16px;
}

/* アイキャッチラベル削除 */
.eye-catch .cat-label {
    display: none !important;
}

/* 拡大可能画像にアイコン表示 */
a[href$=".jpg"],
a[href$=".jpeg"],
a[href$=".png"],
a[href$=".webp"] {
    position: relative;
    display: inline-block;
}
a[href$=".jpg"]::after,
a[href$=".jpeg"]::after,
a[href$=".png"]::after,
a[href$=".webp"]::after {
    content: "\1F50D";
    position: absolute;
    bottom: 8px;
    right: 8px;
    background: rgba(0,0,0,0.6);
    color: #fff;
    font-size: 14px;
    padding: 4px 6px;
    border-radius: 50%;
    opacity: 0;
    transition: opacity 0.2s ease;
}
a[href$=".jpg"]:hover::after,
a[href$=".jpeg"]:hover::after,
a[href$=".png"]:hover::after,
a[href$=".webp"]:hover::after {
    opacity: 1;
}

/* ===== FOOTER ===== */
#mpl-footer { background:var(--bg2); border-top:1px solid var(--border); padding:44px 24px 24px; }
.mpl-footer-inner { max-width:1200px; margin:0 auto; }
.mpl-footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr; gap:36px; margin-bottom:28px; }
.mpl-footer-logo img { height:40px; width:auto; margin-bottom:10px; }
.mpl-footer-tagline { font-size:13px; color:var(--muted); line-height:1.8; }
.mpl-footer-col-title { font-size:13px; font-weight:700; margin-bottom:12px; color:var(--text); }
.mpl-footer-links { list-style:none; }
.mpl-footer-links li { margin-bottom:6px; }
.mpl-footer-links a { font-size:13px; color:var(--muted); transition:color .2s; }
.mpl-footer-links a:hover { color:var(--blue); }
.mpl-footer-links li.parent-label { margin-top:10px; }
.mpl-footer-links li.parent-label:first-child { margin-top:0; }
.mpl-footer-links li.parent-label > a { font-weight:700; color:var(--text); }
.mpl-footer-links li.child { margin-left:12px; margin-bottom:4px; }
.mpl-footer-links li.child a { font-size:12px; }
.mpl-footer-links li.child a::before { content:'└ '; color:var(--border); }
.mpl-footer-bottom { border-top:1px solid var(--border); padding-top:18px; display:flex; justify-content:space-between; align-items:center; }
.mpl-footer-copy { font-size:12px; color:var(--muted); }
.mpl-footer-note { font-size:11px; color:var(--muted); opacity:.7; }

/* ===== リンク下線削除 ===== */
#mpl-header a,
#mpl-cat-nav a,
#mpl-sidebar a,
#mpl-footer a {
    text-decoration: none !important;
}

/* ===== MPL基本リセット ===== */
#mpl-header *, #mpl-cat-nav *, #mpl-sidebar *, #mpl-footer * { box-sizing: border-box; }
#mpl-header, #mpl-cat-nav, #mpl-sidebar, #mpl-footer { font-family: 'Noto Sans JP', sans-serif; font-size: 14px; color: var(--text); }
#mpl-header img, #mpl-cat-nav img, #mpl-sidebar img, #mpl-footer img { max-width: 100%; display: block; }

/* ===== レスポンシブ ===== */
@media (max-width: 1024px) {
    .single #mpl-sidebar { display: none !important; }
    .single #content-in { display: block !important; }
}
@media (max-width: 960px) {
    .mpl-footer-grid { grid-template-columns:1fr 1fr; }
}
@media (max-width: 640px) {
    .mpl-footer-grid { grid-template-columns:1fr; }
    /* ヘッダー縦並び */
    .mpl-header-inner {
        flex-direction: column;
        justify-content: center;
        align-items: center;
        height: auto;
        padding: 14px 0;
        gap: 6px;
        text-align: center;
    }
    .mpl-header-logo img { height: 36px; }
    /* カテゴリナビ アコーディオン */
    .mpl-cat-nav-inner { flex-direction: column; padding: 0; }
    .mpl-cat-nav-item { width: 100%; border-bottom: 1px solid var(--border) !important; justify-content: flex-start; padding: 12px 16px; }
    .mpl-cat-nav-item.has-dropdown > a { justify-content: flex-start; flex: 1; }
    .mpl-cat-nav-item.has-dropdown > a::after { content: ' ▾'; margin-left: auto; transition: transform .2s; }
    .mpl-cat-nav-item.has-dropdown.open > a::after { transform: rotate(180deg); }
    .mpl-cat-nav-item:hover .mpl-dropdown { display: none; }
    .mpl-cat-nav-item.has-dropdown.open .mpl-dropdown { display: block; position: static; border-radius: 0; border: none; border-top: 1px solid var(--border); box-shadow: none; background: var(--bg2); }
    .mpl-dropdown a { padding: 10px 16px 10px 28px; }
}

/* ===== モバイル：記事下サイドバー ===== */
#mpl-sidebar-mobile {
    width: 100%;
    margin-top: 28px;
    padding: 0;
}
#mpl-sidebar-mobile .mpl-sb-section {
    margin-bottom: 16px;
}

/* サイドバー内のおすすめデバイスカード間マージン */
#mpl-sidebar .mpl-new-grid {
    display: grid !important;
    grid-template-columns: 1fr;
    gap: 12px !important;
}

/* ============================================================
 * MPL テーブル共通スタイル
 * ブロックパターンから挿入した場合のみ適用（全テーブルには影響しない）
 * ============================================================ */
.mpl-table-wrap {
    overflow-x: auto;
    margin: 1.5em 0;
    -webkit-overflow-scrolling: touch;
}
.mpl-table-wrap table {
    width: 100%;
    border-collapse: collapse;
    font-size: inherit; /* 記事本文のフォントサイズをそのまま継承 */
    line-height: 1.6;
    min-width: 400px; /* スマホ横スクロール発動の最小幅 */
}
.mpl-table-wrap th,
.mpl-table-wrap td {
    padding: 10px 14px;
    border: 1px solid var(--border);
    vertical-align: middle;
}

/* ===== 案A：比較表（おすすめ強調） ===== */
.mpl-table-compare thead th {
    background: var(--blue);
    color: #fff;
    font-weight: 700;
    text-align: center;
    border-color: var(--blue-d);
    white-space: nowrap;
}
.mpl-table-compare tbody tr:nth-child(even) {
    background: var(--bg2);
}
.mpl-table-compare tbody tr:hover {
    background: #eef4ff;
}
/* おすすめ行：左ボーダー＋背景色で強調 */
.mpl-table-compare .mpl-recommended {
    background: #fffbeb !important;
    border-left: 4px solid #f59e0b;
}
.mpl-table-compare .mpl-recommended td:first-child {
    font-weight: 700;
}
/* おすすめバッジ */
.mpl-badge {
    display: inline-block;
    background: #f59e0b;
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    padding: 2px 7px;
    border-radius: 3px;
    margin-right: 5px;
    vertical-align: middle;
    white-space: nowrap;
}

/* ===== 案B：カード型変換（PC=テーブル / スマホ=カード） ===== */
.mpl-table-card thead th {
    background: var(--bg2);
    color: var(--text);
    font-weight: 700;
    text-align: left;
    border-bottom: 2px solid var(--blue);
    white-space: nowrap;
}
.mpl-table-card tbody tr:nth-child(even) {
    background: var(--bg2);
}
.mpl-table-card tbody tr:hover {
    background: #eef4ff;
}
/* スマホ：480px以下でカード型に変換 */
@media (max-width: 480px) {
    .mpl-table-card {
        overflow-x: visible; /* カード型では横スクロール不要 */
    }
    .mpl-table-card table,
    .mpl-table-card thead,
    .mpl-table-card tbody,
    .mpl-table-card tr,
    .mpl-table-card th,
    .mpl-table-card td {
        display: block;
    }
    .mpl-table-card table {
        min-width: unset; /* スマホでmin-width解除 */
    }
    .mpl-table-card thead {
        display: none; /* ヘッダーはdata-labelで代替するため非表示 */
    }
    .mpl-table-card tbody tr {
        border: 1px solid var(--border);
        border-radius: var(--r);
        margin-bottom: 12px;
        padding: 4px 0;
        background: #fff;
        box-shadow: var(--shadow-s);
    }
    .mpl-table-card td {
        display: flex;
        align-items: baseline;
        gap: 8px;
        padding: 8px 14px;
        border: none;
        border-bottom: 1px solid var(--bg2);
        white-space: normal;
    }
    .mpl-table-card td:last-child {
        border-bottom: none;
    }
    /* data-label属性の値をラベルとして表示 */
    .mpl-table-card td::before {
        content: attr(data-label);
        font-weight: 700;
        font-size: 11px;
        color: var(--muted);
        white-space: nowrap;
        min-width: 80px;
        flex-shrink: 0;
    }
}

/* ===== 案C：シンプル縦型（項目／内容の2列） ===== */
.mpl-table-simple th[scope="row"] {
    background: var(--bg2);
    color: var(--text);
    font-weight: 700;
    text-align: left;
    width: 35%;
    white-space: nowrap;
    border-right: 3px solid var(--blue);
}
.mpl-table-simple td {
    background: #fff;
}
/* 偶数行の色分け（ゼブラストライプ） */
.mpl-table-simple tbody tr:nth-child(even) th[scope="row"],
.mpl-table-simple tbody tr:nth-child(even) td {
    background: var(--bg2);
}