/*
Theme Name: Cocoon Child (Custom)
Template: cocoon
Version: 1.0
*/

*,
*::before,
*::after {
  box-sizing: border-box;
}

/* =========================================
   Global / Layout safety
========================================= */

html,
body {
  overflow-x: hidden;
  -webkit-text-size-adjust: 100%;
}

img,
video,
iframe,
embed,
object {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  word-break: break-word;
}

.wrap,
.container,
.content,
.content-in,
.main,
.sidebar,
.sidebar-widget-area,
.site,
.site-content,
.article,
.entry,
.entry-content,
.wrap-archive {
  min-width: 0;
}

@media (max-width: 1300px) {
  body .wrap,
  body .container,
  body .content,
  body .content-in,
  body .main,
  body .site-content,
  body .article,
  body .entry,
  body .entry-content {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }
}

/* =========================================
   Navi caption overflow fixes
========================================= */

body .navi .item-label,
body .navi .item-description {
  display: block !important;
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: clip !important;
  word-break: break-word !important;
  overflow-wrap: anywhere !important;
  -webkit-line-clamp: unset !important;
  -webkit-box-orient: unset !important;
  height: auto !important;
  max-height: none !important;
}

body .navi .navi-in,
body .navi .navi-in > ul,
body .navi .navi-in > ul > li,
body .navi .navi-in > ul > li > a,
body .navi .navi-in > ul .caption-wrap,
body .navi .navi-in > ul .caption-wrap > div {
  min-width: 0 !important;
  height: auto !important;
  max-height: none !important;
  overflow: visible !important;
}

body .navi .navi-in > ul > li > a {
  align-items: flex-start !important;
}

body .navi .caption-wrap {
  min-width: 0 !important;
}

body .navi-in > ul .caption-wrap > div {
  width: 100% !important;
}

/* =========================================
   Archive layout
========================================= */

.entry-archive-main.wrap-archive {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 16px 32px;
}

.entry-archive-hero {
  background: #0f172a;
  color: #fff;
  padding: 14px 0 10px;
  margin: 0 -16px 12px;
  max-width: 100vw;
}

.entry-archive-hero__inner {
  padding: 0 16px 4px;
}

.entry-archive-hero__title {
  font-size: clamp(20px, 5vw, 26px);
  margin: 0 0 4px;
}

.entry-archive-hero__lead {
  font-size: 0.9rem;
  opacity: 0.9;
  margin: 0 0 6px;
}

.entry-archive-hero__meta {
  font-size: 0.8rem;
  color: #e5e7eb;
  margin-top: 4px;
}

.entry-archive-hero__meta .badge {
  display: inline-block;
  margin-left: 4px;
  padding: 2px 8px;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.9);
  border: 1px solid rgba(148, 163, 184, 0.9);
  font-size: 0.8rem;
}

.entry-archive-hero__nav {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}

.entry-archive-hero__nav a {
  font-size: 0.82rem;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, 0.9);
  color: #e5e7eb;
  text-decoration: none;
}

.entry-archive-hero__nav a:hover {
  background: rgba(15, 23, 42, 0.75);
}

.entry-archive-hero .cm-search {
  margin: 6px 0 4px;
}

.entry-archive-hero .cm-search__input {
  background: #fff;
}

.entry-archive-hero .cm-search__btn {
  background: #fff;
  border-color: #d1d5db;
}

.entry-archive-main .archive-sortbar {
  display: flex;
  justify-content: flex-end;
  margin: 4px 0 8px;
}

.entry-archive-main .archive-sortbar form {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  font-size: 0.85rem;
}

.entry-archive-main .archive-sortbar label {
  display: flex;
  align-items: center;
  gap: 4px;
}

.entry-archive-main .archive-sortbar select {
  padding: 6px 9px;
  border-radius: 8px;
  border: 1px solid #ddd;
  background: #fff;
  font-size: 0.85rem;
}

.entry-archive-main .archive-sortbar .btn {
  padding: 8px 12px;
  border-radius: 8px;
  border: 1px solid #ddd;
  background: #fff;
  cursor: pointer;
}

.entry-archive-main .archive-toolbar {
  margin: 6px 0 12px;
}

.entry-archive-main .archive-filters {
  border-radius: 10px;
  border: 1px solid #e5e7eb;
  background: #f9fafb;
  padding: 6px 10px 8px;
}

.entry-archive-main .archive-filters > summary {
  list-style: none;
  cursor: pointer;
  font-size: 0.9rem;
  color: #374151;
  font-weight: 600;
}

.entry-archive-main .archive-filters > summary::-webkit-details-marker {
  display: none;
}

.entry-archive-main .archive-filters[open] > summary {
  margin-bottom: 8px;
}

.entry-archive-main .archive-filters form {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: flex-end;
  margin-top: 6px;
}

.entry-archive-main .archive-filters label {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 0.8rem;
  color: #374151;
  min-width: 120px;
}

.entry-archive-main .archive-filters select,
.entry-archive-main .archive-filters input[type="search"] {
  padding: 7px 9px;
  border-radius: 8px;
  border: 1px solid #ddd;
  background: #fff;
  font-size: 0.85rem;
}

.entry-archive-main .archive-filters .btn {
  padding: 8px 14px;
  font-size: 0.85rem;
  border-radius: 8px;
  border: 1px solid #d1d5db;
  background: #fff;
  cursor: pointer;
}

