/* ==========================================================
   JBD BRAND PALETTE (official)
   Primary: #364f56 dark  |  #f35338 orange
   Surface: #fafaf6 off-white
   Muted:   #9ba59f sage
   ========================================================== */
:root {
  /* Brand core */
  --jbd-dark:      #364f56;
  --jbd-orange:    #f35338;
  --jbd-offwhite:  #fafaf6;
  --jbd-sage:      #9ba59f;

  /* Derived tokens for UI (palette-consistent, WCAG compliant) */
  --jbd-text:      #364f56;
  --jbd-muted:     #6a7a7f;   /* darker sage for accessible body muted */
  --jbd-border:    #e4e7e2;   /* sage-tinted light border */
  --jbd-surface-2: #f1f2ee;   /* slightly deeper surface than offwhite */
  --jbd-sage-soft: #eef0ec;   /* lightest sage tint for backgrounds */
  --jbd-orange-soft: #fde8e1; /* lightest orange tint for backgrounds */

  /* Aliases for backwards compatibility */
  --jbd-navy:      var(--jbd-dark);
  --jbd-teal:      var(--jbd-dark);
  --jbd-blue:      var(--jbd-dark);
  --jbd-cream:     var(--jbd-offwhite);
  --jbd-burnt:     var(--jbd-orange);
  --jbd-lightblue: var(--jbd-sage);
  --jbd-win:       var(--jbd-sage);
  --jbd-watch:     var(--jbd-orange);
}

/* ==========================================================
   BLOG MODULES
   Intended to match the existing JBD theme classes:
     .block-wrapper, .block-text, .callout, .service-link-card,
     .checklist-group, .has-cnumlist, .sec-row, .ea-card
   The styles below re-create the look in a theme-agnostic way
   so the HTML renders correctly when pasted into a Custom HTML
   block in WordPress. If your theme already styles these
   classes, the theme rules will win.
   ========================================================== */

/* 01. QUICK TAKE (top of post) */
.jbd-quicktake { background: var(--jbd-cream); border-left: 5px solid var(--jbd-orange); padding: 26px 30px; border-radius: 6px; margin: 0 0 32px; }
.jbd-quicktake .eyebrow, 
.jbd-quicktake .eyebrow p{ font-family: 'Montserrat', sans-serif; font-weight: 700; letter-spacing: 2px; font-size: 12px; text-transform: uppercase; color: var(--jbd-orange); margin-bottom: 6px;margin-top:0; }
.jbd-quicktake h2 { font-family: 'Montserrat', sans-serif; font-size: 22px; margin: 0 0 12px; color: var(--jbd-navy); }
.jbd-quicktake p { margin: 0 0 10px; font-size: 17px; color: var(--jbd-text); }
.jbd-quicktake p:last-child { margin-bottom: 0; }

