/* ============================================
   Compagnon Cocoon — Pet wellness & comfort blog
   Unique CSS — Anti-footprint
   Prefix: .cc__
   Palette: warm amber #8B6F47, dark cocoa #2C1810
   Fonts: DM Serif Display (heading), Nunito (body)
   ============================================ */

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

:root {
  --cc-primary: #8B6F47;
  --cc-primary-light: #A6895E;
  --cc-dark: #2C1810;
  --cc-bg: #FDF8F2;
  --cc-bg-alt: #F5EDE3;
  --cc-text: #2C1810;
  --cc-text-muted: #7A6B5D;
  --cc-border: #E8DDD0;
  --cc-accent: #C49A6C;
}

body {
  font-family: 'Nunito', 'Trebuchet MS', sans-serif;
  font-size: 17px;
  line-height: 1.75;
  color: var(--cc-text);
  background: var(--cc-bg);
}

a { color: var(--cc-primary); text-decoration: none; transition: color .25s ease; }
a:hover { color: var(--cc-accent); }

img { max-width: 100%; height: auto; display: block; }

/* ---- Container ---- */
.cc__wrap {
  max-width: 880px;
  margin: 0 auto;
  padding: 0 24px;
}

/* ---- Header ---- */
.cc__head {
  background: var(--cc-dark);
  padding: 20px 0;
  border-bottom: 3px solid var(--cc-primary);
}
.cc__head-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.cc__logo {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 26px;
  color: #FDF8F2;
  text-decoration: none;
  letter-spacing: 0.5px;
}
.cc__logo:hover { color: var(--cc-accent); }
.cc__baseline {
  display: block;
  font-family: 'Nunito', sans-serif;
  font-size: 11px;
  color: var(--cc-text-muted);
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-top: 2px;
}
.cc__nav {
  display: flex;
  gap: 24px;
  align-items: center;
}
.cc__nav a {
  color: #ccc;
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
}
.cc__nav a:hover { color: var(--cc-accent); }
.cc__lang {
  display: flex;
  gap: 8px;
  margin-left: 16px;
  padding-left: 16px;
  border-left: 1px solid #555;
}
.cc__lang a {
  font-size: 12px;
  color: #888;
  font-weight: 700;
}
.cc__lang a.is-active { color: var(--cc-accent); }

/* ---- Hero (homepage) ---- */
.cc__hero {
  background: linear-gradient(135deg, var(--cc-dark) 0%, #3D2A1E 100%);
  padding: 64px 0 68px;
  text-align: center;
  border-bottom: 4px solid var(--cc-primary);
}
.cc__hero-title {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 42px;
  color: #FDF8F2;
  margin-bottom: 16px;
  line-height: 1.15;
  letter-spacing: 0.5px;
}
.cc__hero-sub {
  font-size: 17px;
  color: #B8A898;
  max-width: 560px;
  margin: 0 auto;
  line-height: 1.7;
}

/* ---- Section titles ---- */
.cc__section-title {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 24px;
  color: var(--cc-dark);
  margin: 48px 0 28px;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--cc-border);
}

/* ---- Guides section (homepage pillar content) ---- */
/* --- Guides section (homepage) --- */
.cc__guides {
  padding: 56px 0 40px;
}
.cc__guides-header {
  text-align: center;
  margin-bottom: 40px;
}
.cc__guides-title {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 30px;
  color: var(--cc-dark);
  margin-bottom: 10px;
}
.cc__guides-sub {
  font-size: 15px;
  color: var(--cc-text-muted);
  max-width: 540px;
  margin: 0 auto;
  line-height: 1.6;
}
.cc__guides-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.cc__guide-card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--cc-border);
  border-radius: 14px;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: box-shadow .3s ease, transform .3s ease;
}
.cc__guide-card:hover {
  box-shadow: 0 10px 32px rgba(44,24,16,0.12);
  transform: translateY(-4px);
}
.cc__guide-img {
  width: 100%;
  height: 160px;
  object-fit: cover;
  display: block;
}
.cc__guide-body {
  padding: 20px 18px 18px;
}
.cc__guide-icon {
  font-size: 24px;
  margin-bottom: 6px;
  line-height: 1;
  display: block;
}
.cc__guide-name {
  display: block;
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 17px;
  font-weight: 700;
  color: var(--cc-dark);
  margin-bottom: 8px;
  line-height: 1.3;
}
.cc__guide-desc {
  display: block;
  font-size: 13.5px;
  color: var(--cc-text-muted);
  line-height: 1.55;
}
.cc__guide-cta {
  display: inline-block;
  margin-top: 12px;
  font-size: 13px;
  font-weight: 700;
  color: var(--cc-primary);
  letter-spacing: 0.02em;
}

