import streamlit as st

def apply_custom_styles():
    st.markdown("""
        <style>
        .stApp {
            max-width: 1200px;
            margin: 0 auto;
            background: linear-gradient(135deg, #f5f7fa 0%, #e4e9f2 100%);
            background-attachment: fixed;
            min-height: 100vh;
        }
        .upload-container {
            border: 2px dashed #0066cc;
            border-radius: 10px;
            padding: 20px;
            text-align: center;
            margin: 20px 0;
            background: rgba(255, 255, 255, 0.9);
            backdrop-filter: blur(5px);
        }
        .factor-card {
            background-color: rgba(255, 255, 255, 0.95);
            padding: 20px;
            border-radius: 10px;
            box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
            margin: 10px 0;
            backdrop-filter: blur(5px);
            height: 100%;
        }
        .good-factor {
            border-left: 4px solid #28a745;
        }
        .average-factor {
            border-left: 4px solid #ffc107;
        }
        .bad-factor {
            border-left: 4px solid #dc3545;
        }
        .header-container {
            padding: 2rem 0;
            margin-bottom: 2rem;
            background: linear-gradient(90deg, #0066cc 0%, #0099ff 100%);
            color: white;
            border-radius: 10px;
            text-align: center;
            box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
        }
        .detailed-factor {
            padding: 15px;
            border-radius: 8px;
            margin: 10px 0;
            background: rgba(255, 255, 255, 0.9);
            border-left: 4px solid #666;
        }
        .detailed-factor.good {
            border-left-color: #28a745;
            background: rgba(40, 167, 69, 0.1);
        }
        .detailed-factor.average {
            border-left-color: #ffc107;
            background: rgba(255, 193, 7, 0.1);
        }
        .detailed-factor.bad {
            border-left-color: #dc3545;
            background: rgba(220, 53, 69, 0.1);
        }
        .comparison-table {
            background: white;
            border-radius: 10px;
            box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
            margin: 20px 0;
        }
        </style>
    """, unsafe_allow_html=True)

def show_factor_section(title, factors, color):
    if factors:
        st.markdown(f"""
            <div class="factor-card {color}-factor">
                <h3 style="color: #333;">{title}</h3>
                <ul style="list-style-type: none; padding-left: 0;">
                    {"".join(f'<li style="margin: 10px 0; padding: 10px; background: rgba(248, 249, 250, 0.8); border-radius: 5px;">{factor}</li>' for factor in factors)}
                </ul>
            </div>
        """, unsafe_allow_html=True)

def show_detailed_factors(good_factors, average_factors, bad_factors):
    for factor in good_factors:
        name, explanation = factor.split(':', 1)
        st.markdown(f"""
            <div class="detailed-factor good">
                <strong>{name}</strong>
                <p style="margin: 5px 0 0 0; color: #666;">{explanation}</p>
            </div>
        """, unsafe_allow_html=True)

    for factor in average_factors:
        name, explanation = factor.split(':', 1)
        st.markdown(f"""
            <div class="detailed-factor average">
                <strong>{name}</strong>
                <p style="margin: 5px 0 0 0; color: #666;">{explanation}</p>
            </div>
        """, unsafe_allow_html=True)

    for factor in bad_factors:
        name, explanation = factor.split(':', 1)
        st.markdown(f"""
            <div class="detailed-factor bad">
                <strong>{name}</strong>
                <p style="margin: 5px 0 0 0; color: #666;">{explanation}</p>
            </div>
        """, unsafe_allow_html=True)

def show_factor_summary(summary, verdict, sentiment_title):
    if len(summary) > 0:
        st.markdown(f"""
                <div class="detailed-factor {verdict}">
                    <strong>{sentiment_title}</strong>
                    <p style="margin: 5px 0 0 0; color: #666;">{summary}</p>
                </div>
            """, unsafe_allow_html=True)