.elementor-2322 .elementor-element.elementor-element-ca835a6{--display:flex;}/* Start custom CSS */:root { 
      --petrol: #2B6A7C; 
      --petrol-light: #3D8A9E; 
      --petrol-dark: #1E4D5A; 
      --sky-light: #D5E8F0; 
      --cloud-white: #F8FCFD; 
      --accent-warm: #E8B86D; 
      --text-dark: #333; 
      --text-medium: #555; 
      --warning-red: #E07A5F; 
      --success-green: #6B9B7A; 
      --sarah-purple: #8B7BA8;
      --eco-green: #4A7C59;
      --eco-green-light: #E8F5E9;
    }

    .bsj-hub-page { font-family: 'Quicksand', sans-serif; color: var(--text-dark); line-height: 1.7; max-width: 900px; margin: 0 auto; padding: 20px; }
    .bsj-hub-page h1 { color: var(--eco-green); font-size: 2.4rem; font-weight: 700; line-height: 1.3; margin-bottom: 10px; }
    .bsj-hub-page .hub-subtitle { font-size: 1.3rem; color: var(--text-medium); margin-bottom: 40px; font-weight: 500; }
    .bsj-hub-page h2 { color: var(--petrol); font-size: 1.7rem; font-weight: 700; margin: 50px 0 25px; padding-top: 20px; border-top: 2px solid var(--sky-light); }
    .bsj-hub-page h2:first-of-type { border-top: none; padding-top: 0; }
    .bsj-hub-page h3 { color: var(--petrol-dark); font-size: 1.3rem; font-weight: 600; margin: 35px 0 15px; }
    .bsj-hub-page h4 { color: var(--petrol); font-size: 1.1rem; font-weight: 600; margin: 25px 0 10px; }
    .bsj-hub-page p { margin-bottom: 18px; font-size: 1.05rem; }

    .bsj-hub-page a { color: var(--petrol); }
    
    /* Hub Hero */
    .hub-hero { background: linear-gradient(145deg, var(--eco-green-light), #fff); border: 2px solid var(--eco-green); border-radius: 24px; padding: 35px; margin: 30px 0; display: flex; align-items: flex-start; gap: 25px; }
    .hub-hero .hero-icon { width: 80px; height: 80px; background: var(--eco-green); border-radius: 20px; display: flex; align-items: center; justify-content: center; font-size: 2.5rem; flex-shrink: 0; }
    .hub-hero .hero-content h2 { margin: 0 0 15px 0; color: var(--eco-green); border: none; padding: 0; font-size: 1.5rem; }
    .hub-hero .hero-content p { margin: 0; font-size: 1.05rem; color: var(--text-medium); }
    
    /* Eco Badges */
    .eco-badges { display: flex; flex-wrap: wrap; gap: 15px; justify-content: center; margin: 40px 0; }
    .eco-badge { display: flex; align-items: center; gap: 8px; background: white; border: 2px solid var(--eco-green); border-radius: 30px; padding: 10px 20px; font-weight: 600; color: var(--eco-green); font-size: 0.95rem; }
    .eco-badge .badge-icon { font-size: 1.2rem; }
    
    /* Hub Intro */
    .hub-intro { background: var(--cloud-white); border-radius: 16px; padding: 30px; margin: 30px 0; }
    .hub-intro p { margin-bottom: 15px; }
    .hub-intro p:last-child { margin-bottom: 0; }
    
    /* Hub Grid */
    .hub-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 25px; margin: 30px 0; }
    
    /* Hub Card */
    .hub-card { background: white; border-radius: 20px; padding: 0; box-shadow: 0 5px 30px rgba(43, 106, 124, 0.08); overflow: hidden; position: relative; transition: all 0.3s; border: 2px solid transparent; }
    .hub-card:hover { transform: translateY(-5px); border-color: var(--eco-green); box-shadow: 0 10px 40px rgba(74, 124, 89, 0.15); }
    .hub-card.featured { border-color: var(--eco-green); background: linear-gradient(145deg, var(--eco-green-light), #fff); }
    .hub-card .card-badge { position: absolute; top: 15px; right: 15px; background: var(--eco-green); color: white; padding: 5px 12px; border-radius: 15px; font-size: 0.75rem; font-weight: 700; }
    .hub-card .card-badge.coming { background: #9e9e9e; }
    .hub-card .card-icon { width: 100%; height: 80px; background: linear-gradient(145deg, var(--eco-green-light), #C8E6C9); display: flex; align-items: center; justify-content: center; font-size: 2.5rem; }
    .hub-card .card-content { padding: 25px; }
    .hub-card .card-content h3 { margin: 0 0 12px 0; color: var(--petrol-dark); font-size: 1.15rem; }
    .hub-card .card-content p { margin: 0 0 15px 0; font-size: 0.95rem; color: var(--text-medium); }
    .hub-card .card-meta { display: flex; gap: 15px; font-size: 0.8rem; color: var(--text-medium); margin-bottom: 15px; }
    .hub-card .card-link { display: inline-block; color: var(--eco-green); font-weight: 700; text-decoration: none; font-size: 0.95rem; }
    .hub-card .card-link:hover { text-decoration: underline; }
    .hub-card .card-link.disabled { color: #9e9e9e; cursor: default; }
    .hub-card .card-link.disabled:hover { text-decoration: none; }
    
    /* Criteria Grid */
    .criteria-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin: 30px 0; }
    .criteria-item { background: white; border-radius: 16px; padding: 25px 20px; text-align: center; box-shadow: 0 3px 15px rgba(0,0,0,0.05); border: 1px solid var(--sky-light); }
    .criteria-item .criteria-icon { font-size: 2rem; margin-bottom: 12px; }
    .criteria-item h4 { margin: 0 0 10px 0; color: var(--petrol); font-size: 1rem; }
    .criteria-item p { margin: 0; font-size: 0.85rem; color: var(--text-medium); }
    
    /* Certifications Box */
    .certifications-box { background: linear-gradient(145deg, var(--sky-light), var(--cloud-white)); border-radius: 20px; padding: 30px; margin: 40px 0; }
    .certifications-box h3 { margin: 0 0 25px 0; color: var(--petrol); }
    .cert-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
    .cert-item { background: white; border-radius: 12px; padding: 20px; border: 1px solid var(--sky-light); }
    .cert-item strong { display: block; color: var(--eco-green); font-size: 1.1rem; margin-bottom: 8px; }
    .cert-item p { margin: 0; font-size: 0.9rem; color: var(--text-medium); }
    
    /* Partner Highlight */
    .partner-highlight { background: linear-gradient(145deg, var(--eco-green), #3D5A45); border-radius: 24px; padding: 35px; margin: 40px 0; color: white; display: flex; align-items: flex-start; gap: 30px; }
    .partner-highlight .partner-logo { width: 80px; height: 80px; background: rgba(255,255,255,0.15); border-radius: 16px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 2.5rem; }
    .partner-highlight .partner-content h3 { color: white; margin: 0 0 15px 0; font-size: 1.4rem; }
    .partner-highlight .partner-content p { margin: 0 0 15px 0; opacity: 0.95; font-size: 1rem; }
    .partner-highlight .partner-btn { display: inline-block; background: var(--accent-warm); color: var(--petrol-dark); padding: 12px 25px; border-radius: 10px; font-weight: 700; text-decoration: none; transition: all 0.3s; }
    .partner-highlight .partner-btn:hover { background: #d4a85a; transform: translateY(-2px); }
    
    /* Affiliate Notice */
    .affiliate-notice { background: linear-gradient(145deg, #e8f5e9, #fff); border: 1px solid var(--eco-green); border-radius: 12px; padding: 20px; margin: 30px 0; font-size: 0.9rem; color: var(--text-medium); }
    .affiliate-notice strong { color: var(--eco-green); }
    .affiliate-notice a { color: var(--eco-green); }
    
    /* Related Hubs */
    .related-hubs { margin: 40px 0; }
    .related-hubs h3 { margin: 0 0 20px 0; color: var(--petrol); }
    .related-grid { display: flex; flex-wrap: wrap; gap: 15px; }
    .related-item { display: flex; align-items: center; gap: 10px; background: white; border: 2px solid var(--sky-light); border-radius: 12px; padding: 12px 20px; text-decoration: none; color: var(--petrol-dark); font-weight: 600; transition: all 0.3s; }
    .related-item:hover { border-color: var(--petrol); background: var(--cloud-white); }
    .related-item .related-icon { font-size: 1.3rem; }
    
    /* Responsive */
    @media (max-width: 768px) {
      .bsj-hub-page h1 { font-size: 1.9rem; }
      .hub-hero { flex-direction: column; text-align: center; }
      .hub-grid { grid-template-columns: 1fr; }
      .criteria-grid { grid-template-columns: repeat(2, 1fr); }
      .cert-grid { grid-template-columns: 1fr; }
      .partner-highlight { flex-direction: column; text-align: center; }
      .eco-badges { flex-direction: column; align-items: center; }
    }
    
    @media (max-width: 480px) {
      .criteria-grid { grid-template-columns: 1fr; }
    }/* End custom CSS */