/* --- Article rich content: TOC, tips, warnings, FAQ --- */
.cc__toc {
  background: var(--cc-bg-alt);
  border: 1px solid var(--cc-border);
  border-radius: 10px;
  padding: 20px 24px;
  margin: 24px 0 32px;
}
.cc__toc h3 {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 18px;
  color: var(--cc-dark);
  margin-bottom: 12px;
}
.cc__toc ol {
  padding-left: 20px;
  margin: 0;
}
.cc__toc li {
  margin-bottom: 6px;
  line-height: 1.5;
}
.cc__toc a {
  color: var(--cc-primary);
  text-decoration: none;
  border-bottom: 1px dotted var(--cc-primary-light);
}
.cc__toc a:hover {
  color: var(--cc-dark);
}
.cc__tip {
  background: #FFF9E6;
  border-left: 4px solid #D4A843;
  border-radius: 0 8px 8px 0;
  padding: 16px 20px;
  margin: 24px 0;
}
.cc__tip strong {
  display: block;
  color: #8B6F00;
  margin-bottom: 4px;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.cc__warning {
  background: #FFF0F0;
  border-left: 4px solid #C0392B;
  border-radius: 0 8px 8px 0;
  padding: 16px 20px;
  margin: 24px 0;
}
.cc__warning strong {
  display: block;
  color: #96281B;
  margin-bottom: 4px;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.cc__faq {
  margin-top: 40px;
  padding-top: 32px;
  border-top: 2px solid var(--cc-border);
}
.cc__faq h2 {
  font-family: 'DM Serif Display', Georgia, serif;
  margin-bottom: 20px;
}
.cc__faq details {
  background: #fff;
  border: 1px solid var(--cc-border);
  border-radius: 8px;
  margin-bottom: 10px;
  overflow: hidden;
}
.cc__faq summary {
  padding: 14px 18px;
  font-weight: 700;
  cursor: pointer;
  color: var(--cc-dark);
  list-style: none;
  display: flex;
  align-items: center;
  gap: 10px;
}
.cc__faq summary::before {
  content: '+';
  font-size: 20px;
  font-weight: 700;
  color: var(--cc-primary);
  flex-shrink: 0;
  width: 24px;
  text-align: center;
}
.cc__faq details[open] summary::before {
  content: '−';
}
.cc__faq details p {
  padding: 0 18px 16px;
  color: var(--cc-text-muted);
  line-height: 1.7;
}
.cc__article-meta {
  font-size: 14px;
  color: var(--cc-text-muted);
  margin-bottom: 24px;
}
.cc__feed-header {
  margin-bottom: 28px;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--cc-border);
}
.cc__feed-title {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 22px;
  color: var(--cc-dark);
}

/* ---- Article feed (homepage magazine grid) ---- */
.cc__feed {
  padding: 40px 0 60px;
}
.cc__feed .cc__wrap {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 28px;
  max-width: 960px;
}
.cc__feed article {
  background: #fff;
  border: 1px solid var(--cc-border);
  border-radius: 10px;
  padding: 28px 24px 24px;
  transition: box-shadow .25s ease, transform .2s ease;
}
.cc__feed article:hover {
  box-shadow: 0 6px 24px rgba(44,24,16,0.1);
  transform: translateY(-3px);
}
.cc__feed article img {
  width: 100%;
  height: 180px;
  object-fit: cover;
  border-radius: 6px;
  margin-bottom: 14px;
}
.cc__feed article:first-child {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  align-items: center;
  padding: 36px 32px;
}
.cc__feed article:first-child img {
  height: 280px;
  border-radius: 8px;
  margin-bottom: 0;
}
.cc__feed article h2 {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 20px;
  line-height: 1.3;
  margin-bottom: 8px;
}
.cc__feed article:first-child h2 { font-size: 26px; }
.cc__feed article h2 a { color: var(--cc-dark); text-decoration: none; }
.cc__feed article h2 a:hover { color: var(--cc-primary); }
.cc__feed article time {
  display: block;
  font-size: 11px;
  color: var(--cc-text-muted);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 10px;
}
.cc__feed article p {
  font-size: 14px;
  color: var(--cc-text-muted);
  line-height: 1.6;
  margin-bottom: 14px;
}
.cc__feed article:first-child p { font-size: 15px; }
.cc__feed article > a:last-child {
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  color: var(--cc-primary);
  text-transform: uppercase;
  letter-spacing: 1px;
  border: 2px solid var(--cc-primary);
  padding: 7px 18px;
  border-radius: 4px;
  transition: all .25s ease;
}
.cc__feed article > a:last-child:hover {
  background: var(--cc-primary);
  color: #fff;
}

/* EN section on bilingual homepage */
.cc__feed .cc__section-title {
  grid-column: 1 / -1;
}
.cc__feed .cc__feed-en {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 28px;
}

/* ---- Single article ---- */
.cc__article {
  max-width: 700px;
  margin: 0 auto;
  padding: 44px 0 60px;
}
.cc__article-title {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 32px;
  color: var(--cc-dark);
  line-height: 1.2;
  margin-bottom: 12px;
}
.cc__article-meta {
  font-size: 13px;
  color: var(--cc-text-muted);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 36px;
  padding-bottom: 20px;
  border-bottom: 2px solid var(--cc-primary);
}

.cc__article-hero {
  margin-bottom: 32px;
  border-radius: 10px;
  overflow: hidden;
}
.cc__article-hero img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 10px;
}