.wrap-archive .card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 14px;
  margin: 0;
  padding: 0;
  list-style: none;
  width: 100%;
  max-width: 100%;
  min-width: 0;
}

@media (max-width: 1000px) {
  .wrap-archive .card-grid {
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  }
}

@media (max-width: 780px) {
  .wrap-archive .card-grid {
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  }
}

@media (max-width: 360px) {
  .wrap-archive .card-grid {
    grid-template-columns: 1fr;
  }
}

.wrap-archive .card {
  border: 1px solid #eee;
  border-radius: 10px;
  background: #fff;
  min-width: 0;
  max-width: 100%;
  height: auto;
  max-height: none;
  overflow: visible;
}

.wrap-archive .card a {
  display: block;
  color: inherit;
  text-decoration: none;
  min-width: 0;
  max-width: 100%;
  height: auto;
  max-height: none;
  overflow: visible;
}

.wrap-archive .card-thumb {
  position: relative;
  width: 100%;
  padding-top: 133.3333%;
  background: #fafafa;
  overflow: hidden;
}

.wrap-archive .card-thumb img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.wrap-archive .card-body {
  padding: 8px;
  min-width: 0;
  max-width: 100%;
  height: auto;
  max-height: none;
  overflow: visible;
}

.wrap-archive .card-title {
  font-size: 0.92rem;
  line-height: 1.35;
  margin: 0.2rem 0 0.3rem;
  display: block !important;
  height: auto !important;
  max-height: none !important;
  overflow: visible !important;
  text-overflow: clip !important;
  white-space: normal !important;
  word-break: break-word !important;
  overflow-wrap: anywhere !important;
  -webkit-line-clamp: unset !important;
  -webkit-box-orient: unset !important;
}

.wrap-archive .card-meta {
  font-size: 0.8rem;
  color: #666;
  word-break: break-word;
  overflow-wrap: anywhere;
}

.wrap-archive .badge-upcoming {
  display: inline-block;
  padding: 2px 6px;
  border-radius: 6px;
  background: #fff3cd;
  border: 1px solid #ffe08a;
  color: #7a5e00;
  font-size: 0.75rem;
  margin-right: 6px;
}

/* =========================================
   Pager
========================================= */

.cm-archive-pager {
  display: flex;
  gap: 8px;
  justify-content: center;
  align-items: center;
  margin: 18px 0;
  flex-wrap: wrap;
  font-size: 0.9rem;
}

.cm-archive-pager .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 34px;
  padding: 0 10px;
  border: 1px solid #d6d6d6;
  border-radius: 999px;
  background: #fff;
  text-decoration: none;
  color: #0b5bd3;
  line-height: 1;
  position: relative;
}

.cm-archive-pager .page-numbers.dots {
  border: none;
  background: transparent;
  color: #555;
  min-width: auto;
  padding: 0 6px;
}

.cm-archive-pager .page-numbers.current {
  background: #1973ff;
  color: #fff;
  border-color: #1973ff;
}

.cm-archive-pager .page-numbers.prev,
.cm-archive-pager .page-numbers.next {
  min-width: 70px;
}

.cm-archive-pager .page-numbers.is-disabled {
  opacity: 0.45;
  pointer-events: none;
}

.cm-archive-pager .page-numbers::before,
.cm-archive-pager .page-numbers::after {
  content: none !important;
}

.wrap-archive .nav-links,
.wrap-archive .pagination,
.wrap-archive .page-links {
  display: none !important;
}

.archive-toolbar .btn {
  color: #000;
  font-size: 14px;
  background: #fff;
  border: 1px solid #ccc;
  padding: 8px 14px;
  border-radius: 8px;
  cursor: pointer;
  transition: background-color 0.2s;
}

.archive-toolbar .btn:hover {
  background: #f2f2f2;
}

/* =========================================
   Actress index
========================================= */

.actress-list-index {
  margin: 20px 0;
  padding: 16px;
  background: #f8f9fa;
  border: 1px solid #e2e2e2;
  border-radius: 8px;
}

.actress-list-index h2 {
  margin-bottom: 12px;
  font-size: 1.2rem;
  color: #333;
}

.actress-index {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 16px;
  list-style: none;
  padding: 0;
  margin: 0;
}

.actress-index li {
  font-size: 0.95rem;
}

.actress-index a {
  text-decoration: none;
  color: #1973ff;
}

.actress-index a:hover {
  text-decoration: underline;
}

/* =========================================
   Content safety: tables / code / ads
========================================= */

.entry-content table {
  display: block;
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

pre,
code,
kbd,
samp,
.wp-block-code {
  white-space: pre-wrap;
  word-break: break-word;
  overflow-x: auto;
}

.ad-area img,
.ad-space img,
.widget img {
  max-width: 100%;
  height: auto;
}

/* =========================================
   Focus styles
========================================= */

.cm-archive-pager .page-numbers:focus-visible,
.archive-toolbar .btn:focus-visible,
.archive-toolbar select:focus-visible,
.archive-toolbar input[type="text"]:focus-visible,
.archive-toolbar input[type="search"]:focus-visible {
  outline: 2px solid #1973ff;
  outline-offset: 2px;
  box-shadow: 0 0 0 2px rgba(25, 115, 255, 0.15);
}

.cm-archive-pager .page-numbers:hover {
  background: #f6f9ff;
  border-color: #c9d8ff;
}

.cm-archive-pager .page-numbers.current:hover {
  background: #1867ea;
}

.cm-archive-pager .page-numbers,
.archive-toolbar .btn,
.actress-index a {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

/* =========================================
   Reduced motion
========================================= */

@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* =========================================
   CTA buttons
========================================= */

.entry-cta {
  margin: 16px 0;
  text-align: center;
}

.entry-cta__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 100%;
  max-width: 480px;
  padding: 12px 16px;
  border-radius: 999px;
  border: 0;
  background: #f97316;
  color: #fff;
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.2);
  transition: transform 0.12s ease-out, box-shadow 0.12s ease-out, background-color 0.12s ease-out;
}

