/* ============================================================
   BizProMedia — Client Resource Pages
   Enqueued by includes/client-resources.php only on
   client_resource archive and single pages.

   CSS custom properties (--bpm-*) are defined in the
   Kadence child theme's style.css and are available globally.
   ============================================================ */

/* Guide page hero — condensed light header */
.bpm-guide-hero { background: var(--bpm-neutral); position: relative; padding: 56px 0 52px; }
.bpm-guide-hero::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: var(--bpm-blue); }

.bpm-guide-breadcrumb { font-family: "Public Sans", system-ui, sans-serif; font-size: .8rem; color: var(--bpm-muted); margin-bottom: 18px; }
.bpm-guide-breadcrumb a { color: var(--bpm-blue); text-decoration: none; font-weight: 600; }
.bpm-guide-breadcrumb a:hover { text-decoration: underline; }
.bpm-guide-breadcrumb .sep { margin: 0 8px; color: rgba(20,40,70,.3); }

.bpm-guide-hero-title { font-family: "Public Sans", system-ui, sans-serif; font-size: clamp(1.8rem, 3.5vw, 2.6rem); font-weight: 900; color: var(--bpm-ink); letter-spacing: -.03em; line-height: 1.05; margin: 12px 0 0; }
.bpm-guide-hero-lead { font-family: "Merriweather Sans", system-ui, sans-serif; font-size: 1.05rem; color: var(--bpm-muted); line-height: 1.7; margin: 16px 0 0; max-width: 56ch; }