.cc__article-body {
  font-size: 17px;
  line-height: 1.85;
  color: #3A2D22;
}
.cc__article-body p { margin-bottom: 20px; }
.cc__article-body h2 {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 22px;
  color: var(--cc-dark);
  margin: 36px 0 16px;
  line-height: 1.25;
}
.cc__article-body h3 {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 18px;
  color: var(--cc-text-muted);
  margin: 28px 0 12px;
}
.cc__article-body ul, .cc__article-body ol {
  margin: 0 0 20px 28px;
  color: #4A3D30;
}
.cc__article-body li { margin-bottom: 8px; }
.cc__article-body blockquote {
  margin: 28px 0;
  padding: 22px 28px;
  background: var(--cc-bg-alt);
  border-left: 4px solid var(--cc-primary);
  font-style: italic;
  color: var(--cc-text-muted);
  border-radius: 0 6px 6px 0;
}
.cc__article-body strong { color: var(--cc-dark); }

/* Article footer */
.cc__sources {
  margin-top: 40px;
  padding: 20px 24px;
  background: var(--cc-bg-alt, #FAF6F1);
  border-radius: 8px;
  border-left: 3px solid var(--cc-primary);
}
.cc__sources h3 {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 16px;
  color: var(--cc-dark);
  margin-bottom: 10px;
}
.cc__sources ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.cc__sources li {
  font-size: 13px;
  line-height: 1.8;
  color: var(--cc-text-muted);
}
.cc__sources a {
  color: var(--cc-primary);
  text-decoration: none;
  border-bottom: 1px dotted var(--cc-primary);
}
.cc__sources a:hover {
  border-bottom-style: solid;
}
.cc__article-footer {
  margin-top: 44px;
  padding-top: 24px;
  border-top: 1px solid var(--cc-border);
}
.cc__tags {
  font-size: 12px;
  color: var(--cc-text-muted);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 20px;
}

/* Related articles */
.cc__related {
  margin-top: 20px;
}
.cc__related-title {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 16px;
  color: var(--cc-dark);
  margin-bottom: 10px;
}
.cc__related ul { list-style: none; padding: 0; }
.cc__related li {
  padding: 6px 0;
  font-size: 15px;
}
.cc__related li::before {
  content: "\2192\00a0";
  color: var(--cc-primary);
}

/* ---- About page ---- */
.cc__about {
  max-width: 700px;
  margin: 0 auto;
  padding: 44px 0 60px;
}
.cc__about-title {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 28px;
  color: var(--cc-dark);
  margin-bottom: 8px;
}
.cc__about-role {
  font-size: 14px;
  color: var(--cc-text-muted);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 28px;
  padding-bottom: 20px;
  border-bottom: 2px solid var(--cc-primary);
}
.cc__about-body {
  font-size: 17px;
  line-height: 1.85;
  color: #3A2D22;
}
.cc__about-body p { margin-bottom: 20px; }

/* ---- Footer ---- */
.cc__foot {
  background: var(--cc-dark);
  padding: 28px 0;
  text-align: center;
  color: #7A6B5D;
  font-size: 13px;
  border-top: 3px solid var(--cc-primary);
}
.cc__foot a { color: var(--cc-accent); }
.cc__foot-note {
  margin-top: 8px;
  font-size: 11px;
  color: #5A4B3D;
  font-style: italic;
}

/* ---- Product review (guide-achat) ---- */
.cc__review {
  max-width: 740px;
  margin: 0 auto;
  padding: 44px 0 60px;
}
.cc__review-title {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 30px;
  color: var(--cc-dark);
  line-height: 1.2;
  margin-bottom: 12px;
}
.cc__review-meta {
  font-size: 13px;
  color: var(--cc-text-muted);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 28px;
}
.cc__review-hero {
  margin-bottom: 28px;
  border-radius: 8px;
  overflow: hidden;
  background: var(--cc-bg-alt);
  min-height: 200px;
}
.cc__review-hero img {
  width: 100%;
  height: auto;
  display: block;
}
.cc__review-verdict {
  background: var(--cc-bg-alt);
  border: 2px solid var(--cc-border);
  border-radius: 8px;
  padding: 24px 28px;
  margin-bottom: 32px;
  display: flex;
  align-items: center;
  gap: 20px;
}
.cc__verdict-label {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 14px;
  color: var(--cc-text-muted);
  text-transform: uppercase;
  letter-spacing: 1px;
}
.cc__verdict-score {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 42px;
  color: var(--cc-primary);
  line-height: 1;
  min-width: 60px;
  text-align: center;
}
.cc__verdict-summary {
  font-size: 15px;
  color: var(--cc-text);
  line-height: 1.5;
  flex: 1;
}
.cc__review-specs {
  margin-bottom: 28px;
  border: 1px solid var(--cc-border);
  border-radius: 6px;
  overflow: hidden;
}
.cc__review-specs table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}
.cc__review-specs th {
  background: var(--cc-dark);
  color: #FDF8F2;
  padding: 10px 16px;
  text-align: left;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  font-size: 12px;
}
.cc__review-specs td {
  padding: 10px 16px;
  border-bottom: 1px solid var(--cc-border);
}
.cc__review-specs tr:nth-child(even) td { background: var(--cc-bg-alt); }
.cc__review-specs td:first-child {
  font-weight: 700;
  color: var(--cc-text-muted);
  width: 35%;
}
.cc__review-body {
  font-size: 17px;
  line-height: 1.85;
  color: #3A2D22;
  margin-bottom: 32px;
}
.cc__review-body p { margin-bottom: 20px; }
.cc__review-body h2 {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 22px;
  color: var(--cc-dark);
  margin: 36px 0 16px;
}
.cc__review-body h3 {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 18px;
  color: var(--cc-text-muted);
  margin: 28px 0 12px;
}
.cc__review-body ul, .cc__review-body ol {
  margin: 0 0 20px 28px;
  color: #4A3D30;
}
.cc__review-body li { margin-bottom: 8px; }
.cc__review-body blockquote {
  margin: 28px 0;
  padding: 22px 28px;
  background: var(--cc-bg-alt);
  border-left: 4px solid var(--cc-primary);
  font-style: italic;
  color: var(--cc-text-muted);
  border-radius: 0 6px 6px 0;
}
.cc__review-pros-cons {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 36px;
}
.cc__pros, .cc__cons {
  padding: 20px;
  border-radius: 8px;
}
.cc__pros {
  background: #F0F7F0;
  border: 1px solid #C8E6C8;
}
.cc__cons {
  background: #FFF5F5;
  border: 1px solid #EECECE;
}
.cc__pros h3, .cc__cons h3 {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 16px;
  margin-bottom: 10px;
}
.cc__pros h3 { color: #2E7D32; }
.cc__cons h3 { color: #C62828; }
.cc__pros ul, .cc__cons ul {
  list-style: none;
  padding: 0;
  font-size: 14px;
}
.cc__pros li::before { content: "\2713\00a0"; color: #2E7D32; font-weight: 700; }
.cc__cons li::before { content: "\2717\00a0"; color: #C62828; font-weight: 700; }
.cc__pros li, .cc__cons li { padding: 4px 0; }

/* ---- Shop page (boutique) ---- */
.cc__shop {
  padding: 44px 0 60px;
}
.cc__shop-intro {
  text-align: center;
  margin-bottom: 40px;
}
.cc__shop-title {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 32px;
  color: var(--cc-dark);
  margin-bottom: 16px;
}
.cc__shop-desc {
  font-size: 16px;
  color: var(--cc-text-muted);
  max-width: 640px;
  margin: 0 auto;
  line-height: 1.65;
}
.cc__shop-cats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 48px;
}
.cc__shop-cat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 24px 16px;
  background: var(--cc-bg-alt);
  border: 1px solid var(--cc-border);
  border-radius: 8px;
  text-decoration: none;
  transition: all .25s ease;
}
.cc__shop-cat:hover {
  border-color: var(--cc-primary);
  background: #fff;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(44,24,16,0.08);
}
.cc__shop-cat-icon { font-size: 28px; }
.cc__shop-cat-name {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 15px;
  color: var(--cc-dark);
  text-align: center;
}
.cc__shop-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}
.cc__shop-product {
  border: 1px solid var(--cc-border);
  border-radius: 8px;
  overflow: hidden;
  background: #fff;
  transition: box-shadow .25s ease;
}
.cc__shop-product:hover {
  box-shadow: 0 4px 16px rgba(44,24,16,0.1);
}
.cc__shop-product img {
  width: 100%;
  height: 200px;
  object-fit: cover;
}
.cc__shop-product-info {
  padding: 16px 20px;
}
.cc__shop-product-info h2 {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 17px;
  color: var(--cc-dark);
  margin-bottom: 6px;
}
.cc__shop-product-info h2 a {
  color: inherit;
  text-decoration: none;
}
.cc__shop-product-info h2 a:hover {
  color: var(--cc-primary);
}
.cc__shop-product-info p {
  font-size: 13px;
  color: var(--cc-text-muted);
  line-height: 1.5;
  margin-bottom: 12px;
}
.cc__shop-score {
  display: inline-block;
  font-size: 14px;
  font-weight: 700;
  color: var(--cc-primary);
  margin-bottom: 8px;
}
.cc__product-card {
  border: 1px solid var(--cc-border);
  border-radius: 8px;
  overflow: hidden;
  background: #fff;
  transition: box-shadow .25s ease;
}
.cc__product-card:hover {
  box-shadow: 0 4px 16px rgba(44,24,16,0.1);
}
.cc__product-img {
  width: 100%;
  height: 200px;
  background: var(--cc-bg-alt);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cc-text-muted);
  font-size: 13px;
}
.cc__product-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.cc__product-info {
  padding: 16px 20px;
}
.cc__product-name {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 17px;
  color: var(--cc-dark);
  margin-bottom: 6px;
}
.cc__product-price {
  font-size: 20px;
  font-weight: 700;
  color: var(--cc-primary);
  margin-bottom: 8px;
}
.cc__product-desc {
  font-size: 13px;
  color: var(--cc-text-muted);
  line-height: 1.5;
  margin-bottom: 12px;
}
.cc__product-btn {
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  color: var(--cc-primary);
  text-transform: uppercase;
  letter-spacing: 1px;
  border: 2px solid var(--cc-primary);
  padding: 6px 16px;
  border-radius: 4px;
  text-decoration: none;
  transition: all .25s ease;
}
.cc__product-btn:hover {
  background: var(--cc-primary);
  color: #fff;
}