.entry-cta__btn:hover {
  background: #ea580c;
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.25);
}

.entry-cta__btn:active {
  transform: translateY(0);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.18);
}

.entry-cta__btn:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 2px;
  box-shadow: 0 0 0 2px rgba(249, 115, 22, 0.7);
}

.af-btn {
  display: inline-block;
  padding: 12px 22px;
  background: #e60033;
  color: #fff;
  text-decoration: none;
  border-radius: 4px;
  font-weight: bold;
  text-align: center;
}

.af-btn:hover {
  opacity: 0.9;
}

.vr-cta-box {
  margin-top: 12px;
  padding: 12px 16px;
  border: 1px solid #eee;
  background: #fff7f7;
}

.vr-point-list {
  margin-left: 1.4em;
}

/* =========================================
   Sample images (legacy .cm-sample-images)
========================================= */

/* サンプル画像の箇条書き●を消す */
.cm-sample-images ul,
.cm-sample-images ol {
  list-style: none;
  padding-left: 0;
  margin-left: 0;
}

/* グリッド化（クラス名はあなたのHTML側に合わせて必要なら調整） */
.cm-sample-images ul {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.cm-sample-images li a {
  display: block;
  border-radius: 14px;
  overflow: hidden;
}

.cm-sample-images img {
  display: block;
  width: 100%;
  height: auto;
}

@media (max-width: 768px) {
  .cm-sample-images ul {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* =========================================
   Responsive tweaks (<= 768)
========================================= */

@media (max-width: 768px) {
  .entry-content,
  .entry-archive-main.wrap-archive {
    padding-left: 12px;
    padding-right: 12px;
  }

  .entry-archive-main.wrap-archive {
    padding-bottom: 24px;
  }

  .entry-archive-hero {
    margin: 0 -12px 10px;
    padding: 12px 0 8px;
  }

  .entry-archive-hero__inner {
    padding: 0 12px 4px;
  }

  .entry-archive-main .archive-sortbar {
    justify-content: flex-start;
    margin-top: 0;
  }

  .entry-archive-main .archive-filters form {
    flex-direction: column;
    align-items: stretch;
  }

  .entry-archive-main .archive-filters label {
    min-width: 0;
    width: 100%;
  }

  .actress-list-index {
    padding: 12px;
    margin: 14px 0;
  }

  .actress-list-index h2 {
    font-size: 1.05rem;
    margin-bottom: 8px;
  }

  .actress-index {
    gap: 6px 12px;
  }

  .cm-archive-pager {
    gap: 6px;
    margin: 18px 0;
  }

  .cm-archive-pager .page-numbers {
    min-width: 38px;
    height: 32px;
    padding: 9px 10px;
    font-size: 15px;
  }

  .cm-archive-pager .page-numbers.prev,
  .cm-archive-pager .page-numbers.next {
    min-width: 60px;
  }

  .ad-area,
  .ad-space,
  .widget {
    margin: 14px 0;
  }

  .entry-cta {
    margin: 14px 0;
  }

  .entry-cta__btn {
    max-width: none;
    width: 100%;
    font-size: 16px;
    padding: 13px 18px;
  }
}

@media (max-width: 480px) {
  .cm-archive-pager .page-numbers {
    min-width: 36px;
    padding: 8px 10px;
    font-size: 14px;
  }
}

@media (max-width: 375px) {
  .entry-archive-hero {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
  }

  input,
  select,
  textarea,
  button {
    max-width: 100%;
  }

  .entry-archive-hero__nav {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 6px;
  }

  .entry-archive-hero__nav a {
    flex: 0 0 auto;
    white-space: nowrap;
  }

  .entry-archive-hero__nav::-webkit-scrollbar {
    display: none;
  }

  .entry-archive-hero .cm-search {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }

  .entry-archive-hero .cm-search__input {
    flex: 1 1 100%;
    min-width: 0;
  }

  .entry-archive-hero .cm-search__btn {
    flex: 1 1 100%;
    width: 100%;
    white-space: nowrap;
  }

  .entry-archive-main .archive-sortbar form {
    flex-direction: column;
    align-items: stretch;
  }

  .entry-archive-main .archive-sortbar label,
  .entry-archive-main .archive-sortbar select,
  .entry-archive-main .archive-sortbar .btn {
    width: 100%;
  }

  .entry-archive-main .archive-filters select,
  .entry-archive-main .archive-filters input[type="search"] {
    width: 100%;
    min-width: 0;
  }

  .cm-archive-pager {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding: 0 6px;
  }

  .cm-archive-pager::-webkit-scrollbar {
    display: none;
  }

  .cm-archive-pager .page-numbers {
    flex: 0 0 auto;
    min-width: auto;
    height: 32px;
    padding: 0 12px;
    white-space: nowrap;
    line-height: 32px;
  }

  .cm-archive-pager .page-numbers.prev,
  .cm-archive-pager .page-numbers.next {
    min-width: auto;
    padding: 0 12px;
  }

  .entry-content .alignwide,
  .entry-content .alignfull {
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
  }
}

@media (max-width: 340px) {
  .cm-archive-pager .page-numbers {
    padding: 0 10px;
    font-size: 14px;
  }

  .wrap-archive .card-title {
    font-size: 0.88rem;
  }
}

/* ===== single-entry（この single-entry.php 用 / av.fit寄せ） ===== */

#page.cm-page {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 16px 32px;
}

/* ヘッダーまわり */
.entry-header .adicon {
  display: inline-block;
  margin: 8px 0 6px;
  padding: 2px 8px;
  border: 1px solid #ddd;
  border-radius: 6px;
  font-size: 0.8rem;
  color: #666;
  background: #fff;
}

.entry-header .description {
  margin: 6px 0 10px;
  color: #374151;
  font-size: 0.95rem;
  line-height: 1.6;
}

/* SNS */
.entry-sns {
  display: flex;
  gap: 8px;
  margin: 10px 0 6px;
  flex-wrap: wrap;
}

.entry-sns .sns-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  border-radius: 8px;
  border: 1px solid #ddd;
  text-decoration: none;
  background: #fff;
  color: #111;
  font-size: 0.9rem;
}

/* ページ内ナビ（av.fit の ul.feature 相当） */
.entry-page-nav .feature {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  list-style: none;
  padding: 0;
  margin: 8px 0 0;
}

.entry-page-nav .feature a {
  display: inline-block;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid #d1d5db;
  text-decoration: none;
  font-size: 0.82rem;
  color: #111;
  background: #fff;
}

.entry-page-nav .feature a:hover {
  background: #f6f6f6;
}

/* セクション見出し */
.sec-title {
  margin: 0 0 10px;
  font-size: 1.1rem;
}

/* 詳細：photopc + table（av.fit っぽく画像を右寄せ） */
.entry-details .photopc {
  float: right;
  width: min(320px, 42%);
  margin: 0 0 12px 12px;
}

.entry-details .photopc img.package {
  width: 100%;
  height: auto;
  border-radius: 8px;
}

.entry-details::after {
  content: "";
  display: block;
  clear: both;
}

/* 詳細テーブル */
.entry-detail-table {
  width: 100%;
  border-collapse: collapse;
  background: #fff;
}

.entry-detail-table th,
.entry-detail-table td {
  border: 1px solid #eee;
  padding: 8px 10px;
  font-size: 0.9rem;
  vertical-align: top;
}

.entry-detail-table th {
  width: 120px;
  background: #f9fafb;
  text-align: left;
}

/* CTA（av.fitの afflink fanzalink） */
.afflink.fanzalink {
  margin: 14px 0 0;
  text-align: center;
}

.afflink.fanzalink a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 100%;
  max-width: 520px;
  padding: 12px 16px;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 700;
  background: #f97316;
  color: #fff;
}