/* Guide page body — neutral bg, white card */
.bpm-guide-body { background: var(--bpm-neutral); padding: 52px 0 80px; }
.bpm-guide-card { background: #fff; border-radius: var(--bpm-radius-lg); box-shadow: var(--bpm-shadow-sm); max-width: 740px; margin-inline: auto; padding: 52px 56px; }
@media (max-width: 640px) { .bpm-guide-card { padding: 32px 24px; } }

/* Guide content typography */
.bpm-guide-card h2 { font-family: "Public Sans", system-ui, sans-serif; font-size: clamp(1.3rem, 2.2vw, 1.75rem); font-weight: 900; color: var(--bpm-charcoal); letter-spacing: -.025em; margin-top: 48px; margin-bottom: 14px; line-height: 1.1; }
.bpm-guide-card h2:first-child { margin-top: 0; }
.bpm-guide-card h3 { font-family: "Public Sans", system-ui, sans-serif; font-size: 1.1rem; font-weight: 800; color: var(--bpm-charcoal); margin-top: 32px; margin-bottom: 10px; }
.bpm-guide-card p { font-family: "Merriweather Sans", system-ui, sans-serif; font-size: 1rem; color: var(--bpm-ink); line-height: 1.82; margin-bottom: 18px; }
.bpm-guide-card p:last-child { margin-bottom: 0; }
.bpm-guide-card strong { font-weight: 700; color: var(--bpm-charcoal); }
.bpm-guide-card ul, .bpm-guide-card ol { font-family: "Merriweather Sans", system-ui, sans-serif; font-size: 1rem; color: var(--bpm-ink); line-height: 1.82; padding-left: 1.5rem; margin-bottom: 18px; }
.bpm-guide-card li { margin-bottom: .5rem; }

/* Guide footer contact nudge */
.bpm-guide-contact { text-align: center; margin-top: 52px; padding-top: 28px; border-top: 1px solid rgba(20,40,70,.08); font-family: "Merriweather Sans", system-ui, sans-serif; font-size: .93rem; color: var(--bpm-muted); }
.bpm-guide-contact a { color: var(--bpm-blue); font-weight: 700; text-decoration: none; }
.bpm-guide-contact a:hover { text-decoration: underline; }

/* Callout boxes */
.bpm-callout { border-radius: var(--bpm-radius); padding: 18px 22px; margin: 28px 0; border-left: 4px solid; }
.bpm-callout-label { font-family: "Public Sans", system-ui, sans-serif; font-size: .72rem; font-weight: 800; text-transform: uppercase; letter-spacing: .12em; margin-bottom: 8px; display: block; }
.bpm-callout p { margin-bottom: 0 !important; font-size: .96rem; }
.bpm-callout--tip { background: rgba(79,168,61,.07); border-color: var(--bpm-green); }
.bpm-callout--tip .bpm-callout-label { color: var(--bpm-green-deep); }
.bpm-callout--info { background: rgba(23,78,140,.06); border-color: var(--bpm-blue); }
.bpm-callout--info .bpm-callout-label { color: var(--bpm-blue); }
.bpm-callout--important { background: rgba(198,61,47,.06); border-color: var(--bpm-red); }
.bpm-callout--important .bpm-callout-label { color: var(--bpm-red-deep); }

/* Guide step sequences (distinct from .bpm-steps — that's the homepage 4-col process grid) */
.bpm-guide-steps { display: flex; flex-direction: column; gap: 20px; margin: 28px 0; }
.bpm-guide-step { display: flex; gap: 18px; align-items: flex-start; }
.bpm-guide-step-num { width: 34px; height: 34px; border-radius: 50%; background: var(--bpm-blue); color: #fff; font-family: "Public Sans", system-ui, sans-serif; font-weight: 900; font-size: .9rem; display: grid; place-items: center; flex: none; margin-top: 2px; }
.bpm-guide-step-body { flex: 1; }
.bpm-guide-step-body h4 { font-family: "Public Sans", system-ui, sans-serif; font-weight: 800; font-size: 1rem; color: var(--bpm-charcoal); margin: 0 0 6px; }
.bpm-guide-step-body p { font-family: "Merriweather Sans", system-ui, sans-serif; font-size: .95rem; color: var(--bpm-muted); line-height: 1.7; margin: 0; }

/* Archive/hub page */
.bpm-resource-hero { background: linear-gradient(160deg, #1a1d22, var(--bpm-charcoal) 55%, #202326); padding: 70px 0 60px; }
.bpm-resource-hero-title { font-family: "Public Sans", system-ui, sans-serif; font-size: clamp(1.8rem, 3.5vw, 2.6rem); font-weight: 900; color: #fff; letter-spacing: -.03em; line-height: 1.05; margin: 12px 0 0; }
.bpm-resource-hero-lead { font-family: "Merriweather Sans", system-ui, sans-serif; font-size: 1.05rem; color: rgba(255,255,255,.72); line-height: 1.7; margin: 16px 0 0; max-width: 52ch; }
.bpm-resource-body { background: var(--bpm-neutral); padding: 64px 0 90px; }
.bpm-resource-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 22px; margin-top: 40px; }
.bpm-resource-card { background: #fff; border-radius: var(--bpm-radius); padding: 28px 28px 24px; border: 1px solid rgba(20,40,70,.07); box-shadow: var(--bpm-shadow-sm); display: flex; flex-direction: column; gap: 10px; text-decoration: none; color: inherit; transition: transform .25s var(--bpm-ease), box-shadow .25s var(--bpm-ease); }
.bpm-resource-card:hover { transform: translateY(-4px); box-shadow: var(--bpm-shadow-md); }
.bpm-resource-card-title { font-family: "Public Sans", system-ui, sans-serif; font-weight: 800; font-size: 1.05rem; color: var(--bpm-charcoal); letter-spacing: -.015em; margin: 0; transition: color .2s; }
.bpm-resource-card:hover .bpm-resource-card-title { color: var(--bpm-blue); }
.bpm-resource-card-excerpt { font-family: "Merriweather Sans", system-ui, sans-serif; font-size: .9rem; color: var(--bpm-muted); line-height: 1.65; margin: 0; flex: 1; }
.bpm-resource-card-link { font-family: "Public Sans", system-ui, sans-serif; font-weight: 700; font-size: .85rem; color: var(--bpm-blue); margin-top: 4px; }

/* Option cards — "pick one of these" lists (storage providers, tool choices, etc.) */
.bpm-guide-options { display: flex; flex-direction: column; gap: 12px; margin: 28px 0; }
.bpm-guide-option { display: flex; gap: 18px; align-items: flex-start; background: var(--bpm-neutral); border-radius: var(--bpm-radius); padding: 20px 22px; border: 1px solid rgba(20,40,70,.07); }
.bpm-guide-option-icon { width: 44px; height: 44px; border-radius: 12px; background: var(--opt-color, var(--bpm-blue)); display: grid; place-items: center; flex: none; color: #fff; }
.bpm-guide-option-icon svg { width: 22px; height: 22px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.bpm-guide-option-body { flex: 1; }
.bpm-guide-option-body h4 { font-family: "Public Sans", system-ui, sans-serif; font-weight: 800; font-size: 1rem; color: var(--bpm-charcoal); margin: 0 0 6px; }
.bpm-guide-option-body p { font-family: "Merriweather Sans", system-ui, sans-serif; font-size: .92rem; color: var(--bpm-muted); line-height: 1.65; margin: 0; }

/* Coming soon cards — no hover lift, muted indicator dot */
.bpm-resource-card--soon { cursor: default; }
.bpm-resource-card--soon:hover { transform: none; box-shadow: var(--bpm-shadow-sm); }
.bpm-resource-card-soon { font-family: "Public Sans", system-ui, sans-serif; font-weight: 700; font-size: .82rem; color: var(--bpm-muted); letter-spacing: .04em; margin-top: 4px; display: inline-flex; align-items: center; gap: 6px; }
.bpm-resource-card-soon::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--bpm-gray); display: inline-block; }
