/* static/style.css */

body {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
    /* Většina základních stylů těla je převzata z Bootstrapu */
}

/* Karty projektů na indexu - aktivní projekty s modrým levým okrajem */
.project-card-active {
    border-left: 4px solid var(--bs-primary) !important; 
}

/* Zjemněné zobrazení hotových úkolů v tabulkách */
.task-done-row {
    color: var(--bs-gray-600); /* Trochu tmavší než výchozí .text-muted pro lepší čitelnost */
    font-style: italic; /* Přidána kurzíva zpět dle tvého přání */
}
.task-done-row a { /* Odkazy uvnitř hotových úkolů budou také ztlumené a s kurzívou */
    color: var(--bs-gray-600) !important; 
    font-style: italic;
}
.task-done-row a:hover {
    color: var(--bs-gray-700) !important;
}
/* Ujistí se, že červený text termínu u hotových, ale zpožděných úkolů zůstane viditelný */
.task-done-row .text-danger.fw-bold {
    color: var(--bs-danger) !important; 
    font-style: normal !important; /* Odebrání kurzívy pro varování termínu */
}

/* Ikony stavů úkolů v tabulkách */
.task-status-icon {
    font-size: 1.25rem; /* Odpovídá Bootstrap fs-5 */
    vertical-align: middle;
}

/* Finanční přehled na detailu projektu - jednotlivé položky */
.financial-overview-item {
    padding: 0.75rem;
    border: 1px solid var(--bs-border-color-translucent);
    border-radius: var(--bs-border-radius);
    margin-bottom: 1rem; 
}
@media (min-width: 768px) { 
    .financial-overview-item {
        margin-bottom: 0; 
    }
}

/* Barvy pro finanční rozdíly v tabulkách forecastu */
.positive-diff { color: var(--bs-success); font-weight: 500; }
.negative-diff { color: var(--bs-danger); font-weight: 500; }

/* Graf kontejner */
#chart-container { 
    width: 100%; 
    max-width: 900px; 
}

/* Vertikální mezery mezi sekcemi na stránce forecastu */
.forecast-section {
    margin-bottom: 3rem; 
}
.forecast-section:last-child {
    margin-bottom: 1.5rem; 
}
.forecast-section .small.text-muted {
    margin-top: 0.5rem;
}

/* Drag & Drop zóna pro nahrávání souborů */
#drop-zone {
    border: 2px dashed var(--bs-primary);
    border-radius: var(--bs-border-radius);
    padding: 2rem;
    text-align: center;
    margin-bottom: 1.5rem;
    background-color: var(--bs-light);
    transition: background-color 0.2s ease-in-out, border-color 0.2s ease-in-out;
}
#drop-zone.dragover {
    background-color: #cfe2ff; 
    border-color: var(--bs-primary-dark);
}
#drop-zone p { margin-bottom: 0.5rem; }
.file-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.5rem 0.75rem;
    border: 1px solid var(--bs-border-color-translucent);
    border-radius: var(--bs-border-radius-sm);
    margin-bottom: 0.5rem;
    background-color: var(--bs-body-bg);
}
.file-item:last-child { margin-bottom: 0; }
.file-name { flex-grow: 1; margin-right: 1rem; word-break: break-all; }
.file-status { margin-left: 1rem; font-style: italic; white-space: nowrap; }
.status-success { color: var(--bs-success); font-weight: bold; }
.status-error { color: var(--bs-danger); font-weight: bold; }
.status-progress { color: var(--bs-primary); }
#file-input-hidden { display: none; }
.custom-file-upload-label { cursor: pointer; color: var(--bs-link-color); text-decoration: underline; font-weight: bold; }
.custom-file-upload-label:hover { color: var(--bs-link-hover-color); }


/* Nový styl pro vizuální odlišení hlavičky u nabídek */
.header-offer {
    background-color: #e7f3fe; /* Světle modré pozadí (jako Bootstrap "info" alert) */
    border: 1px solid #bde0fe;   /* decentní modrý rámeček */
    padding: 1rem 1.5rem;        /* Vnitřní odsazení, aby to vypadalo dobře */
    border-radius: 0.5rem;       /* Zakulacené rohy, aby to ladilo s designem */
    margin-bottom: 1.5rem;       /* Odsazení od obsahu pod hlavičkou */
}

/* Styly pro finanční přehled na stránce splátky */
.stat-card-row {
    margin-bottom: 2rem;
}

.stat-card {
    background-color: #fff;
    border: 1px solid #dee2e6;
    border-radius: 0.5rem;
    padding: 1.25rem;
    text-align: center;
    border-left-width: 5px;
    box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
}

.stat-card-title {
    font-size: 0.9rem;
    font-weight: 600;
    color: #6c757d;
    text-transform: uppercase;
    margin-bottom: 0.5rem;
}

.stat-card-value {
    font-size: 1.75rem;
    font-weight: 700;
    color: #212529;
}

