/* ============================================================
   Compare & Conquer — CSS
   wholesalecatalogz.com / OpenCart + Journal3
   File: catalog/view/theme/[theme]/stylesheet/compare.css
   All classes prefixed cp- to avoid Journal3 conflicts
   ============================================================ */

:root {
  --cp-navy:      #111827;
  --cp-navy-mid:  #243050;
  --cp-accent:    #c8922a;
  --cp-teal:      #1D9E75;
  --cp-teal-lt:   #e1f5ee;
  --cp-coral:     #c94f2a;
  --cp-coral-lt:  #fdf0ec;
  --cp-purple:    #6b5fd4;
  --cp-purple-lt: #eeedfe;
  --cp-amber:     #b06e12;
  --cp-amber-lt:  #faeeda;
  --cp-blue:      #1a5fa5;
  --cp-blue-lt:   #e6f1fb;
  --cp-gray-bg:   #f7f6f3;
  --cp-border:    #e5e3de;
  --cp-text:      #1a1a1a;
  --cp-text-2:    #555555;
  --cp-text-muted:#888888;
  --cp-white:     #ffffff;
  --cp-r:         8px;
  --cp-rl:        12px;
}


/* ════════════════════════════════════════════════════════════
   1. HERO BANNER
════════════════════════════════════════════════════════════ */
.cp-hero {
  background: var(--cp-navy);
  padding: 32px 0 28px;
  position: relative;
  overflow: hidden;
}
.cp-hero::before {
  content: '';
  position: absolute;
  top: -50px; right: -60px;
  width: 280px; height: 280px;
  background: radial-gradient(circle, rgba(200,146,42,.12) 0%, transparent 70%);
  pointer-events: none;
}
.cp-hero::after {
  content: '';
  position: absolute;
  bottom: -30px; left: -30px;
  width: 180px; height: 180px;
  background: radial-gradient(circle, rgba(107,95,212,.08) 0%, transparent 70%);
  pointer-events: none;
}
.cp-hero-inner {
  position: relative;
  z-index: 1;
}

/* Breadcrumb override inside hero */
.cp-hero .breadcrumb {
  background: transparent;
  padding: 0;
  margin-bottom: 14px;
}
.cp-hero .breadcrumb li a,
.cp-hero .breadcrumb li + li::before {
  color: rgba(255,255,255,.5);
}
.cp-hero .breadcrumb > li:last-child a,
.cp-hero .breadcrumb > li.active {
  color: rgba(255,255,255,.7);
}

.cp-hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: rgba(200,146,42,.15);
  border: 1px solid rgba(200,146,42,.32);
  border-radius: 20px;
  padding: 4px 14px;
  font-size: 12px;
  font-weight: 600;
  color: var(--cp-accent);
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: 14px;
}

.cp-hero h1 {
  font-size: 28px;
  font-weight: 700;
  color: #ffffff;
  line-height: 1.3;
  margin-bottom: 10px;
  max-width: 780px;
}

.cp-hero-sub {
  color: rgba(255,255,255,.62);
  font-size: 15px;
  line-height: 1.68;
  max-width: 660px;
  margin-bottom: 18px;
}

/* A vs B pill strip */
.cp-versus-strip {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.cp-vs-pill {
  display: inline-flex;
  align-items: center;
  padding: 5px 16px;
  border-radius: 20px;
  border: 1px solid;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .02em;
}
.cp-vs-divider {
  font-size: 18px;
  font-weight: 700;
  color: rgba(255,255,255,.4);
}

.cp-hero-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  font-size: 12.5px;
  color: rgba(255,255,255,.4);
}
.cp-meta-dot { color: rgba(255,255,255,.22); }

/* Listing hero extras */
.cp-hero-listing .cp-hero-stats {
  display: flex;
  gap: 28px;
  flex-wrap: wrap;
  margin-top: 20px;
  padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,.1);
}
.cp-hero-stat strong {
  display: block;
  font-size: 20px;
  font-weight: 700;
  color: #ffffff;
  line-height: 1.1;
  margin-bottom: 3px;
}
.cp-hero-stat span { font-size: 12px; color: rgba(255,255,255,.45); }