/* 02. NUMBERED FRAMEWORK BLOCK */
.jbd-framework { background: #fff; border: 1px solid var(--jbd-border); border-radius: 10px; padding: 28px 32px; margin: 0 0 20px; position: relative; }
.jbd-framework .fw-num,
.jbd-framework .fw-num p{ font-family: 'Montserrat', sans-serif; font-weight: 800; font-size: 14px; letter-spacing: 3px; color: var(--jbd-orange); text-transform: uppercase; }
.jbd-framework h3 { font-family: 'Montserrat', sans-serif; font-size: 24px; color: var(--jbd-navy); margin: 4px 0 12px; }
.jbd-framework p { margin: 0; color: var(--jbd-text); font-size: 16px; }
.jbd-framework--filled { background: var(--jbd-dark); color: #fff; border-color: var(--jbd-dark); }
.jbd-framework--filled .fw-num { color: var(--jbd-orange); }
.jbd-framework--filled h3 { color: #fff; }
.jbd-framework--filled p { color: #d9dedc; }

/* 03. STAT HERO BAND */
.jbd-stathero { background: var(--jbd-dark); color: #fff; border-radius: 10px; padding: 40px 36px; display: grid; grid-template-columns: auto 1fr; gap: 32px; align-items: center; margin: 0 0 24px; }
.jbd-stathero .stat-num ,
.jbd-stathero .stat-num p{ font-family: 'Montserrat', sans-serif; font-weight: 800; font-size: 72px; line-height: 1; color: var(--jbd-orange); letter-spacing: -0.02em; }
.jbd-stathero .stat-label,
.jbd-stathero .stat-label p{ font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: 600; margin: 0 0 6px; }
.jbd-stathero .stat-source,
.jbd-stathero .stat-source p{ font-size: 13px; color: var(--jbd-sage); }
@media (max-width: 600px) { .jbd-stathero { grid-template-columns: 1fr; gap: 12px; text-align: center; } .jbd-stathero .stat-num , .jbd-stathero .stat-num p{ font-size: 56px; } }

/* 04. PULL QUOTE SIDEBAR */
.jbd-pullquote { border-left: 4px solid var(--jbd-orange); padding: 4px 0 4px 24px; margin: 24px 0; }
.jbd-pullquote blockquote, 
.jbd-pullquote blockquote p{ font-family: 'Montserrat', sans-serif; font-size: 22px; line-height: 1.35; font-weight: 500; color: var(--jbd-navy); margin: 0 0 10px; font-style: normal; }
.jbd-pullquote cite { font-style: normal; font-size: 13px; color: var(--jbd-muted); font-family: 'Inter', sans-serif; letter-spacing: 1px; text-transform: uppercase; }

/* 05. QUICK WIN CALLOUT */
.jbd-callout { display: grid; grid-template-columns: 44px 1fr; gap: 16px; padding: 20px 22px; border-radius: 8px; margin: 20px 0; align-items: start; }
.jbd-callout .cal-icon { width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: 'Montserrat', sans-serif; font-weight: 800; font-size: 18px; color: #fff; }
.jbd-callout h4 { font-family: 'Montserrat', sans-serif; margin: 0 0 4px; font-size: 16px; letter-spacing: 1px; text-transform: uppercase; }
.jbd-callout p { margin: 0; font-size: 15px; }
.jbd-callout--win { background: var(--jbd-sage-soft); border: 1px solid #d4dad2; }
.jbd-callout--win .cal-icon { background: var(--jbd-sage); }
.jbd-callout--win h4 { color: var(--jbd-dark); }
.jbd-callout--watch { background: var(--jbd-orange-soft); border: 1px solid #f4b8a8; }
.jbd-callout--watch .cal-icon { background: var(--jbd-orange); }
.jbd-callout--watch h4 { color: var(--jbd-orange); }

/* 06. COMPARISON BLOCK */
.jbd-compare { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin: 24px 0; }
.jbd-compare .compare-col { padding: 24px; border-radius: 10px; }
.jbd-compare .col-old { background: var(--jbd-surface-2); border: 1px solid var(--jbd-border); }
.jbd-compare .col-new { background: var(--jbd-offwhite); border: 1px solid #f0d8cd; border-left: 4px solid var(--jbd-orange); }
.jbd-compare h4 { font-family: 'Montserrat', sans-serif; font-size: 12px; letter-spacing: 2px; text-transform: uppercase; margin: 0 0 10px; }
.jbd-compare .col-old h4 { color: var(--jbd-muted); }
.jbd-compare .col-new h4 { color: var(--jbd-orange); }
.jbd-compare h3 { font-family: 'Montserrat', sans-serif; font-size: 20px; color: var(--jbd-navy); margin: 0 0 10px; }
.jbd-compare ul { margin: 0; padding-left: 18px; font-size: 15px; }
.jbd-compare ul li { margin-bottom: 6px; }
@media (max-width: 640px) { .jbd-compare { grid-template-columns: 1fr; } }

/* 07. MINI CASE STUDY CARD */
.jbd-case { background: #fff; border: 1px solid var(--jbd-border); border-radius: 12px; overflow: hidden; display: grid; grid-template-columns: 200px 1fr; margin: 24px 0; }
.jbd-case .case-metric { background: var(--jbd-dark); color: #fff; padding: 28px 24px; display: flex; flex-direction: column; justify-content: center; }
.jbd-case .case-metric .num,
.jbd-case .case-metric .num p{ font-family: 'Montserrat', sans-serif; font-weight: 800; font-size: 44px; line-height: 1; color: var(--jbd-orange);margin:0; }
.jbd-case .case-metric .lbl,
.jbd-case .case-metric .lbl p{ font-family: 'Montserrat', sans-serif; font-size: 12px; letter-spacing: 1.5px; text-transform: uppercase; margin-top: 8px; margin-bottom:0;}
.jbd-case .case-body { padding: 22px 24px; }
.jbd-case .case-body h4 { font-family: 'Montserrat', sans-serif; margin: 0 0 4px; font-size: 17px; color: var(--jbd-navy); }
.jbd-case .case-body .case-meta,
.jbd-case .case-body .case-meta p{ font-size: 12px; letter-spacing: 1px; text-transform: uppercase; color: var(--jbd-muted); margin-bottom: 10px;margin-top:0; }
.jbd-case .case-body p { margin: 0 0 10px; font-size: 15px; }
.jbd-case .case-body cite { font-style: normal; font-size: 13px; color: var(--jbd-muted); }
@media (max-width: 620px) { .jbd-case { grid-template-columns: 1fr; } }

/* 08. PHASED ROADMAP */
.jbd-roadmap { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin: 24px 0; }
.jbd-roadmap .phase { background: #fff; border: 1px solid var(--jbd-border); border-top: 4px solid var(--jbd-orange); border-radius: 10px; padding: 22px; }
.jbd-roadmap .phase .phase-num,
.jbd-roadmap .phase .phase-num p{ font-family: 'Montserrat', sans-serif; font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--jbd-muted);margin:0; }
.jbd-roadmap .phase h4 { font-family: 'Montserrat', sans-serif; font-size: 18px; color: var(--jbd-navy); margin: 4px 0 10px; }
.jbd-roadmap .phase ul { margin: 0; padding-left: 18px; font-size: 14px; }
.jbd-roadmap .phase ul li { margin-bottom: 5px; }
@media (max-width: 760px) { .jbd-roadmap { grid-template-columns: 1fr; } }

/* 09. CHECKLIST MODULE */
.jbd-checklist { background: var(--jbd-offwhite); border: 1px solid var(--jbd-border); border-radius: 12px; padding: 26px 28px; margin: 24px 0; }
.jbd-checklist h3 { font-family: 'Montserrat', sans-serif; font-size: 20px; color: var(--jbd-navy); margin: 0 0 16px; }
.jbd-checklist ul { list-style: none; padding: 0; margin: 0; }
.jbd-checklist li { position: relative; padding: 8px 0 8px 32px; border-bottom: 1px solid var(--jbd-border); font-size: 15px; }
.jbd-checklist li:last-child { border-bottom: none; }
.jbd-checklist li::before { content: ""; position: absolute; left: 0; top: 12px; width: 18px; height: 18px; border: 2px solid var(--jbd-teal); border-radius: 4px; background: #fff; }
.jbd-checklist li.done::before { background: var(--jbd-teal); }
.jbd-checklist li.done::after { content: ""; position: absolute; left: 5px; top: 14px; width: 8px; height: 4px; border-left: 2px solid #fff; border-bottom: 2px solid #fff; transform: rotate(-45deg); }

/* 10. FAQ ACCORDION (static, plugin-ready markup) */
.jbd-faq { margin: 24px 0; }
.jbd-faq details { background: #fff; border: 1px solid var(--jbd-border); border-radius: 8px; padding: 14px 20px; margin-bottom: 10px; }
.jbd-faq details[open] { border-color: var(--jbd-orange); }
.jbd-faq summary { font-family: 'Montserrat', sans-serif; font-size: 16px; font-weight: 600; color: var(--jbd-navy); cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center;outline:0; }
.jbd-faq summary::after { content: "+"; font-size: 22px; color: var(--jbd-orange); }
.jbd-faq details[open] summary::after { content: "–"; }
.jbd-faq details p { margin: 10px 0 4px; font-size: 15px; color: var(--jbd-text); }

/* 11. RELATED ARTICLES GRID */
.jbd-related { margin: 40px 0 0; }
.jbd-related h3 { font-family: 'Montserrat', sans-serif; font-size: 20px; color: var(--jbd-navy); margin: 0 0 16px; }
.jbd-related .related-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.jbd-related .rel-card { background: #fff; border: 1px solid var(--jbd-border); border-radius: 10px; padding: 20px; text-decoration: none; color: inherit; transition: transform .15s ease, border-color .15s ease; display: block; }
.jbd-related .rel-card:hover { transform: translateY(-2px); border-color: var(--jbd-orange); }
.jbd-related .rel-tag, 
.jbd-related .rel-tag p{ font-family: 'Montserrat', sans-serif; font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--jbd-orange);margin:0; }
.jbd-related .rel-card h4 { font-family: 'Montserrat', sans-serif; font-size: 16px; color: var(--jbd-navy); margin: 6px 0 4px; line-height: 1.3; }
.jbd-related .rel-card p { margin: 0; font-size: 13px; color: var(--jbd-muted); }
@media (max-width: 780px) { .jbd-related .related-grid { grid-template-columns: 1fr; } }

/* 12. NEXT STEP / CTA BLOCK */
.jbd-cta { background: var(--jbd-dark); color: #fff; border-radius: 12px; padding: 36px 32px; text-align: center; margin: 40px 0 0; }
.jbd-cta h3 { font-family: 'Montserrat', sans-serif; font-size: 26px; margin: 0 0 8px; color: #fff; }
.jbd-cta p { margin: 0 0 20px; color: #d9dedc; font-size: 16px; }
.jbd-cta a.jbd-btn { display: inline-block; background: var(--jbd-orange); color: #fff; text-decoration: none; padding: 14px 28px; border-radius: 6px; font-family: 'Montserrat', sans-serif; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; font-size: 14px; transition: background .15s ease; }
.jbd-cta a.jbd-btn:hover { background: var(--jbd-burnt); }

.trust-strip {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2rem;
  padding: 0.75rem 1rem;
  background: #f9fafb;
  border-top: 1px solid #e5e7eb;
  border-bottom: 1px solid #e5e7eb;
  font-size: 0.875rem;
  text-align: center;
}

.trust-value {
  font-weight: 600;
  color: #111827;
}

.trust-label {
  color: #6b7280;
}
