/**
 * Module: article_text_image
 */

/* ============================================
   TEXT WITH IMAGE
   ============================================ */

.t1-text-image {
    display: grid;
    grid-template-columns: 1fr 40%;
    gap: 2rem;
    align-items: start;
    margin: 2rem 0;
}

.t1-text-image--left {
    grid-template-columns: 40% 1fr;
}

.t1-text-image--left .t1-text-image__figure {
    order: -1;
}

.t1-text-image--size-10 { grid-template-columns: 1fr 10%; }
.t1-text-image--size-10.t1-text-image--left { grid-template-columns: 10% 1fr; }

.t1-text-image--size-15 { grid-template-columns: 1fr 15%; }
.t1-text-image--size-15.t1-text-image--left { grid-template-columns: 15% 1fr; }

.t1-text-image--size-20 { grid-template-columns: 1fr 20%; }
.t1-text-image--size-20.t1-text-image--left { grid-template-columns: 20% 1fr; }

.t1-text-image--size-25 { grid-template-columns: 1fr 25%; }
.t1-text-image--size-25.t1-text-image--left { grid-template-columns: 25% 1fr; }

.t1-text-image--size-30 { grid-template-columns: 1fr 30%; }
.t1-text-image--size-30.t1-text-image--left { grid-template-columns: 30% 1fr; }

.t1-text-image--size-35 { grid-template-columns: 1fr 35%; }
.t1-text-image--size-35.t1-text-image--left { grid-template-columns: 35% 1fr; }

.t1-text-image--size-40 { grid-template-columns: 1fr 40%; }
.t1-text-image--size-40.t1-text-image--left { grid-template-columns: 40% 1fr; }

.t1-text-image--size-45 { grid-template-columns: 1fr 45%; }
.t1-text-image--size-45.t1-text-image--left { grid-template-columns: 45% 1fr; }

.t1-text-image--size-50 { grid-template-columns: 1fr 50%; }
.t1-text-image--size-50.t1-text-image--left { grid-template-columns: 50% 1fr; }

.t1-text-image--size-55 { grid-template-columns: 1fr 55%; }
.t1-text-image--size-55.t1-text-image--left { grid-template-columns: 55% 1fr; }

.t1-text-image--size-60 { grid-template-columns: 1fr 60%; }
.t1-text-image--size-60.t1-text-image--left { grid-template-columns: 60% 1fr; }

.t1-text-image__figure {
    margin: 0;
}

.t1-text-image__img {
    width: 100%;
    border-radius: 8px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.1);
    display: block;
}

.t1-text-image__caption {
    font-size: 0.875rem;
    color: var(--stone);
    font-style: italic;
    margin-top: 0.75rem;
    text-align: center;
}

/* Rich text content styles (mirrors article_text for module isolation) */
.t1-text-image__content {
    font-size: 1.0625rem;
    line-height: 1.8;
    color: var(--ink);
}

.t1-text-image__content > *:first-child {
    margin-top: 0;
}

.t1-text-image__content > *:last-child {
    margin-bottom: 0;
}

.t1-text-image__content p {
    margin: 0 0 1.5rem;
}

.t1-text-image__content h2 {
    font-size: 1.5rem;
    font-weight: 700;
    margin: 2.5rem 0 1rem;
    color: var(--ink);
}

.t1-text-image__content h3 {
    font-size: 1.25rem;
    font-weight: 600;
    margin: 2rem 0 0.75rem;
    color: var(--ink);
}

.t1-text-image__content h4 {
    font-size: 1.125rem;
    font-weight: 600;
    margin: 1.5rem 0 0.5rem;
    color: var(--ink);
}

.t1-text-image__content a {
    color: var(--jade);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.t1-text-image__content a:hover {
    color: var(--jade-dark);
}

.t1-text-image__content ul,
.t1-text-image__content ol {
    margin: 1.5rem 0;
    padding-left: 1.5rem;
}

.t1-text-image__content li {
    margin-bottom: 0.5rem;
}

.t1-text-image__content ul li {
    list-style: disc;
}

.t1-text-image__content ol li {
    list-style: decimal;
}

.t1-text-image__content blockquote {
    margin: 2rem 0;
    padding: 1.25rem 1.5rem;
    background: var(--jade-light);
    border-left: 3px solid var(--jade);
    border-radius: 0 8px 8px 0;
    font-style: italic;
    color: var(--jade-dark);
}

.t1-text-image__content code {
    font-family: 'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono', Consolas, monospace;
    font-size: 0.9375em;
    background: var(--pearl);
    padding: 0.125rem 0.375rem;
    border-radius: 4px;
}

.t1-text-image__content img {
    border-radius: 8px;
    margin: 2rem 0;
    display: block;
    max-width: 100%;
    height: auto;
}

@media (max-width: 768px) {
    .t1-text-image,
    .t1-text-image--left,
    .t1-text-image--size-10,
    .t1-text-image--size-15,
    .t1-text-image--size-20,
    .t1-text-image--size-25,
    .t1-text-image--size-30,
    .t1-text-image--size-35,
    .t1-text-image--size-40,
    .t1-text-image--size-45,
    .t1-text-image--size-50,
    .t1-text-image--size-55,
    .t1-text-image--size-60,
    .t1-text-image--size-10.t1-text-image--left,
    .t1-text-image--size-15.t1-text-image--left,
    .t1-text-image--size-20.t1-text-image--left,
    .t1-text-image--size-25.t1-text-image--left,
    .t1-text-image--size-30.t1-text-image--left,
    .t1-text-image--size-35.t1-text-image--left,
    .t1-text-image--size-40.t1-text-image--left,
    .t1-text-image--size-45.t1-text-image--left,
    .t1-text-image--size-50.t1-text-image--left,
    .t1-text-image--size-55.t1-text-image--left,
    .t1-text-image--size-60.t1-text-image--left {
        grid-template-columns: 1fr;
    }
    
    .t1-text-image--left .t1-text-image__figure {
        order: 0;
    }
    
    .t1-text-image__figure {
        margin-top: 1.5rem;
    }
}

/* ========================================
   LIGHT THEME OVERRIDE
   ======================================== */

.t1-text-image--light .t1-text-image__caption {
    color: var(--stone);
}

.t1-text-image--light .t1-text-image__content {
    color: var(--ink);
}

.t1-text-image--light .t1-text-image__content h2,
.t1-text-image--light .t1-text-image__content h3,
.t1-text-image--light .t1-text-image__content h4 {
    color: var(--ink);
}

.t1-text-image--light .t1-text-image__content a {
    color: var(--jade);
}

.t1-text-image--light .t1-text-image__content a:hover {
    color: var(--jade-dark);
}

.t1-text-image--light .t1-text-image__content blockquote {
    background: var(--jade-light);
    border-left-color: var(--jade);
    color: var(--jade-dark);
}

.t1-text-image--light .t1-text-image__content code {
    background: var(--pearl);
}