/* ════════════════════════════════════════════════════════════
   2. PAGE LAYOUT
════════════════════════════════════════════════════════════ */
.cp-wrap { background: #f4f3f0; }

.cp-body {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 28px;
  align-items: start;
  padding: 28px 0 60px;
}
@media (max-width: 900px) {
  .cp-body { grid-template-columns: 1fr; }
  .cp-sidebar { order: -1; }
}
.cp-main  { min-width: 0; }
.cp-sidebar { min-width: 0; }


/* ════════════════════════════════════════════════════════════
   3. SECTION WRAPPERS
════════════════════════════════════════════════════════════ */
.cp-section {
  background: var(--cp-white);
  border: 1px solid var(--cp-border);
  border-radius: var(--cp-rl);
  padding: 24px 26px;
  margin-bottom: 20px;
}
.cp-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--cp-accent);
  margin-bottom: 8px;
}
.cp-section-title {
  font-size: 18px;
  font-weight: 700;
  color: var(--cp-text);
  margin-bottom: 10px;
  line-height: 1.35;
}
.cp-gold-line {
  width: 40px;
  height: 3px;
  background: var(--cp-accent);
  border-radius: 2px;
  margin-bottom: 18px;
}
.cp-intro {
  font-size: 15px;
  color: var(--cp-text-2);
  line-height: 1.78;
}


/* ════════════════════════════════════════════════════════════
   4. ITEM CARDS  (Option A / Option B summary)
════════════════════════════════════════════════════════════ */
.cp-cards-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
@media (max-width: 580px) {
  .cp-cards-grid { grid-template-columns: 1fr; }
}
.cp-item-card {
  background: var(--cp-gray-bg);
  border: 1px solid var(--cp-border);
  border-radius: var(--cp-rl);
  padding: 18px 18px 14px;
}
.cp-item-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  margin-bottom: 6px;
}
.cp-item-name {
  font-size: 17px;
  font-weight: 700;
  color: var(--cp-text);
  margin-bottom: 4px;
}
.cp-item-tagline {
  font-size: 13px;
  color: var(--cp-text-muted);
  margin-bottom: 12px;
  line-height: 1.5;
}
.cp-item-link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 13px;
  font-weight: 600;
  text-decoration: none !important;
  margin-bottom: 14px;
  transition: gap .15s;
}
.cp-item-link:hover { gap: 7px; }

.cp-item-profiles {
  border-top: 1px solid var(--cp-border);
  padding-top: 12px;
  margin-top: 4px;
}
.cp-profiles-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--cp-text-muted);
  margin-bottom: 8px;
}
.cp-profile-row {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 12.5px;
  color: var(--cp-text-2);
  line-height: 1.55;
  margin-bottom: 6px;
}
.cp-profile-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  margin-top: 5px;
  flex-shrink: 0;
}


/* ════════════════════════════════════════════════════════════
   5. COMPARISON TABLE
════════════════════════════════════════════════════════════ */
.cp-table-wrap { overflow-x: auto; margin-top: 4px; }

.cp-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13.5px;
}
.cp-table thead tr {
  background: var(--cp-navy);
}
.cp-table th {
  padding: 12px 14px;
  text-align: left;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .04em;
  color: rgba(255,255,255,.85);
  white-space: nowrap;
}
.cp-th-criteria { width: 32%; }
.cp-th-a, .cp-th-b { width: 26%; }
.cp-th-winner   { width: 16%; }

.cp-tr { border-bottom: 1px solid var(--cp-border); }
.cp-tr-even { background: var(--cp-gray-bg); }
.cp-tr:last-child { border-bottom: none; }

