/**
 * Regenerate Cascadia - Infohub
 * Modular CSS partial from rc-template-styles.css
 * Version: v1.1-s164
 * Date: 2026-04-14
 * Generated by Claude (S164)
 *
 * Sections: 52 (SINGLE OPPORTUNITY + RESOURCE TEMPLATES), 53 (INFO HUB (MEDIA CENTER HUB))
 */

/* =============================================
   SECTION 52: SINGLE OPPORTUNITY + RESOURCE TEMPLATES
   Version: v1.0
   Date: March 28, 2026
   Generated by Claude (S123)

   Extracted from inline <style> blocks in
   single-rc_opportunity.php and single-rc_resource.php.
   Phase 7 alignment: static CSS in stylesheet.
   ============================================= */

/* --- Shared Layout (both CPTs) --- */
.rc-opp-single,
.rc-res-single { max-width: 1120px; margin: 0 auto; padding: 32px 20px 60px; font-family: 'Jost', sans-serif; }
.rc-opp-single-layout,
.rc-res-single-layout { display: grid; grid-template-columns: 1fr 320px; gap: 48px; align-items: start; }
@media (max-width: 860px) {
  .rc-opp-single-layout,
  .rc-res-single-layout { grid-template-columns: 1fr; gap: 32px; }
}