/* ---- Category page ---- */
.cc__catpage {
  padding: 44px 0 60px;
}
.cc__catpage-header {
  margin-bottom: 36px;
}
.cc__catpage-title {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 28px;
  color: var(--cc-dark);
  margin-bottom: 12px;
}
.cc__catpage-desc {
  font-size: 16px;
  color: var(--cc-text-muted);
  line-height: 1.65;
  margin-bottom: 16px;
}
.cc__breadcrumb {
  font-size: 13px;
  color: var(--cc-text-muted);
}
.cc__breadcrumb a { color: var(--cc-primary); }
.cc__catpage-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  margin-bottom: 48px;
}
.cc__catpage-guide {
  background: var(--cc-bg-alt);
  padding: 28px 32px;
  border-radius: 8px;
  margin-bottom: 40px;
}
.cc__catpage-guide h2 {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 22px;
  color: var(--cc-dark);
  margin-bottom: 16px;
}
.cc__catpage-guide p {
  font-size: 15px;
  line-height: 1.7;
  margin-bottom: 12px;
}
.cc__catpage-articles h2 {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 22px;
  color: var(--cc-dark);
  margin-bottom: 16px;
}

/* ---- Article images ---- */
.cc__article-img {
  margin: 28px 0;
  border-radius: 8px;
  overflow: hidden;
  background: var(--cc-bg-alt);
}
.cc__article-img img {
  width: 100%;
  height: auto;
  display: block;
}
.cc__article-img figcaption {
  padding: 10px 16px;
  font-size: 13px;
  color: var(--cc-text-muted);
  font-style: italic;
  text-align: center;
}

/* ---- Responsive ---- */
@media (max-width: 680px) {
  .cc__head-inner {
    flex-direction: column;
    gap: 12px;
    text-align: center;
  }
  .cc__nav { flex-wrap: wrap; justify-content: center; gap: 14px; }
  .cc__lang { margin-left: 0; padding-left: 0; border-left: none; }
  .cc__hero-title { font-size: 26px; }
  .cc__article-title { font-size: 24px; }
  .cc__section-title { font-size: 20px; }
  .cc__wrap { padding: 0 16px; }
  .cc__guides-grid { grid-template-columns: repeat(2, 1fr); }
  .cc__guide-img { height: 130px; }
  .cc__feed .cc__wrap { grid-template-columns: 1fr; }
  .cc__feed article:first-child { grid-template-columns: 1fr; }
  .cc__feed .cc__feed-en { grid-template-columns: 1fr; }
  .cc__shop-cats { grid-template-columns: repeat(2, 1fr); }
  .cc__shop-grid { grid-template-columns: 1fr; }
  .cc__catpage-grid { grid-template-columns: 1fr; }
  .cc__review-pros-cons { grid-template-columns: 1fr; }
}