.cp-td-criteria {
  padding: 12px 14px;
  font-weight: 600;
  color: var(--cp-text);
  vertical-align: top;
}
.cp-criteria-icon {
  margin-right: 5px;
  font-size: 14px;
}
.cp-criteria-note {
  font-size: 11.5px;
  color: var(--cp-text-muted);
  font-weight: 400;
  margin-top: 4px;
  line-height: 1.45;
}

.cp-td-val {
  padding: 12px 14px;
  color: var(--cp-text-2);
  vertical-align: top;
  line-height: 1.5;
}
.cp-td-win {
  background: rgba(29,158,117,.07);
  font-weight: 600;
  color: var(--cp-text);
}

.cp-td-winner {
  padding: 12px 14px;
  vertical-align: middle;
}
.cp-winner-badge {
  display: inline-block;
  font-size: 11.5px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 10px;
  white-space: nowrap;
}
.cp-winner-both {
  background: rgba(29,158,117,.15);
  color: #085041;
}
.cp-winner-neutral {
  color: var(--cp-text-muted);
  font-size: 16px;
}


/* ════════════════════════════════════════════════════════════
   6. VERDICT BOX
════════════════════════════════════════════════════════════ */
.cp-verdict-box {
  background: var(--cp-navy);
  border-radius: var(--cp-rl);
  padding: 22px 24px;
  margin-top: 4px;
}
.cp-verdict-winner-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}
.cp-verdict-icon { font-size: 20px; }
.cp-verdict-winner-label {
  font-size: 15px;
  color: rgba(255,255,255,.7);
}
.cp-verdict-winner-label strong {
  color: var(--cp-accent);
  font-size: 16px;
}
.cp-verdict-body {
  font-size: 14px;
  color: rgba(255,255,255,.65);
  line-height: 1.75;
}
.cp-verdict-body strong { color: #ffffff; }


/* ════════════════════════════════════════════════════════════
   7. FAQ ACCORDION
════════════════════════════════════════════════════════════ */
.cp-faq-list { display: flex; flex-direction: column; gap: 8px; }

.cp-faq-item {
  border: 1px solid var(--cp-border);
  border-radius: var(--cp-r);
  overflow: hidden;
}
.cp-faq-q {
  width: 100%;
  background: var(--cp-gray-bg);
  border: none;
  padding: 13px 18px;
  text-align: left;
  font-family: inherit;
  font-size: 14px;
  font-weight: 600;
  color: var(--cp-text);
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  transition: background .15s;
  line-height: 1.4;
}
.cp-faq-q:hover    { background: #eeecea; }
.cp-faq-item.open .cp-faq-q { background: var(--cp-navy); color: #ffffff; }
.cp-faq-chev {
  font-size: 11px;
  transition: transform .25s;
  flex-shrink: 0;
}
.cp-faq-item.open .cp-faq-chev { transform: rotate(180deg); }
.cp-faq-a {
  display: none;
  padding: 13px 18px;
  font-size: 13.5px;
  color: var(--cp-text-2);
  line-height: 1.75;
  border-top: 1px solid var(--cp-border);
  background: var(--cp-white);
}
.cp-faq-item.open .cp-faq-a { display: block; }


/* ════════════════════════════════════════════════════════════
   8. CTA BLOCK
════════════════════════════════════════════════════════════ */
.cp-cta-block {
  background: var(--cp-navy);
  border-radius: var(--cp-rl);
  padding: 26px 24px;
  margin-bottom: 20px;
  text-align: center;
}
.cp-cta-block h3 {
  font-size: 20px;
  font-weight: 700;
  color: #ffffff;
  margin-bottom: 8px;
}
.cp-cta-block p {
  font-size: 13.5px;
  color: rgba(255,255,255,.55);
  margin-bottom: 18px;
}
.cp-cta-links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
}
.cp-cta-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 9px 18px;
  background: var(--cp-accent);
  color: #ffffff !important;
  text-decoration: none !important;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 600;
  transition: opacity .2s;
}
.cp-cta-btn:hover { opacity: .88; }
.cp-cta-btn.outline {
  background: transparent;
  border: 1px solid rgba(255,255,255,.28);
  color: rgba(255,255,255,.8) !important;
}
.cp-cta-btn.outline:hover {
  border-color: rgba(255,255,255,.55);
  color: #ffffff !important;
}


/* ════════════════════════════════════════════════════════════
   9. SIDEBAR
════════════════════════════════════════════════════════════ */
.cp-sidebar-card {
  background: var(--cp-white);
  border: 1px solid var(--cp-border);
  border-radius: var(--cp-rl);
  padding: 16px 18px;
  margin-bottom: 18px;
}
.cp-sidebar-card h4 {
  font-size: 14px;
  font-weight: 700;
  color: var(--cp-text);
  margin-bottom: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--cp-border);
}