/* --- Shared Badge --- */
.rc-opp-single-badge,
.rc-res-single-badge { display: inline-block; padding: 4px 14px; border-radius: 4px; color: #fff; font-size: 12px; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; margin-bottom: 12px; }
.rc-res-single-badge { display: inline-flex; align-items: center; gap: 6px; }
.rc-res-single-badge svg { opacity: 0.85; }

/* --- Shared Title --- */
.rc-opp-single-title,
.rc-res-single-title { font-family: 'Cormorant Garamond', serif; font-size: clamp(26px, 3.5vw, 38px); font-weight: 700; color: var(--rc-forest, #0F2318); line-height: 1.15; margin: 0 0 8px; }

/* --- Org / Source Line --- */
.rc-opp-single-org,
.rc-res-single-source { font-size: 17px; font-weight: 500; color: var(--rc-canopy, #2D6A4F); margin: 0 0 6px; }

/* --- Shared Meta Row --- */
.rc-opp-single-meta-row,
.rc-res-single-meta-row { display: flex; flex-wrap: wrap; gap: 16px; font-size: 14px; color: rgba(0,0,0,0.5); margin-bottom: 28px; }
.rc-opp-single-meta-item,
.rc-res-single-meta-item { display: flex; align-items: center; gap: 5px; }
.rc-opp-single-meta-item svg,
.rc-res-single-meta-item svg { width: 15px; height: 15px; flex-shrink: 0; opacity: 0.55; }

/* --- Video Embed (Resource) --- */
.rc-res-single-embed { position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden; border-radius: 10px; margin-bottom: 28px; background: #000; }
.rc-res-single-embed iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: 0; }

/* --- Shared Body --- */
.rc-opp-single-body h3,
.rc-res-single-body h3 { font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 700; color: var(--rc-forest, #0F2318); margin: 32px 0 12px; }
.rc-opp-single-body h3:first-child,
.rc-res-single-body h3:first-child { margin-top: 0; }
.rc-opp-single-desc,
.rc-res-single-desc { font-weight: 300; line-height: 1.75; color: #2D3A2E; }
.rc-opp-single-desc p,
.rc-res-single-desc p { margin: 0 0 14px; }

/* --- Shared Sidebar --- */
.rc-opp-single-sidebar,
.rc-res-single-sidebar { position: sticky; top: 100px; }
.rc-opp-single-card,
.rc-res-single-card { background: #fff; border: 1px solid rgba(0,0,0,0.08); border-radius: 10px; padding: 28px 24px; box-shadow: 0 2px 8px rgba(0,0,0,0.04); }
.rc-opp-single-thumb,
.rc-res-single-thumb { width: 100%; border-radius: 8px; margin-bottom: 20px; }

/* --- Shared CTA Button --- */
.rc-opp-single-apply,
.rc-res-single-cta { display: block; width: 100%; padding: 14px 20px; background: var(--rc-forest, #0F2318); color: #fff; text-align: center; text-decoration: none; border-radius: 6px; font-family: 'Jost', sans-serif; font-size: 15px; font-weight: 600; letter-spacing: 0.02em; transition: background 0.2s; margin-bottom: 20px; border: none; cursor: pointer; }
.rc-opp-single-apply:hover,
.rc-res-single-cta:hover { background: var(--rc-canopy, #2D6A4F); color: #fff; }

/* --- Shared DL Metadata --- */
.rc-opp-single-dl,
.rc-res-single-dl { margin: 0; }
.rc-opp-single-dl dt,
.rc-res-single-dl dt { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; color: rgba(0,0,0,0.4); margin: 16px 0 4px; }
.rc-opp-single-dl dt:first-child,
.rc-res-single-dl dt:first-child { margin-top: 0; }
.rc-opp-single-dl dd,
.rc-res-single-dl dd { margin: 0; font-size: 14px; font-weight: 400; color: #2D3A2E; line-height: 1.5; }

/* --- Shared Landscape Tag --- */
.rc-opp-single-landscape-tag,
.rc-res-single-landscape-tag { display: inline-block; background: var(--rc-cream, #FAF6EE); border: 1px solid rgba(0,0,0,0.08); padding: 3px 10px; border-radius: 4px; font-size: 13px; color: var(--rc-forest, #0F2318); }

/* --- Shared Posted Info --- */
.rc-opp-single-posted,
.rc-res-single-posted { font-size: 12px; color: rgba(0,0,0,0.35); margin-top: 20px; padding-top: 16px; border-top: 1px solid rgba(0,0,0,0.06); }

/* --- Opportunity: Deadline Colors --- */
.rc-opp-single-deadline--urgent { color: #B33A3A; font-weight: 600; }
.rc-opp-single-deadline--soon { color: #B8860B; font-weight: 500; }
.rc-opp-single-deadline--closed { color: #999; font-style: italic; }

/* --- Opportunity: Email Link --- */
.rc-opp-single-email-link { color: var(--rc-canopy, #2D6A4F); text-decoration: none; }
.rc-opp-single-email-link:hover { text-decoration: underline; }

/* --- Resource: URL Display --- */
.rc-res-single-url { font-size: 12px; color: rgba(0,0,0,0.3); word-break: break-all; margin-top: 8px; }
.rc-res-single-url a { color: var(--rc-canopy, #2D6A4F); text-decoration: none; }
.rc-res-single-url a:hover { text-decoration: underline; }

/* --- Shared Prev/Next Navigation --- */
.rc-cpt-nav { display: grid; grid-template-columns: 1fr 1fr; gap: 2px; margin-top: 36px; }
.rc-cpt-nav a { display: block; background: var(--rc-cream); padding: 24px 28px; text-decoration: none; transition: background 0.2s; }
.rc-cpt-nav a:hover { background: var(--rc-fog); }
.rc-cpt-nav .rc-nav-label { font-family: 'Inconsolata', monospace; font-size: 9px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--rc-fern); display: block; margin-bottom: 6px; }
.rc-cpt-nav .rc-nav-title { font-family: 'Cormorant Garamond', serif; font-size: 18px; font-weight: 700; color: var(--rc-forest); line-height: 1.25; }
.rc-cpt-nav-next { text-align: right; }
@media (max-width: 900px) { .rc-cpt-nav { grid-template-columns: 1fr; } }

/* --- Resource Attachments (S127, extracted S128) --- */
.rc-res-single-attachments { margin-top: 32px; }
.rc-res-single-attachments h3 {
    font-family: 'Cormorant Garamond', serif; font-size: 20px; font-weight: 600;
    color: var(--rc-forest); margin: 0 0 12px 0;
}
.rc-res-att-list { display: flex; flex-direction: column; gap: 6px; }
.rc-res-att-item {
    display: flex; align-items: center; gap: 12px; padding: 12px 16px;
    background: var(--rc-fog); text-decoration: none;
    transition: background 0.15s, box-shadow 0.15s;
}
.rc-res-att-item:hover {
    background: var(--rc-warm-white);
    box-shadow: 0 1px 4px rgba(0,0,0,0.08);
}
.rc-res-att-icon { flex-shrink: 0; display: flex; align-items: center; }
.rc-res-att-info { flex: 1; display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.rc-res-att-name {
    font-family: 'Jost', sans-serif; font-size: 14px; font-weight: 400;
    color: var(--rc-forest); overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.rc-res-att-meta {
    font-family: 'Inconsolata', monospace; font-size: 11px; letter-spacing: 0.05em;
    color: rgba(0,0,0,0.35); text-transform: uppercase;
}
.rc-res-att-dl {
    flex-shrink: 0; color: var(--rc-canopy); opacity: 0.5;
    transition: opacity 0.15s;
}
.rc-res-att-item:hover .rc-res-att-dl { opacity: 1; }

/* --- Resource Linked Photos (S127, extracted S128) --- */
.rc-res-single-photos { margin-top: 32px; }
.rc-res-single-photos h3 {
    font-family: 'Cormorant Garamond', serif; font-size: 20px; font-weight: 600;
    color: var(--rc-forest); margin: 0 0 12px 0;
}
.rc-res-photo-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 8px;
}
.rc-res-photo-item {
    position: relative; aspect-ratio: 1; overflow: hidden; display: block;
    background: var(--rc-fog);
}
.rc-res-photo-item img {
    width: 100%; height: 100%; object-fit: cover; display: block;
    transition: transform 0.3s;
}
.rc-res-photo-item:hover img { transform: scale(1.05); }
.rc-res-photo-credit {
    position: absolute; bottom: 0; left: 0; right: 0; padding: 4px 8px;
    font-family: 'Inconsolata', monospace; font-size: 10px; color: white;
    background: rgba(0,0,0,0.55); white-space: nowrap; overflow: hidden;
    text-overflow: ellipsis; opacity: 0; transition: opacity 0.2s;
}
.rc-res-photo-item:hover .rc-res-photo-credit { opacity: 1; }

@media (max-width: 768px) {
    .rc-res-photo-grid { grid-template-columns: repeat(auto-fill, minmax(100px, 1fr)); }
}



/* =============================================
   SECTION 53: INFO HUB (MEDIA CENTER HUB)
   Version: v1.0
   Date: March 28, 2026
   Generated by Claude (S128)

   Extracted from inline <style> in parts/media-center-hub.php.
   Covers: feature slider, info bar with search, browse-by-type
   cards, editorial featured grid, three-stream rows with sidebar
   filters, contribute CTA, and responsive breakpoints.
   .rc-mch- prefix throughout (RC Media Center Hub).
   ============================================= */

/* Reset for full-width sections */
.rc-mch-full { width: 100vw; margin-left: calc(-50vw + 50%); position: relative; }
.rc-utility-page-wrap--full:has(.rc-mch-full:first-child) { padding-top: 0 !important; margin-top: 0 !important; }
.rc-utility-main--full:has(.rc-mch-full:first-child) { padding-top: 0 !important; }
.rc-mch-contained { max-width: 1100px; margin: 0 auto; padding: 0 24px; }

/* --- 53.1 Feature Slider --- */
.rc-mch-slider { position: relative; height: 420px; overflow: hidden; background: #0D2818; margin-top: 0; }
.rc-mch-slider-track { position: relative; width: 100%; height: 100%; }
.rc-mch-slide { position: absolute; inset: 0; opacity: 0; transition: opacity .6s ease; }
.rc-mch-slide.active { opacity: 1; z-index: 1; }
.rc-mch-slide-img { width: 100%; height: 100%; object-fit: cover; }
.rc-mch-slide-overlay { position: absolute; inset: 0; background: linear-gradient(0deg, rgba(0,0,0,.7) 0%, rgba(0,0,0,.15) 50%, rgba(0,0,0,.05) 100%); }
.rc-mch-slide-content { position: absolute; bottom: 0; left: 0; right: 0; padding: 40px 48px; z-index: 2; color: #fff; }
.rc-mch-slide-badge { display: inline-block; font-size: 11px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; padding: 4px 10px; border-radius: 4px; color: #fff; margin-bottom: 10px; }
.rc-mch-slide-title { font-family: 'Cormorant Garamond', serif; font-size: 30px; font-weight: 600; line-height: 1.25; margin: 0 0 6px; max-width: 680px; }
.rc-mch-slide-title a { color: #fff; text-decoration: none; }
.rc-mch-slide-title a:hover { text-decoration: underline; }
.rc-mch-slide-meta { font-size: 14px; opacity: .8; }
.rc-mch-slider-arrows { position: absolute; top: 50%; left: 0; right: 0; z-index: 3; display: flex; justify-content: space-between; padding: 0 16px; transform: translateY(-50%); pointer-events: none; }
.rc-mch-arrow { width: 44px; height: 44px; border-radius: 50%; background: rgba(255,255,255,.15); backdrop-filter: blur(4px); border: 1px solid rgba(255,255,255,.2); color: #fff; display: flex; align-items: center; justify-content: center; cursor: pointer; pointer-events: auto; transition: background .2s; font-size: 20px; }
.rc-mch-arrow:hover { background: rgba(255,255,255,.3); }
.rc-mch-slider-dots { position: absolute; bottom: 16px; left: 50%; transform: translateX(-50%); z-index: 3; display: flex; gap: 8px; }
.rc-mch-dot { width: 10px; height: 10px; border-radius: 50%; background: rgba(255,255,255,.35); border: none; cursor: pointer; transition: background .2s, transform .2s; }
.rc-mch-dot.active { background: #fff; transform: scale(1.2); }

/* --- 53.2 Info Bar --- */
.rc-mch-info { padding: 40px 0 32px; }
.rc-mch-info-inner { display: grid; grid-template-columns: 1fr auto; gap: 32px; align-items: start; }
.rc-mch-info-eyebrow { font-size: 12px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--rc-gold); margin-bottom: 4px; }
.rc-mch-info-title { font-family: 'Cormorant Garamond', serif; font-size: 32px; font-weight: 600; color: var(--rc-deep-forest); margin: 0 0 6px; line-height: 1.2; }
.rc-mch-info-desc { font-size: 15px; color: #666; margin: 0 0 16px; line-height: 1.5; }
.rc-mch-info-search { display: flex; gap: 8px; max-width: 480px; }
.rc-mch-info-search input[type="text"] { flex: 1; padding: 10px 14px; border: 1px solid #d0cec8; border-radius: 6px; font-size: 14px; background: #fff; }
.rc-mch-info-search input:focus { outline: none; border-color: var(--rc-fern); box-shadow: 0 0 0 3px rgba(77,139,99,.1); }
.rc-mch-info-search button { padding: 10px 20px; background: var(--rc-forest); color: #fff; border: none; border-radius: 6px; font-weight: 600; font-size: 14px; cursor: pointer; white-space: nowrap; }
.rc-mch-info-search button:hover { background: var(--rc-deep-forest); }
.rc-mch-info-actions { display: flex; flex-direction: column; gap: 8px; padding-top: 8px; }
.rc-mch-info-actions span { font-size: 11px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: #999; }
.rc-mch-info-act-btn { padding: 9px 18px; border-radius: 6px; font-size: 13px; font-weight: 600; text-decoration: none; text-align: center; display: block; transition: background .15s; }
.rc-mch-info-act-primary { background: var(--rc-forest); color: #fff; }
.rc-mch-info-act-primary:hover { background: var(--rc-deep-forest); }
.rc-mch-info-act-secondary { background: transparent; color: var(--rc-forest); border: 1px solid var(--rc-fern); }
.rc-mch-info-act-secondary:hover { background: var(--rc-fog); }

/* --- 53.3 Browse by Type --- */
.rc-mch-section { margin-bottom: 40px; }
.rc-mch-section-header { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 16px; border-bottom: 1px solid rgba(0,0,0,.08); padding-bottom: 8px; }
.rc-mch-section-header h3 { font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 600; color: var(--rc-deep-forest); margin: 0; }
.rc-mch-section-header a { font-size: 13px; color: var(--rc-forest); text-decoration: none; font-weight: 500; }
.rc-mch-section-header a:hover { text-decoration: underline; }
.rc-mch-types { display: flex; flex-wrap: wrap; gap: 10px; }
.rc-mch-type-card { display: inline-flex; align-items: center; gap: 8px; padding: 10px 16px; border-radius: 8px; text-decoration: none; font-size: 14px; font-weight: 500; color: #fff; transition: transform .15s, box-shadow .15s; }
.rc-mch-type-card:hover { transform: translateY(-1px); box-shadow: 0 4px 12px rgba(0,0,0,.12); }
.rc-mch-type-card svg { opacity: .85; }
.rc-mch-type-card .rc-mch-tc-count { font-size: 12px; opacity: .75; margin-left: 2px; }

/* --- 53.4 Featured Content Grid --- */
.rc-mch-feat-full { background: var(--rc-fog); padding: 40px 0; }
.rc-mch-feat-grid { display: grid; grid-template-columns: 1fr 1fr 280px; gap: 24px; }
.rc-mch-feat-large { position: relative; border-radius: 10px; overflow: hidden; min-height: 360px; }
.rc-mch-feat-large img { width: 100%; height: 100%; object-fit: cover; position: absolute; inset: 0; }
.rc-mch-feat-large-overlay { position: absolute; inset: 0; background: linear-gradient(0deg, rgba(0,0,0,.75) 0%, rgba(0,0,0,.1) 60%); }
.rc-mch-feat-large-body { position: absolute; bottom: 0; left: 0; right: 0; padding: 24px; color: #fff; z-index: 1; }
.rc-mch-feat-large-body .rc-mch-card-badge { margin-bottom: 8px; }
.rc-mch-feat-large-body .rc-mch-card-title { color: #fff; font-size: 22px; margin-bottom: 4px; }
.rc-mch-feat-large-body .rc-mch-card-meta { color: rgba(255,255,255,.8); }
.rc-mch-feat-large a { text-decoration: none; display: block; height: 100%; }
.rc-mch-feat-mid { display: flex; flex-direction: column; gap: 16px; }
.rc-mch-feat-mid-card { flex: 1; border-radius: 10px; overflow: hidden; background: #fff; display: flex; flex-direction: column; text-decoration: none; color: inherit; transition: box-shadow .15s; }
.rc-mch-feat-mid-card:hover { box-shadow: 0 6px 20px rgba(0,0,0,.08); }
.rc-mch-feat-mid-card img { width: 100%; height: 140px; object-fit: cover; }
.rc-mch-feat-mid-card .rc-mch-card-body { padding: 14px 16px; flex: 1; }
.rc-mch-feat-sidebar { display: flex; flex-direction: column; gap: 0; }
.rc-mch-feat-sidebar-label { font-size: 12px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--rc-forest); margin-bottom: 12px; padding-bottom: 8px; border-bottom: 2px solid var(--rc-gold); }
.rc-mch-feat-sb-item { display: flex; gap: 12px; padding: 12px 0; border-bottom: 1px solid rgba(0,0,0,.06); text-decoration: none; color: inherit; transition: background .1s; }
.rc-mch-feat-sb-item:hover { background: rgba(0,0,0,.02); }
.rc-mch-feat-sb-thumb { width: 72px; height: 56px; border-radius: 6px; overflow: hidden; flex-shrink: 0; background: #e8e4db; }
.rc-mch-feat-sb-thumb img { width: 100%; height: 100%; object-fit: cover; }
.rc-mch-feat-sb-info { flex: 1; min-width: 0; }
.rc-mch-feat-sb-title { font-family: 'Cormorant Garamond', serif; font-size: 15px; font-weight: 600; line-height: 1.3; color: var(--rc-deep-forest); margin: 0 0 3px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.rc-mch-feat-sb-meta { font-size: 11px; color: #999; }

/* --- 53.5 Three Stream Rows + Sidebar --- */
.rc-mch-streams { display: grid; grid-template-columns: 1fr 260px; gap: 40px; margin-bottom: 40px; padding-top: 16px; }
.rc-mch-streams-main { min-width: 0; }
.rc-mch-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)); gap: 20px; }
.rc-mch-streams-main .rc-mch-grid { display: flex; gap: 20px; overflow: hidden; }
.rc-mch-streams-main .rc-mch-card { flex: 1 1 0; min-width: 0; }
.rc-mch-card { display: flex; flex-direction: column; border: 1px solid rgba(0,0,0,.08); border-radius: 10px; overflow: hidden; text-decoration: none; color: inherit; transition: box-shadow .15s, transform .15s; background: #fff; }
.rc-mch-card:hover { box-shadow: 0 6px 20px rgba(0,0,0,.08); transform: translateY(-2px); }
.rc-mch-card-thumb { height: 140px; overflow: hidden; background: #f0ede5; }
.rc-mch-card-thumb img { width: 100%; height: 100%; object-fit: cover; }
.rc-mch-card-thumb-empty { height: 140px; background: linear-gradient(135deg, #e8e4db 0%, #d5d0c6 100%); display: flex; align-items: center; justify-content: center; }
.rc-mch-card-thumb-empty svg { width: 32px; height: 32px; opacity: .25; }
.rc-mch-card-body { padding: 14px 16px 16px; flex: 1; display: flex; flex-direction: column; }
.rc-mch-card-badge { display: inline-block; font-size: 11px; font-weight: 600; letter-spacing: .02em; padding: 3px 8px; border-radius: 4px; color: #fff; margin-bottom: 8px; align-self: flex-start; }
.rc-mch-card-title { font-family: 'Cormorant Garamond', serif; font-size: 17px; font-weight: 600; line-height: 1.3; margin: 0 0 6px; color: var(--rc-deep-forest); }
.rc-mch-card-meta { font-size: 12px; color: #888; margin-bottom: 6px; }
.rc-mch-card-excerpt { font-size: 13px; color: #666; line-height: 1.5; flex: 1; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.rc-mch-card-date { font-size: 12px; color: #aaa; margin-top: 8px; }
.rc-mch-card-empty { display: flex; align-items: center; justify-content: center; border: 2px dashed rgba(0,0,0,.1); border-radius: 10px; min-height: 200px; padding: 24px; text-align: center; }
.rc-mch-card-empty p { color: #999; font-size: 14px; margin: 0; }

/* Sidebar filters */
.rc-mch-sidebar { position: static; }
.rc-mch-sb-label { font-family: 'Cormorant Garamond', serif; font-size: 20px; font-weight: 600; color: var(--rc-deep-forest); margin: 0 0 20px; padding-bottom: 8px; border-bottom: 2px solid var(--rc-gold); }
.rc-mch-sb-group { margin-bottom: 20px; }
.rc-mch-sb-group label { display: block; font-size: 12px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: #888; margin-bottom: 6px; }
.rc-mch-sb-group select { width: 100%; padding: 9px 12px; border: 1px solid #d0cec8; border-radius: 6px; font-size: 14px; background: #fff; color: #333; appearance: auto; cursor: pointer; }
.rc-mch-sb-group select:focus { outline: none; border-color: var(--rc-fern); box-shadow: 0 0 0 3px rgba(77,139,99,.1); }
.rc-mch-sb-topics { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 16px; }
.rc-mch-sb-topic { display: inline-block; padding: 5px 12px; border: 1px solid rgba(0,0,0,.1); border-radius: 16px; font-size: 12px; color: var(--rc-forest); text-decoration: none; transition: background .15s; }
.rc-mch-sb-topic:hover { background: var(--rc-fog); border-color: var(--rc-fern); }

/* --- 53.6 Bottom CTA --- */
.rc-mch-cta { display: flex; gap: 16px; flex-wrap: wrap; padding: 28px 32px; background: var(--rc-fog); border-radius: 10px; margin-bottom: 40px; align-items: center; }
.rc-mch-cta-text { flex: 1; min-width: 200px; }
.rc-mch-cta-text h3 { font-family: 'Cormorant Garamond', serif; font-size: 20px; margin: 0 0 4px; color: var(--rc-deep-forest); }
.rc-mch-cta-text p { font-size: 14px; color: #666; margin: 0; }
.rc-mch-cta-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.rc-mch-cta-btn { padding: 10px 20px; border-radius: 6px; font-size: 14px; font-weight: 600; text-decoration: none; display: inline-block; }
.rc-mch-cta-btn-primary { background: var(--rc-forest); color: #fff; }
.rc-mch-cta-btn-secondary { background: transparent; color: var(--rc-forest); border: 1px solid var(--rc-fern); }

/* --- 53.7 Info Hub Responsive --- */
@media (max-width: 900px) {
    .rc-mch-slider { height: 320px; }
    .rc-mch-slide-content { padding: 24px; }
    .rc-mch-slide-title { font-size: 24px; }
    .rc-mch-info-inner { grid-template-columns: 1fr; }
    .rc-mch-info-actions { flex-direction: row; }
    .rc-mch-feat-grid { grid-template-columns: 1fr 1fr; }
    .rc-mch-feat-sidebar { display: none; }
    .rc-mch-streams { grid-template-columns: 1fr; }
    .rc-mch-streams-main .rc-mch-grid { flex-wrap: wrap; }
    .rc-mch-streams-main .rc-mch-card { flex: 0 0 100%; }
}
@media (max-width: 640px) {
    .rc-mch-slider { height: 280px; }
    .rc-mch-slide-title { font-size: 20px; }
    .rc-mch-slide-content { padding: 20px; }
    .rc-mch-feat-grid { grid-template-columns: 1fr; }
    .rc-mch-feat-large { min-height: 260px; }
    .rc-mch-grid { grid-template-columns: 1fr; }
    .rc-mch-info-search { flex-direction: column; }
    .rc-mch-info-actions { flex-direction: column; }
    .rc-mch-cta { flex-direction: column; text-align: center; }
}

/* --- 53.8 Info Hub Sidebar Layout --- */
.rc-infohub-layout { display: grid; grid-template-columns: 1fr 280px; gap: 40px; align-items: start; max-width: 1100px; margin: 0 auto; }
.rc-infohub-main { min-width: 0; }
.rc-infohub-sidebar { position: static; display: flex; flex-direction: column; gap: 16px; }

/* Filter card */
.rc-infohub-sb-filters { background: var(--rc-cream); padding: 24px; }
.rc-infohub-sb-title {
    font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 700;
    color: var(--rc-forest); margin: 0 0 16px; padding-bottom: 10px;
    border-bottom: 2px solid var(--rc-gold);
}
.rc-infohub-sb-filter-group { margin-bottom: 20px; }
.rc-infohub-sb-filter-group:last-child { margin-bottom: 0; }
.rc-infohub-sb-filter-group > label {
    display: block; font-family: 'Inconsolata', monospace; font-size: 10px; font-weight: 600;
    letter-spacing: .15em; text-transform: uppercase; color: rgba(0,0,0,0.45); margin-bottom: 8px;
}
.rc-infohub-sb-filter-group select {
    width: 100%; padding: 9px 12px; border: 1px solid rgba(0,0,0,0.12); border-radius: 4px;
    font-family: 'Jost', sans-serif; font-size: 14px; color: var(--rc-ink); background: #fff;
    appearance: auto; cursor: pointer;
}
.rc-infohub-sb-filter-group select:focus { outline: none; border-color: var(--rc-canopy); box-shadow: 0 0 0 3px rgba(45,106,79,0.08); }
.rc-infohub-sb-topics { display: flex; flex-wrap: wrap; gap: 6px; }
.rc-infohub-sb-topic {
    display: inline-block; padding: 5px 12px; border: 1px solid rgba(0,0,0,0.1);
    border-radius: 16px; font-family: 'Jost', sans-serif; font-size: 12px;
    color: var(--rc-forest); text-decoration: none; transition: background .15s, border-color .15s;
}
.rc-infohub-sb-topic:hover { background: var(--rc-fog); border-color: var(--rc-fern); }

/* Info Hub sidebar responsive */
@media (max-width: 900px) {
    .rc-infohub-layout { grid-template-columns: 1fr; }
    .rc-infohub-sidebar { position: static; }
}

/* Filter bar refinements (S129) */
.rc-opp-filter-row + .rc-opp-filter-row,
.rc-resource-filter-row + .rc-resource-filter-row { margin-top: 12px; }
.rc-opp-filter-row-secondary { align-items: center; }
.rc-opp-filter-row-secondary label {
  display: flex; align-items: center; gap: 8px;
  font-family: 'Jost', sans-serif; font-size: 13px; font-weight: 400;
  color: var(--rc-text); cursor: pointer;
}
.rc-opp-filter-row-secondary input[type="checkbox"] {
  width: 16px; height: 16px; accent-color: var(--rc-canopy); cursor: pointer;
  flex-shrink: 0;
}
.rc-btn.rc-btn-sm,
button.rc-btn.rc-btn-sm {
  font-family: 'Inconsolata', monospace; font-size: 11px; font-weight: 500;
  letter-spacing: .15em; text-transform: uppercase;
  background: var(--rc-forest); color: var(--rc-cream);
  border: 1px solid var(--rc-forest); padding: 8px 20px;
  cursor: pointer; transition: background .2s;
}
.rc-btn.rc-btn-sm:hover,
button.rc-btn.rc-btn-sm:hover { background: var(--rc-canopy); border-color: var(--rc-canopy); }
.rc-btn.rc-btn-outline {
  font-family: 'Inconsolata', monospace; font-size: 11px; font-weight: 500;
  letter-spacing: .15em; text-transform: uppercase;
  background: transparent; color: var(--rc-canopy);
  border: 1px solid rgba(45,106,79,.25); padding: 10px 24px;
  text-decoration: none; cursor: pointer; transition: all .2s;
}
.rc-btn.rc-btn-outline:hover { background: var(--rc-forest); color: var(--rc-cream); border-color: var(--rc-forest); }

/* Blog-style opportunity cards (S129) */
.rc-opp-card-image {
  position: relative; aspect-ratio: 16/10; overflow: hidden; background: var(--rc-cream);
}
.rc-opp-card-image img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform .3s;
}
.rc-opp-card:hover .rc-opp-card-image img { transform: scale(1.03); }
.rc-opp-card-image .rc-opp-type-badge {
  position: absolute; bottom: 10px; left: 10px; z-index: 2;
}
.rc-opp-card-image-placeholder {
  width: 100%; height: 100%; display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--rc-fog) 0%, var(--rc-cream) 100%);
  color: rgba(0,0,0,0.12);
}
.rc-opp-card-expired { opacity: .65; }
.rc-opp-date {
  font-family: 'Inconsolata', monospace; font-size: 11px; font-weight: 500;
  letter-spacing: .04em; color: rgba(0,0,0,0.35);
}

/* Override card grids inside Info Hub layout (narrower main column) */
/* =============================================
   SECTION 52B: RESOURCE + OPPORTUNITY DIRECTORY LISTINGS
   Version: v1.0
   Date: April 6, 2026
   Generated by Claude (S157)

   Filter bars, card grids, pagination, and empty states for
   /info/resources/ and /info/opportunities/ directory shortcodes.
   These styles were lost during the S147 CSS modularization and
   have been reconstructed from the PHP class structure.
   ============================================= */

/* --- Shared Directory Layout --- */
.rc-resource-directory,
.rc-opp-directory { padding: 0 0 40px; }

/* --- Shared Filter Bar --- */
.rc-resource-filters,
.rc-opp-filters { margin-bottom: 24px; }

.rc-resource-filter-row,
.rc-opp-filter-row { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }

.rc-resource-filter-row + .rc-resource-filter-row,
.rc-opp-filter-row + .rc-opp-filter-row { margin-top: 12px; }

.rc-resource-filter-field,
.rc-opp-filter-field { flex: 1 1 180px; min-width: 140px; }

.rc-resource-filter-field input[type="text"],
.rc-opp-filter-field input[type="text"] {
    width: 100%; padding: 9px 12px; border: 1px solid #d0cec8; border-radius: 4px;
    font-family: 'Jost', sans-serif; font-size: 14px; background: #fff; color: #333;
}
.rc-resource-filter-field input:focus,
.rc-opp-filter-field input:focus {
    outline: none; border-color: var(--rc-fern); box-shadow: 0 0 0 3px rgba(77,139,99,.1);
}

.rc-resource-filter-field select,
.rc-opp-filter-field select {
    width: 100%; padding: 9px 12px; border: 1px solid #d0cec8; border-radius: 4px;
    font-family: 'Jost', sans-serif; font-size: 14px; background: #fff; color: #333;
    appearance: auto; cursor: pointer;
}
.rc-resource-filter-field select:focus,
.rc-opp-filter-field select:focus {
    outline: none; border-color: var(--rc-fern); box-shadow: 0 0 0 3px rgba(77,139,99,.1);
}

.rc-resource-filter-actions,
.rc-opp-filter-actions { display: flex; align-items: center; gap: 12px; flex: 0 0 auto; }

.rc-resource-clear-link,
.rc-opp-clear-link {
    font-family: 'Jost', sans-serif; font-size: 13px; color: var(--rc-canopy, #2D6A4F);
    text-decoration: none;
}
.rc-resource-clear-link:hover,
.rc-opp-clear-link:hover { text-decoration: underline; }

/* --- Results Count --- */
.rc-resource-count,
.rc-opp-count {
    font-family: 'Jost', sans-serif; font-size: 14px; color: rgba(0,0,0,0.45);
    margin-bottom: 20px;
}

/* --- Resource Card Grid --- */
.rc-resource-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 24px;
}

.rc-resource-card {
    display: flex; flex-direction: column; border: 1px solid rgba(0,0,0,.08);
    border-radius: 10px; overflow: hidden; background: #fff;
    transition: box-shadow .15s, transform .15s;
}
.rc-resource-card:hover { box-shadow: 0 6px 20px rgba(0,0,0,.08); transform: translateY(-2px); }

.rc-resource-card-thumb { height: 160px; overflow: hidden; background: var(--rc-fog, #f0ede5); }
.rc-resource-card-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .3s; }
.rc-resource-card:hover .rc-resource-card-thumb img { transform: scale(1.03); }

.rc-resource-card-body { padding: 16px 18px 20px; flex: 1; display: flex; flex-direction: column; }

.rc-resource-type-badge {
    display: inline-block; font-size: 11px; font-weight: 600; letter-spacing: .02em;
    padding: 3px 10px; border-radius: 4px; color: #fff; margin-bottom: 10px; align-self: flex-start;
}

.rc-resource-card-title {
    font-family: 'Cormorant Garamond', serif; font-size: 18px; font-weight: 600;
    line-height: 1.3; margin: 0 0 6px; color: var(--rc-deep-forest, #0F2318);
}

.rc-resource-card-source {
    font-size: 13px; color: var(--rc-canopy, #2D6A4F); margin: 0 0 4px; font-weight: 500;
}

.rc-resource-card-date { font-size: 12px; color: rgba(0,0,0,0.35); margin: 0 0 8px; }

.rc-resource-card-desc {
    font-size: 13px; color: #666; line-height: 1.5; flex: 1;
    display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
}

.rc-resource-view-link {
    font-family: 'Jost', sans-serif; font-size: 13px; font-weight: 500;
    color: var(--rc-canopy, #2D6A4F); margin-top: 12px; display: block;
}

/* --- Opportunity Card Grid --- */
.rc-opp-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 24px;
}

.rc-opp-card {
    display: flex; flex-direction: column; border: 1px solid rgba(0,0,0,.08);
    border-radius: 10px; overflow: hidden; background: #fff;
    transition: box-shadow .15s, transform .15s;
}
.rc-opp-card:hover { box-shadow: 0 6px 20px rgba(0,0,0,.08); transform: translateY(-2px); }

.rc-opp-type-badge {
    display: inline-block; font-size: 11px; font-weight: 600; letter-spacing: .02em;
    padding: 3px 10px; border-radius: 4px; color: #fff; position: relative; z-index: 2;
}

.rc-opp-card-body { padding: 16px 18px; flex: 1; display: flex; flex-direction: column; }

.rc-opp-card-title {
    font-family: 'Cormorant Garamond', serif; font-size: 18px; font-weight: 600;
    line-height: 1.3; margin: 0 0 6px; color: var(--rc-deep-forest, #0F2318);
}

.rc-opp-card-org {
    font-size: 13px; color: var(--rc-canopy, #2D6A4F); margin: 0 0 6px; font-weight: 500;
}

.rc-opp-card-meta { display: flex; flex-wrap: wrap; gap: 12px; font-size: 12px; color: rgba(0,0,0,0.5); margin-bottom: 8px; }
.rc-opp-meta-item { display: inline; }

.rc-opp-card-desc {
    font-size: 13px; color: #666; line-height: 1.5; flex: 1;
    display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
}

.rc-opp-card-footer {
    display: flex; justify-content: space-between; align-items: center;
    padding: 12px 18px; border-top: 1px solid rgba(0,0,0,.06);
    font-size: 13px;
}

.rc-opp-deadline { font-family: 'Inconsolata', monospace; font-size: 12px; color: rgba(0,0,0,0.4); }
.rc-opp-deadline-urgent { color: #B33A3A; font-weight: 600; }
.rc-opp-deadline-near { color: #B8860B; font-weight: 500; }
.rc-opp-deadline-expired { color: #999; font-style: italic; }

.rc-opp-view-link {
    font-family: 'Jost', sans-serif; font-size: 13px; font-weight: 500;
    color: var(--rc-canopy, #2D6A4F);
}

/* --- Shared Pagination --- */
.rc-resource-pagination,
.rc-opp-pagination {
    display: flex; gap: 6px; margin-top: 32px; justify-content: center;
}
.rc-resource-pagination a,
.rc-opp-pagination a {
    display: inline-flex; align-items: center; justify-content: center;
    width: 36px; height: 36px; border: 1px solid rgba(0,0,0,.1); border-radius: 4px;
    font-size: 14px; color: var(--rc-forest); text-decoration: none;
    transition: background .15s;
}
.rc-resource-pagination a:hover,
.rc-opp-pagination a:hover { background: var(--rc-fog); }
.rc-resource-page-current,
.rc-opp-page-current {
    display: inline-flex; align-items: center; justify-content: center;
    width: 36px; height: 36px; background: var(--rc-forest); color: #fff;
    border-radius: 4px; font-size: 14px; font-weight: 600;
}

/* --- Empty State --- */
.rc-resource-empty,
.rc-opp-empty {
    text-align: center; padding: 48px 24px; color: #888;
    border: 2px dashed rgba(0,0,0,.08); border-radius: 10px;
}
.rc-resource-empty p,
.rc-opp-empty p { margin: 0 0 8px; }
.rc-resource-empty a,
.rc-opp-empty a { color: var(--rc-canopy); }

/* --- Submit CTA --- */
.rc-resource-submit-cta,
.rc-opp-submit-cta { margin-top: 32px; text-align: center; }

/* --- Narrower grid inside Info Hub layout --- */
.rc-infohub-main .rc-resource-grid { grid-template-columns: repeat(2, 1fr); }
.rc-infohub-main .rc-opp-grid { grid-template-columns: repeat(2, 1fr); }

/* --- Directory Responsive --- */
@media (max-width: 700px) {
    .rc-resource-grid,
    .rc-opp-grid { grid-template-columns: 1fr; }
    .rc-resource-filter-row,
    .rc-opp-filter-row { flex-direction: column; }
    .rc-resource-filter-field,
    .rc-opp-filter-field { flex: 1 1 100%; }
    .rc-infohub-main .rc-resource-grid,
    .rc-infohub-main .rc-opp-grid { grid-template-columns: 1fr; }
}


/* =============================================
   53.9: SLIDER TEXT CONTAINMENT FIX (S157)
   ============================================= */
.rc-mch-slide-content { max-width: 1100px; margin: 0 auto; box-sizing: border-box; }