/* 見どころ */
.entry-highlights .highlights-body {
  line-height: 1.75;
}

/* ギャラリー（templateの gallery-grid / gallery-item 用） */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 10px;
}

.gallery-item img {
  width: 100%;
  height: auto;
  border-radius: 8px;
}

.gallery-cta {
  margin-top: 12px;
  text-align: center;
}

.gallery-cta .cta-secondary {
  display: inline-block;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid #ddd;
  background: #fff;
  text-decoration: none;
  color: #111;
}

/* ジャンル（av.fitの feature1） */
.entry-themes .feature1 {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  list-style: none;
  padding: 0;
  margin: 0;
}

.entry-themes .feature1 a {
  display: inline-block;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid #ddd;
  text-decoration: none;
  background: #fff;
  color: #111;
}

/* モバイル固定CTA（templateの mobile-fixed-cta 用） */
.mobile-fixed-cta {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 999;
  padding: 10px 12px;
  background: rgba(255, 255, 255, 0.92);
  border-top: 1px solid #eee;
}

.mobile-fixed-cta__btn {
  display: block;
  text-align: center;
  padding: 12px 16px;
  border-radius: 999px;
  background: #1973ff;
  color: #fff;
  text-decoration: none;
  font-weight: 700;
}

/* 画像右寄せはモバイルで解除 + 固定CTAぶん余白追加 */
@media (max-width: 768px) {
  #page.cm-page {
    padding-left: 12px;
    padding-right: 12px;
    padding-bottom: 110px;
  }

  .entry-details .photopc {
    float: none;
    width: 100%;
    margin: 0 0 12px 0;
  }
}

/* ===== AV:fit寄せ：single-entry 強化（見どころ→CTA→ギャラリー→CTA + 内部リンク） ===== */

.entry-single .entry-section {
  margin: 18px 0;
}

.entry-single .entry-section__title {
  margin: 0 0 10px;
  font-size: 1.1rem;
}

.entry-single .entry-highlights-body {
  font-size: 0.95rem;
  line-height: 1.75;
  color: #111;
}

.entry-single .entry-highlights-body p {
  margin: 0 0 12px;
}

/* chips */
.entry-single .entry-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  list-style: none;
  padding: 0;
  margin: 8px 0 0;
}

.entry-single .entry-chips a {
  display: inline-block;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid #ddd;
  background: #fff;
  text-decoration: none;
  color: #111;
  font-size: 0.82rem;
}