/* Quick verdict sidebar */
.cp-verdict-card { border-top: 3px solid var(--cp-accent); }
.cp-quick-verdict { display: flex; flex-direction: column; gap: 8px; }
.cp-qv-row {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 13px;
  color: var(--cp-text-2);
  line-height: 1.45;
}
.cp-qv-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-top: 4px;
  flex-shrink: 0;
}
.cp-qv-vs {
  font-size: 12px;
  font-weight: 700;
  color: var(--cp-text-muted);
  text-align: center;
  padding: 2px 0;
}
.cp-qv-result {
  font-size: 12.5px;
  color: var(--cp-text-muted);
  padding-top: 10px;
  border-top: 1px solid var(--cp-border);
}
.cp-qv-result strong { color: var(--cp-accent); }

/* Related + all list */
.cp-related-list,
.cp-all-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.cp-related-list li a,
.cp-all-list li a {
  display: block;
  padding: 7px 0;
  border-bottom: 1px solid var(--cp-border);
  font-size: 13px;
  color: var(--cp-text-2) !important;
  text-decoration: none !important;
  transition: color .15s;
  line-height: 1.4;
}
.cp-related-list li:last-child a,
.cp-all-list li:last-child a { border-bottom: none; }
.cp-related-list li a:hover,
.cp-all-list li a:hover { color: var(--cp-navy) !important; }
.cp-all-list li a.cp-active { color: var(--cp-accent) !important; font-weight: 600; }

/* CTA sidebar card */
.cp-cta-card {
  background: var(--cp-navy);
  border-radius: var(--cp-rl);
  padding: 18px;
  margin-bottom: 18px;
}
.cp-cta-card h4 {
  font-size: 15px;
  font-weight: 600;
  color: #ffffff;
  margin-bottom: 8px;
}
.cp-cta-card p {
  font-size: 12.5px;
  color: rgba(255,255,255,.55);
  margin-bottom: 14px;
  line-height: 1.55;
}
.cp-wa-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 9px 16px;
  background: #25d366;
  color: #ffffff !important;
  text-decoration: none !important;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 600;
  margin-bottom: 8px;
  transition: opacity .2s;
}
.cp-wa-btn:hover { opacity: .88; }


/* ════════════════════════════════════════════════════════════
   10. LISTING PAGE
════════════════════════════════════════════════════════════ */

/* Filter bar */
.cp-filter-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.cp-filter-label {
  font-size: 13px;
  font-weight: 500;
  color: var(--cp-text-muted);
  flex-shrink: 0;
}
.cp-filter-btn {
  padding: 6px 16px;
  font-size: 13px;
  font-family: inherit;
  font-weight: 500;
  border: 1px solid var(--cp-border);
  border-radius: 20px;
  background: var(--cp-white);
  color: var(--cp-text-2);
  cursor: pointer;
  transition: all .15s;
}
.cp-filter-btn:hover { border-color: var(--cp-accent); color: var(--cp-accent); }
.cp-filter-btn.active { background: var(--cp-navy); color: #ffffff; border-color: var(--cp-navy); }

/* Cards grid */
.cp-listing-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin-bottom: 20px;
}
@media (max-width: 640px) {
  .cp-listing-grid { grid-template-columns: 1fr; }
}

