/* ==============================================
   TX City Commercial Template (9 cities)
   ============================================== */

#ec-ccb *:where(:not([class*="cp-"])),
    #ec-ccb *:where(:not([class*="cp-"]))::before,
    #ec-ccb *:where(:not([class*="cp-"]))::after {
        margin: 0; padding: 0; border: 0; font-size: 100%; font: inherit;
        vertical-align: baseline; box-sizing: border-box; text-decoration: none; box-shadow: none;
    }
    #ec-ccb {
        font-family: 'Plus Jakarta Sans', 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
        color: #1a1a2e; width: 100%; max-width: 100%; line-height: 1.6;
        -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale;
    }
    #ec-ccb a { color: #0E9F6E; } #ec-ccb a:hover { color: #0a7550; text-decoration: underline; }
    #ec-ccb a.cp-plan-cta { color: #fff; } #ec-ccb a.cp-plan-cta:hover { color: #fff; text-decoration: none; }

    #ec-ccb .ccb-section { padding: 3.5rem 0; position: relative; }
    #ec-ccb .ccb-section--alt { background: #f8faf9; border-radius: 12px; padding: 3.5rem 2rem; }
    @media (max-width: 768px) {
        #ec-ccb .ccb-section { padding: 2.5rem 0; }
        #ec-ccb .ccb-section--alt { padding: 2.5rem 1.25rem; }
    }

    #ec-ccb .ccb-label {
        display: inline-flex; align-items: center; gap: 0.5rem;
        font-size: 0.6875rem; font-weight: 700; text-transform: uppercase;
        letter-spacing: 0.1em; color: #0E9F6E; margin-bottom: 0.75rem;
    }
    #ec-ccb .ccb-num {
        background: #ecfdf5; color: #0E9F6E; font-weight: 800;
        width: 22px; height: 22px; border-radius: 6px;
        display: inline-flex; align-items: center; justify-content: center; font-size: 0.6875rem;
    }
    #ec-ccb .ccb-h2 {
        font-size: 1.75rem; font-weight: 800; color: #0A2540;
        letter-spacing: -0.025em; line-height: 1.2; margin-bottom: 0.75rem;
    }
    @media (max-width: 640px) {
        #ec-ccb .ccb-h2 { font-size: 1.4rem; }
    }

    #ec-ccb .ccb-content { max-width: 100%; }
    #ec-ccb .ccb-content h3 {
        font-size: 1.25rem; font-weight: 700; color: #0A2540;
        margin: 2rem 0 0.5rem; letter-spacing: -0.01em;
    }
    #ec-ccb .ccb-content p {
        font-size: 1rem; color: #374151; line-height: 1.8; margin-bottom: 1rem;
    }
    #ec-ccb .ccb-content strong { font-weight: 700; color: #0A2540; }


    #ec-ccb .ccb-faq-list { border-top: 1px solid #e5e7eb; }
    #ec-ccb .ccb-faq-item { border-bottom: 1px solid #e5e7eb; }
    #ec-ccb .ccb-faq-q {
        padding: 1.25rem 0.25rem; font-size: 1rem; font-weight: 600; color: #0A2540;
        cursor: pointer; display: flex; justify-content: space-between; align-items: center;
        gap: 1rem; background: transparent; transition: color 0.15s; list-style: none;
    }
    #ec-ccb .ccb-faq-q::-webkit-details-marker { display: none; }
    #ec-ccb .ccb-faq-q::marker { display: none; content: ''; }
    #ec-ccb .ccb-faq-q::after {
        content: '+'; font-size: 1.5rem; font-weight: 400; color: #9ca3af;
        flex-shrink: 0; transition: color 0.2s;
    }
    #ec-ccb .ccb-faq-q:hover { color: #0E9F6E; }
    #ec-ccb details[open] .ccb-faq-q { color: #0E9F6E; }
    #ec-ccb details[open] .ccb-faq-q::after { content: '\2212'; color: #0E9F6E; }
    #ec-ccb .ccb-faq-a {
        padding: 0 0.25rem 1.25rem; font-size: 0.9375rem; color: #4b5563; line-height: 1.75;
    }
    #ec-ccb .ccb-faq-a strong { font-weight: 700; color: #0A2540; }
    #ec-ccb .ccb-faq-a p { margin-bottom: 0.75rem; }
    #ec-ccb .ccb-faq-a p:last-child { margin-bottom: 0; }
    @media (max-width: 480px) { #ec-ccb .ccb-faq-q { font-size: 0.9375rem; padding: 1rem 0.25rem; } }