/* サンプル画像：縦横混在OKのグリッド（Cocoonのul/liに勝つ） */
.entry-single .entry-gallery__grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr)) !important;
  gap: 10px !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.entry-single .entry-gallery__item {
  margin: 0 !important;
  padding: 0 !important;
}

.entry-single .entry-gallery__item a {
  display: block;
}

.entry-single .entry-gallery__item img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 8px;
}

/* ギャラリーの“もっと見る” */
.entry-single .gallery-cta {
  margin-top: 12px;
  text-align: center;
}

/* 固定CTA（下部） */
.entry-fixed-cta {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 999;
  padding: 10px 12px;
  background: rgba(255, 255, 255, 0.92);
  border-top: 1px solid #eee;
}

.entry-fixed-cta a {
  display: block;
  text-align: center;
  padding: 12px 16px;
  border-radius: 999px;
  background: #1973ff;
  color: #fff;
  text-decoration: none;
  font-weight: 700;
}

/* モバイルは2列寄せ */
@media (max-width: 480px) {
  .entry-single .entry-gallery__grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
/* ===== CM Portal additions ===== */
.cm-main { margin-top: 10px; }

/* ranking number */
.cm-rank__no{
  position:absolute;
  right:8px;
  top:8px;
  width:28px;
  height:28px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:700;
  font-size:13px;
  background:rgba(255,255,255,.92);
  color:#111;
  border:1px solid rgba(0,0,0,.1);
}

/* =========================================================
   CM Portal Front Page (cm-sec / cm-grid / cm-card)
   ========================================================= */
.cm-sec{margin:2em 0}
.cm-sec__head{display:flex;align-items:baseline;justify-content:space-between;gap:.75em;border-bottom:1px solid #eee;padding-bottom:.5em;margin-bottom:1em}
.cm-sec__title{font-size:1.25rem;margin:0;line-height:1.2}
.cm-sec__more{font-size:.9rem;text-decoration:none;white-space:nowrap}

.cm-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
@media (max-width:1024px){.cm-grid{grid-template-columns:repeat(4,1fr)}}
@media (max-width:768px){.cm-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:520px){.cm-grid{grid-template-columns:repeat(2,1fr)}}

.cm-card{background:#fff;border:1px solid #eee;border-radius:10px;overflow:hidden;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.cm-card__link{display:block;color:inherit;text-decoration:none;height:100%}

.cm-card__thumb{position:relative;aspect-ratio:4/3;background:#f3f3f3;overflow:hidden}
.cm-card__img{width:100%;height:100%;object-fit:cover;display:block}
.cm-card__noimg{width:100%;height:100%;background:linear-gradient(135deg,#eee,#f9f9f9)}

.cm-card__title{font-size:.95rem;line-height:1.35;margin:.6em .7em .8em;max-height:3.9em;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}

.cm-rank__no{position:absolute;top:8px;left:8px;background:rgba(0,0,0,.72);color:#fff;font-weight:700;font-size:.85rem;padding:2px 8px;border-radius:999px}

.cm-note{grid-column:1/-1;padding:1em;background:#fafafa;border:1px dashed #ddd;border-radius:10px}
.cm-note--small{font-size:.9rem}


/* CM pagination */
.cm-pagination{margin:20px 0}
.cm-pagination .page-numbers,
.cm-pagination a.page-numbers{display:inline-block;margin:0 4px;padding:6px 10px;border:1px solid #ddd;border-radius:8px;text-decoration:none}
.cm-pagination .page-numbers.current{background:#111;color:#fff;border-color:#111}
.cm-pagination ul{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:6px}
.cm-pagination li{margin:0;padding:0}


/* ===== CM Portal Top (front-page.php direct) ===== */
.cm-hero{padding:18px 0 10px;background:#fff;border-bottom:1px solid #eee}
.cm-hero__inner{max-width:1200px;margin:0 auto;padding:0 16px}
.cm-hero__title{margin:0 0 10px;font-size:1.35rem}

.cm-search{display:flex;gap:8px;margin:10px 0 12px}
.cm-search__input{flex:1;min-width:0;padding:10px 12px;border:1px solid #ddd;border-radius:10px}
.cm-search__btn{padding:10px 14px;border:1px solid #111;background:#111;color:#fff;border-radius:10px;font-weight:700}

.cm-topnav{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 0}
.cm-topnav a{display:inline-block;padding:6px 10px;border:1px solid #ddd;border-radius:999px;text-decoration:none;background:#fff;color:#111;font-size:.85rem}
.cm-topnav a:hover{background:#f6f6f6}

.cm-subline{margin:0 0 10px;color:#374151;font-size:.95rem}

.cm-datebar{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 10px}
.cm-datechip{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid #ddd;border-radius:999px;text-decoration:none;background:#fff;color:#111;font-size:.86rem}
.cm-datechip__cnt{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:22px;padding:0 8px;border-radius:999px;background:#111;color:#fff;font-size:.78rem}

.cm-chips{display:flex;flex-wrap:wrap;gap:8px}
.cm-chip{display:inline-block;padding:6px 10px;border-radius:999px;border:1px solid #ddd;background:#fff;text-decoration:none;color:#111;font-size:.86rem}
.cm-chip:hover{background:#f6f6f6}

.cm-twocol{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:768px){.cm-twocol{grid-template-columns:1fr}}

.cm-subtitle{margin:0 0 8px;font-size:1.05rem}

.cm-ranktabs{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
@media (max-width:1024px){.cm-ranktabs{grid-template-columns:1fr}}
.cm-ranktitle{margin:0 0 8px;font-size:1.05rem}

.cm-monthbar{display:flex;flex-wrap:wrap;gap:8px}
.cm-monthchip{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid #ddd;border-radius:999px;text-decoration:none;background:#fff;color:#111;font-size:.86rem}
.cm-monthchip__cnt{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:22px;padding:0 8px;border-radius:999px;background:#111;color:#fff;font-size:.78rem}

.cm-postlist{list-style:none;margin:0;padding:0;border:1px solid #eee;border-radius:10px;overflow:hidden;background:#fff}
.cm-postlist li{display:flex;justify-content:space-between;gap:10px;padding:10px 12px;border-bottom:1px solid #eee}
.cm-postlist li:last-child{border-bottom:none}
.cm-postlist a{text-decoration:none}
.cm-postdate{color:#6b7280;font-size:.85rem;white-space:nowrap}

/* sale badge */
.cm-badge{position:absolute;left:8px;bottom:8px;padding:2px 8px;border-radius:999px;font-size:.78rem;font-weight:800}
.cm-badge--sale{background:rgba(249,115,22,.92);color:#fff}


/* ===== FIX: show archive pagination (override) ===== */
.wrap-archive .nav-links,
.wrap-archive .pagination{
  display:block !important;
}

/* 見た目を整える（Cocoon標準の nav-links 対応） */
.wrap-archive .nav-links ul{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}
.wrap-archive .nav-links li{margin:0;padding:0}
.wrap-archive .nav-links .page-numbers{
  display:inline-block;
  padding:6px 10px;
  border:1px solid #ddd;
  border-radius:8px;
  text-decoration:none;
}
.wrap-archive .nav-links .page-numbers.current{
  background:#111;
  color:#fff;
  border-color:#111;
}

/* ===== CM pagination (fix wrap / center) ===== */
.cm-pagination{display:flex;justify-content:center}
.cm-pagination ul{justify-content:center}
.cm-pagination .page-numbers{white-space:nowrap}

/* mobile: 横幅が厳しい時は横スクロールで崩さない */
@media (max-width: 480px){
  .cm-pagination{overflow-x:auto;-webkit-overflow-scrolling:touch;padding:0 6px}
  .cm-pagination::-webkit-scrollbar{display:none}
}

/* ===== FIX: cm-pagination が縦並びになる問題を強制的に横並びへ ===== */
.cm-pagination{
  margin: 18px 0;
  overflow-x: auto;               /* 画面が狭い時は横スクロール可 */
  -webkit-overflow-scrolling: touch;
}
.cm-pagination::-webkit-scrollbar{display:none}

/* ul.page-numbers を確実にflex(row)にする（テーマ側に負けないように強め） */
.cm-pagination > ul.page-numbers{
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  align-items: center;
  list-style: none;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
}

/* li が幅100%にされて縦積みになるのを防ぐ */
.cm-pagination > ul.page-numbers > li{
  list-style: none;
  margin: 0 !important;
  padding: 0 !important;
  flex: 0 0 auto;
}

/* ボタン（a / span）を“横に崩れない”表示に */
.cm-pagination a.page-numbers,
.cm-pagination span.page-numbers{
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: auto !important;
  min-width: 38px;
  height: 34px;
  padding: 0 12px;
  border: 1px solid #d6d6d6;
  border-radius: 999px;
  background: #fff;
  text-decoration: none;

  white-space: nowrap;           /* ← "Pr / ev" みたいな分割を防ぐ */
  word-break: keep-all;
  overflow-wrap: normal;
  line-height: 1;
}

/* current / dots */
.cm-pagination span.page-numbers.current{
  background: #111;
  color: #fff;
  border-color: #111;
}
.cm-pagination span.page-numbers.dots{
  border: 0;
  background: transparent;
  min-width: auto;
  padding: 0 6px;
}

/* 前へ/次へは少し広め（文字が割れないように） */
.cm-pagination a.page-numbers.prev,
.cm-pagination a.page-numbers.next{
  min-width: 72px;
}

/* すごく狭い端末は折り返しより横スクロール優先 */
@media (max-width:480px){
  .cm-pagination > ul.page-numbers{
    flex-wrap: nowrap;
  }
}

/* ===== FIX: cm-pagination が縦並びになる問題を強制的に横並びへ ===== */
.cm-pagination{
  margin: 18px 0;
  overflow-x: auto;               /* 画面が狭い時は横スクロール可 */
  -webkit-overflow-scrolling: touch;
}
.cm-pagination::-webkit-scrollbar{display:none}

/* ul.page-numbers を確実にflex(row)にする（テーマ側に負けないように強め） */
.cm-pagination > ul.page-numbers{
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  align-items: center;
  list-style: none;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
}

/* li が幅100%にされて縦積みになるのを防ぐ */
.cm-pagination > ul.page-numbers > li{
  list-style: none;
  margin: 0 !important;
  padding: 0 !important;
  flex: 0 0 auto;
}

/* ボタン（a / span）を“横に崩れない”表示に */
.cm-pagination a.page-numbers,
.cm-pagination span.page-numbers{
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: auto !important;
  min-width: 38px;
  height: 34px;
  padding: 0 12px;
  border: 1px solid #d6d6d6;
  border-radius: 999px;
  background: #fff;
  text-decoration: none;

  white-space: nowrap;           /* ← "Pr / ev" みたいな分割を防ぐ */
  word-break: keep-all;
  overflow-wrap: normal;
  line-height: 1;
}

/* current / dots */
.cm-pagination span.page-numbers.current{
  background: #111;
  color: #fff;
  border-color: #111;
}
.cm-pagination span.page-numbers.dots{
  border: 0;
  background: transparent;
  min-width: auto;
  padding: 0 6px;
}

/* 前へ/次へは少し広め（文字が割れないように） */
.cm-pagination a.page-numbers.prev,
.cm-pagination a.page-numbers.next{
  min-width: 72px;
}

/* すごく狭い端末は折り返しより横スクロール優先 */
@media (max-width:480px){
  .cm-pagination > ul.page-numbers{
    flex-wrap: nowrap;
  }
}

/* ===== CM pagination (force horizontal) ===== */
.cm-pagination{
  margin:24px 0;
  width:100%;
}
.cm-pagination > ul.page-numbers{
  display:flex !important;
  flex-direction:row !important;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  gap:8px;
  margin:0;
  padding:0;
  width:100%;
  list-style:none;
}
.cm-pagination > ul.page-numbers > li{
  margin:0;
  padding:0;
  list-style:none;
}

/* clickable pills */
.cm-pagination .page-numbers{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:44px;
  height:38px;
  padding:0 12px;
  border:1px solid #ddd;
  border-radius:10px;
  background:#fff;
  color:#111;
  text-decoration:none;

  /* prevent "Pr / ev" or "17 / ,8 / 72" */
  white-space:nowrap;
  word-break:keep-all;
  overflow-wrap:normal;
  line-height:1;
}
.cm-pagination .page-numbers.current{
  background:#111;
  color:#fff;
  border-color:#111;
}

/* prev/next can be a bit wider */
.cm-pagination .prev.page-numbers,
.cm-pagination .next.page-numbers{
  min-width:auto;
  padding:0 14px;
}


/* Fix: cm-pagination horizontal */
.cm-pagination{margin:20px 0}
.cm-pagination ul.page-numbers{
  list-style:none;
  margin:0;
  padding:0;
  display:flex !important;
  flex-wrap:wrap;
  gap:8px;
  justify-content:center;
  align-items:center;
}
.cm-pagination li{margin:0;padding:0;display:block}
.cm-pagination .page-numbers{
  display:inline-flex !important;
  align-items:center;
  justify-content:center;
  min-width:44px;
  height:44px;
  padding:0 12px;
  border:1px solid #ddd;
  border-radius:12px;
  text-decoration:none;
  line-height:1;
  background:#fff;
  color:#111;
}
.cm-pagination .page-numbers.current{
  background:#111;
  color:#fff;
  border-color:#111;
}
.cm-pagination a.page-numbers:hover{background:#f6f6f6}
.cm-pagination .dots{border-color:#eee;color:#666}

/* =========================================
   DMM litevideo iframe（サンプル動画）崩れ対策
   - iframe内スクロールが出る/高さが変になるのを抑制
========================================= */

/* 0) サンプル動画セクションは float の影響を受けないように */
.entry-sample-movie,
.cm-sample-movie-wrap{
  clear: both;
}

/* 1) litevideo の iframe をレスポンシブ化（aspect-ratio を優先） */
.entry-content iframe[src*="dmm.co.jp/litevideo"],
.entry-content iframe[src*="litevideo"],
.entry-single iframe[src*="dmm.co.jp/litevideo"],
.entry-single iframe[src*="litevideo"]{
  width: 100% !important;
  max-width: 100% !important;
  aspect-ratio: 16 / 9;
  height: auto !important;
  min-height: 0 !important;
  display: block !important;
  border: 0 !important;
}

/* 2) 親が変な overflow を持っていてもスクロールが出にくいように */
.entry-content .sample-movie,
.entry-content .cm-sample-movie,
.entry-content .cm-sample-movie-wrap,
.entry-single .sample-movie,
.entry-single .cm-sample-movie,
.entry-single .cm-sample-movie-wrap{
  width: 100%;
  max-width: 100%;
  overflow: hidden;
}

/* 3) Cocoon側の iframe 固定height指定があっても極力打ち消す */
.entry-content .sample-movie iframe,
.entry-content .cm-sample-movie iframe,
.entry-content .cm-sample-movie-wrap iframe,
.entry-single .sample-movie iframe,
.entry-single .cm-sample-movie iframe,
.entry-single .cm-sample-movie-wrap iframe{
  height: auto !important;
}

/* =========================================
   サンプル画像（グリッド）の崩れにくさ強化
   - 画像が巨大化/縦横混在で崩れるのを抑制
========================================= */

/* ul/li がテーマ側で変な margin/padding/float を持っても勝つ */
.entry-content .cm-sample-images ul,
.entry-single  .cm-sample-images ul,
.entry-content .entry-gallery__grid,
.entry-single  .entry-gallery__grid{
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* 画像の表示を安定（親に引っ張られて横幅が崩れない） */
.entry-content .cm-sample-images img,
.entry-single  .cm-sample-images img,
.entry-content .entry-gallery__grid img,
.entry-single  .entry-gallery__grid img{
  max-width: 100% !important;
  height: auto !important;
  display: block !important;
}

/* 画像リンクに余計な inline 要素が混ざっても崩れない */
.entry-content .cm-sample-images li a,
.entry-single  .cm-sample-images li a,
.entry-content .entry-gallery__item a,
.entry-single  .entry-gallery__item a{
  display: block !important;
  width: 100%;
}

/* すごく狭い画面で“縦1列”を避けたい時の保険 */
@media (max-width: 360px){
  .entry-content .cm-sample-images ul{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
/* =========================
   CM TOP: PCレイアウト崩れ修正
   （front-page の .cm-cards に対応）
========================= */

/* 1) トップのカード一覧をグリッド化 */
body.home .cm-cards{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px;
  align-items: stretch;
}

/* 2) a.cm-card を“ブロック/カード”として扱う（これが崩れの本丸） */
body.home .cm-cards > a.cm-card{
  display: flex;
  flex-direction: column;
  height: 100%;
  color: inherit;
  text-decoration: none;
}

/* 3) 画像枠と本文の安定化 */
body.home .cm-card__thumb{ position: relative; aspect-ratio: 4/3; overflow: hidden; }
body.home .cm-card__img{ width: 100%; height: 100%; object-fit: cover; display: block; }

body.home .cm-card__body{ padding: 0; }
body.home .cm-card__meta{
  margin: -0.2em .7em .8em;
  font-size: .85rem;
  color: #6b7280;
}

/* 4) 画面が狭いときは2列に固定（スマホ安定） */
@media (max-width: 520px){
  body.home .cm-cards{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
/* =========================================================
   FIX: PCでトップだけ1カラム化（余白/カラム崩れ対策）
   - Cocoonの「メイン860px＋サイドバー」前提だと、
     トップのカード/検索UIが細く見えやすいので、
     トップ（body.home）のみサイドバーを消してメインを全幅にします。
   ========================================================= */
@media (min-width: 1024px){
  body.home .sidebar,
  body.home #sidebar,
  body.home .sidebar-widget-area{
    display: none !important;
  }
  body.home .main{
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    float: none !important;
  }
  body.home .content,
  body.home #content{
    width: 100% !important;
  }
  body.home .content-in,
  body.home #content-in{
    width: 100% !important;
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
  }
}

/* =========================================================
   FIX: トップのカード画像の比率を安定（PCでも崩れにくく）
   ========================================================= */
body.home .cm-sec--new .cm-card__thumb{
  aspect-ratio: 4 / 3;
}
body.home .cm-sec--new .cm-card__img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}
/* =========================================================
   OPTION: 競合寄り（PCは3列固定 / タブレット2列 / スマホ2列）
   - いまの auto-fill(minmax()) だとPCで列数が増えすぎる場合があります。
   ========================================================= */
@media (min-width: 1024px){
  body.home .cm-sec--new .cm-cards{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (max-width: 1023px){
  body.home .cm-sec--new .cm-cards{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
/* =========================================================
   CM: トップ（body.home）余白/オーバーフロー崩れの復旧パッチ
   目的:
   - PCでコンテンツ枠が不自然に細い/余白が広い問題を緩和
   - 見出し・長文が途中で切れる（overflow/nowrap）を防ぐ
   - スマホ/PC両対応
   使い方: 子テーマ style.css の「一番下」にコピペ
========================================================= */

/* --- 1) トップの“枠”をPCで広げる（必要な範囲だけ） --- */
@media (min-width: 1025px){
  body.home .content-in{
    max-width: 1200px;         /* お好みで 1100〜1400 */
    width: calc(100% - 40px);  /* 左右余白 */
    margin: 0 auto;
  }
}

/* スマホは左右余白を小さく */
@media (max-width: 520px){
  body.home .content-in{
    width: calc(100% - 20px);
    margin: 0 auto;
  }
}

/* --- 2) 文字が“途中で切れる”系を強制解除（トップだけ） --- */
/* 見出し/タイトルが nowrap + overflow hidden で切れているケースが多い */
body.home h1,
body.home h2,
body.home .site-title,
body.home .site-name,
body.home .logo-text,
body.home .cm-hero__title{
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: clip !important;
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* flex内でテキストがはみ出して切れる対策（min-width:0 が重要） */
body.home .content-in *{
  /* “とりあえずの安全弁”として、長いURLや英数字も折り返す */
  overflow-wrap: anywhere;
}

/* --- 3) トップのカード一覧（.cm-cards）をPC/スマホで安定表示 --- */
body.home .cm-cards{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  gap: 12px;
  align-items: stretch;
}

body.home .cm-cards > a.cm-card{
  display: flex;
  flex-direction: column;
  height: 100%;
  min-width: 0;
  text-decoration: none;
  color: inherit;
}

/* サムネ枠：画像を確実に収める */
body.home .cm-card__thumb{
  position: relative;
  aspect-ratio: 4/3;
  overflow: hidden;
  border-radius: 10px;
}

body.home .cm-card__img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* タイトルが長い場合でも“横はみ出し”させない */
body.home .cm-card__title{
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* スマホは2列固定（崩れにくい） */
@media (max-width: 520px){
  body.home .cm-cards{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }
}

/* --- 4) 検索ボタン/チップが横に飛び出す対策（存在する場合のみ効く） --- */
body.home .cm-chiplist,
body.home .cm-tags,
body.home .cm-btns,
body.home .cm-nav,
body.home .cm-links{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  min-width: 0;
}