.cp-listing-card {
  background: var(--cp-white);
  border: 1px solid var(--cp-border);
  border-radius: var(--cp-rl);
  overflow: hidden;
  text-decoration: none !important;
  display: flex;
  flex-direction: column;
  transition: box-shadow .2s, border-color .2s;
}
.cp-listing-card:hover {
  box-shadow: 0 4px 18px rgba(0,0,0,.09);
  border-color: var(--cp-accent);
}

/* Category top-bar colours */
.cp-listing-card-bar { height: 3px; flex-shrink: 0; }
.cp-bar-fabric   { background: var(--cp-teal);   }
.cp-bar-category { background: var(--cp-blue);   }
.cp-bar-occasion { background: var(--cp-purple); }
.cp-bar-business { background: var(--cp-amber);  }

.cp-listing-card-body {
  padding: 20px 20px 14px;
  flex: 1;
}
.cp-listing-eyebrow {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  margin-bottom: 10px;
}
.cp-ey-fabric   { color: var(--cp-teal);   }
.cp-ey-category { color: var(--cp-blue);   }
.cp-ey-occasion { color: var(--cp-purple); }
.cp-ey-business { color: var(--cp-amber);  }

/* A vs B names inside listing card */
.cp-listing-versus {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.cp-lv-a, .cp-lv-b {
  font-size: 15px;
  font-weight: 700;
}
.cp-lv-vs {
  font-size: 12px;
  font-weight: 700;
  color: var(--cp-text-muted);
}

.cp-listing-card-body h3 {
  font-size: 14px;
  font-weight: 600;
  color: var(--cp-text);
  line-height: 1.4;
  margin-bottom: 7px;
}
.cp-listing-card-body p {
  font-size: 13px;
  color: var(--cp-text-2);
  line-height: 1.6;
}

.cp-listing-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 20px 14px;
  border-top: 1px solid var(--cp-border);
  flex-wrap: wrap;
  gap: 8px;
}
.cp-read-link {
  font-size: 13px;
  font-weight: 600;
  color: var(--cp-navy) !important;
  text-decoration: none !important;
  transition: color .15s;
}
.cp-listing-card:hover .cp-read-link { color: var(--cp-accent) !important; }

/* Category tags */
.cp-cat-tag {
  font-size: 11px;
  font-weight: 600;
  padding: 2px 9px;
  border-radius: 10px;
}
.cp-cat-fabric   { background: var(--cp-teal-lt);   color: #085041; }
.cp-cat-category { background: var(--cp-blue-lt);   color: #0c447c; }
.cp-cat-occasion { background: var(--cp-purple-lt); color: #3c3489; }
.cp-cat-business { background: var(--cp-amber-lt);  color: #633806; }

/* Empty state */
.cp-empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: 40px 20px;
  font-size: 14px;
  color: var(--cp-text-muted);
  background: var(--cp-white);
  border: 1px solid var(--cp-border);
  border-radius: var(--cp-rl);
}

/* ════════════════════════════════════════════════════════════
   11. RESPONSIVE
════════════════════════════════════════════════════════════ */
@media (max-width: 480px) {
  .cp-hero h1          { font-size: 22px; }
  .cp-hero-sub         { font-size: 14px; }
  .cp-section          { padding: 18px 16px; }
  .cp-section-title    { font-size: 16px; }
  .cp-verdict-box      { padding: 18px 16px; }
  .cp-cta-block        { padding: 20px 16px; }
  .cp-cta-links        { flex-direction: column; }
  .cp-cta-btn          { justify-content: center; }
  .cp-table th, .cp-td-criteria,
  .cp-td-val, .cp-td-winner { padding: 9px 10px; font-size: 12.5px; }
}