/* Barevné varianty */
.stat-card-info { border-left-color: #0d6efd; } /* Modrá - Celkem */
.stat-card-success { border-left-color: #198754; } /* Zelená - Uhrazeno */
.stat-card-warning { border-left-color: #ffc107; } /* Žlutá/Oranžová - Zbývá */
.stat-card-secondary { border-left-color: #6c757d; } /* Šedá - Detail plateb */

/* Další barevné varianty pro stat-card */
.stat-card-danger { border-left-color: #dc3545; }  /* Červená - pro náklady */
.stat-card-purple { border-left-color: #6f42c1; }  /* Fialová - pro marži */

/* ===== OPRAVA PRO SCROLLOVÁNÍ CHATU ===== */

.chat-history {
    /* Nastaví maximální výšku. Můžeš si upravit podle potřeby (např. 50vh nebo 400px). */
    max-height: 60vh; 

    /* Tyto vlastnosti zajistí, že se zprávy řadí pod sebe a kontejner se správně roztahuje. */
    display: flex;
    flex-direction: column;

    /* Toto je klíčová vlastnost: automaticky přidá svislý posuvník, když je obsahu moc. */
    overflow-y: auto; 
}

/* Zajišťuje správné zobrazení a skrytí tlačítka pro smazání zprávy */
.chat-bubble .delete-message-btn {
    opacity: 0; /* Tlačítko je standardně neviditelné (plně průhledné) */
    transition: opacity 0.2s ease-in-out; /* Pěkný přechod při zobrazení */
}

/* Zobrazí tlačítko, když najedete myší na CELOU bublinu se zprávou */
.chat-bubble:hover .delete-message-btn {
    opacity: 0.7; /* Lehce průhledné pro decentní vzhled */
}

/* Při najetí přímo na tlačítko bude plně viditelné */
.chat-bubble .delete-message-btn:hover {
    opacity: 1;
}

/* ========================================================== */
/* === Sjednocené styly pro karty a detaily v adresářích === */
/* ========================================================== */

.directory-card {
    background-color: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: .5rem;
    border-left-width: 4px; /* Sjednocená tloušťka okraje */
    border-left-style: solid;
    box-shadow: 0 1px 2px rgba(0,0,0,.04);
    transition: all .2s ease-in-out;
    padding: 1rem 1.25rem;

    /* ZDE JE PŘIDANÁ OPRAVA: Zajistí, že dlouhý text bez mezer se zalomí
       a nerozbije layout celé karty. */
    overflow-wrap: break-word;
}

.directory-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--bs-box-shadow-sm);
}

/* Pravidlo pro jméno na kartě (sjednoceno pro všechny typy) */
.directory-card .contact-name, 
.directory-card .investor-name,
.directory-card .user-name { /* Přidáno pro interní kontakty */
    font-weight: 600;
    font-size: 1.1rem;
    
    /* Pojistka pro zalamování i na samotném elementu jména */
    overflow-wrap: break-word;
}

/* Pravidlo pro detaily na kartě (sjednoceno pro všechny typy) */
.directory-card .contact-detail, 
.directory-card .investor-detail {
    font-size: 0.9rem;
    color: var(--bs-secondary-color);
    display: flex;
    align-items: center;
    margin-bottom: 0.25rem;
}

.directory-card .contact-detail i, 
.directory-card .investor-detail i {
    width: 24px;
    text-align: center;
}

/* ========================================================== */
/* === Styly pro responzivní mřížku karet === */
/* ========================================================== */

/* --- Výchozí styl pro desktop --- */
.directory-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
    gap: 1rem;
}

/* --- Styl pro mobily (obrazovky užší než 768px) --- */
@media (max-width: 767.98px) {
    .directory-grid {
        display: block; /* Vypne mřížku, prvky se budou chovat jako bloky */
    }
    .directory-grid > .directory-card {
        margin-bottom: 1rem; /* Nahradíme mezeru (gap), která v block layoutu nefunguje */
    }
}

/* ========================================================== */
/* FINÁLNÍ CHYTRÉ STYLY PRO ZOBRAZENÍ PROHLÍŽEČE (v4)     */
/* ========================================================== */

/* KDYŽ JE OTEVŘENÝ JAKÝKOLIV PANEL, NIKDY NECHCEME Tmavé pozadí */
.offcanvas-backdrop.show {
    display: none !important;
}

/* --- Speciální pravidla POUZE pro zobrazení "Master-Detail" --- */

/* TŘÍDY se aplikují na BODY, POUZE KDYŽ jsou oba panely otevřené */
body.contracts-open.viewer-open {
    padding-left: 30%;  /* Místo pro levý panel */
    padding-right: 70%; /* Místo pro pravý panel */
    transition: all 0.3s ease-in-out;
}

/* Udělá z levého panelu "přilepený" sidebar, POUZE KDYŽ je otevřený i pravý */
body.contracts-open.viewer-open #contractsOffcanvas.show {
    transform: none !important;
    visibility: visible !important;
    border-right: 1px solid #dee2e6;
}

/* Udělá z pravého panelu "přilepený" sidebar, POUZE KDYŽ je otevřený i levý */
body.contracts-open.viewer-open #fileViewerOffcanvas.show {
    transform: none !important;
    visibility: visible !important;
}