/* =====================================================================
   Tecnical Expert - Foglio di stile principale
   =====================================================================
   Design: stile B2B/SaaS moderno ispirato al layout di riferimento
   fornito (card bianche su sfondo grigio chiaro, colonne, blu primario).
   Tutti i colori e le misure sono variabili CSS per facile rebranding.
   ===================================================================== */

/* ---------------------------------------------------------------------
   1. Variabili CSS - palette, tipografia, spaziature
   --------------------------------------------------------------------- */
:root {
    /* Palette */
    --colore-bg:           #eef4ff;
    --colore-card:         #ffffff;     /* sfondo delle card */
    --colore-bordo:        #e5edf9;
    --colore-bordo-soft:   #edf2fb;
    --colore-testo:        #16325c;     /* blu scuro per testi principali */
    --colore-testo-soft:   #54698d;     /* grigio-blu per testi secondari */
    --colore-help:         #706e6b;     /* grigio per testi di aiuto */

    --colore-primario:     #1d4ed8;
    --colore-primario-hover: #1e40af;
    --colore-header:       #1e3a8a;
    --colore-success:      #2e844a;
    --colore-warning:      #fe9339;
    --colore-error:        #c23934;

    /* Tipografia */
    --font-stack: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
                  "Helvetica Neue", Arial, sans-serif;
    --font-mono:  "SF Mono", Menlo, Consolas, monospace;

    /* Spaziature */
    --spazio-xs:  4px;
    --spazio-sm:  8px;
    --spazio-md:  16px;
    --spazio-lg:  24px;
    --spazio-xl:  32px;

    /* Raggi */
    --raggio:    10px;
    --raggio-lg: 14px;

    /* Ombre */
    --ombra-card: 0 10px 28px rgba(16, 24, 40, 0.08);
    --ombra-modale: 0 8px 24px rgba(0, 0, 0, 0.18);
}

/* ---------------------------------------------------------------------
   2. Reset minimale e base
   --------------------------------------------------------------------- */
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html, body {
    height: 100%;
    background:
        radial-gradient(circle at 0 0, rgba(59, 130, 246, 0.14) 0%, rgba(59, 130, 246, 0) 40%),
        radial-gradient(circle at 100% 0, rgba(147, 197, 253, 0.12) 0%, rgba(147, 197, 253, 0) 44%),
        radial-gradient(circle at 30% 100%, rgba(37, 99, 235, 0.10) 0%, rgba(37, 99, 235, 0) 45%),
        radial-gradient(rgba(15, 23, 42, 0.06) 1px, transparent 1px),
        linear-gradient(180deg, #e8f0ff 0%, #f5f8ff 55%, #eef4ff 100%);
    background-size: auto, auto, auto, 18px 18px, auto;
    color: var(--colore-testo);
    font-family: var(--font-stack);
    font-size: 14px;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
}

button { font-family: inherit; cursor: pointer; }
input, textarea, select { font-family: inherit; font-size: inherit; }

ul { padding-left: 1.2em; }

/* ---------------------------------------------------------------------
   3. Header in alto
   --------------------------------------------------------------------- */
.te-header {
    display: flex;
    align-items: center;
    gap: var(--spazio-md);
    background: linear-gradient(180deg, #1e3a8a 0%, #1e40af 100%);
    border-bottom: 1px solid rgba(255, 255, 255, 0.10);
    padding: 14px var(--spazio-lg);
    box-shadow: 0 8px 24px rgba(2, 6, 23, 0.25);
    position: sticky;
    top: 0;
    z-index: 10;
}

.te-header__brand {
    display: flex;
    align-items: center;
    gap: var(--spazio-md);
}

.te-header__logo {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.18);
    color: white;
    font-weight: 700;
    font-size: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.te-header__titles h1 {
    font-size: 18px;
    font-weight: 700;
    line-height: 1.1;
    color: #ffffff;
}

.te-header__sottotitolo {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.75);
}

.te-header__pratica {
    flex: 1;
    margin: 0 var(--spazio-lg);
    padding: var(--spazio-sm) var(--spazio-md);
    background: rgba(255, 255, 255, 0.10);
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 999px;
    font-size: 13px;
    min-height: 44px;
    display: flex;
    align-items: center;
    gap: var(--spazio-md);
    flex-wrap: wrap;
}

.te-header__pratica strong {
    color: #ffffff;
}

.te-header__pratica .te-vuoto {
    color: rgba(255, 255, 255, 0.75);
    font-style: normal;
}

.te-header__azioni {
    display: flex;
    gap: var(--spazio-sm);
}

/* ---------------------------------------------------------------------
   4. Layout principale a due colonne
   --------------------------------------------------------------------- */
.te-main {
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
    gap: var(--spazio-lg);
    padding: var(--spazio-lg);
    max-width: 1360px;
    margin: 0 auto;
    align-items: start;
}

.te-colonna {
    display: flex;
    flex-direction: column;
    gap: var(--spazio-md);
    min-width: 0;
}

.te-colonna--dx {
    position: sticky;
    top: 90px; /* sotto l'header */
    /* Calcoliamo l'altezza per occupare il viewport rimanente */
    height: calc(100vh - 90px - var(--spazio-lg));
}

/* Su schermi stretti torniamo a colonna unica */
@media (max-width: 1100px) {
    .te-main {
        grid-template-columns: 1fr;
    }
    .te-colonna--dx {
        position: static;
        height: 600px;
    }
}

/* ---------------------------------------------------------------------
   5. Card (componente base ovunque)
   --------------------------------------------------------------------- */
.te-card {
    background: var(--colore-card);
    border: 1px solid var(--colore-bordo);
    border-radius: var(--raggio);
    box-shadow: var(--ombra-card);
    overflow: hidden;
}

.te-card--full {
    height: 100%;
    display: flex;
    flex-direction: column;
}

.te-card__header {
    display: flex;
    align-items: center;
    gap: var(--spazio-sm);
    padding: var(--spazio-md);
    border-bottom: 1px solid var(--colore-bordo-soft);
}

.te-card__icona {
    font-size: 18px;
}

.te-card__header h2 {
    font-size: 14px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--colore-testo);
    flex: 1;
}

.te-card__azione {
    margin-left: auto;
}

.te-card__body {
    padding: var(--spazio-md);
}

.te-help {
    color: var(--colore-help);
    font-size: 13px;
    font-style: italic;
}

/* ---------------------------------------------------------------------
   6. Pulsanti
   --------------------------------------------------------------------- */
.te-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    border: 1px solid var(--colore-bordo);
    border-radius: var(--raggio);
    background: var(--colore-card);
    color: var(--colore-testo);
    font-size: 13px;
    font-weight: 500;
    transition: all 0.15s ease;
    white-space: nowrap;
}

.te-btn:hover:not(:disabled) {
    background: var(--colore-bg);
    border-color: var(--colore-primario);
}

.te-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.te-btn--primary {
    background: var(--colore-primario);
    color: white;
    border-color: var(--colore-primario);
}

.te-btn--primary:hover:not(:disabled) {
    background: var(--colore-primario-hover);
    border-color: var(--colore-primario-hover);
}

.te-btn--secondary {
    background: var(--colore-card);
}

.te-header .te-btn--secondary {
    background: rgba(255, 255, 255, 0.10);
    border-color: rgba(255, 255, 255, 0.18);
    color: #ffffff;
}

.te-header .te-btn--secondary:hover:not(:disabled) {
    background: rgba(255, 255, 255, 0.14);
    border-color: rgba(255, 255, 255, 0.22);
}

.te-btn--small {
    padding: 4px 10px;
    font-size: 12px;
}

.te-link {
    background: none;
    border: none;
    color: var(--colore-primario);
    font-size: 13px;
    text-decoration: none;
    padding: 4px 8px;
    border-radius: var(--raggio);
}

.te-link:hover {
    background: var(--colore-bg);
    text-decoration: underline;
}

/* ---------------------------------------------------------------------
   7. Tab in cima alla card di destra
   --------------------------------------------------------------------- */
.te-tabs {
    display: flex;
    border-bottom: 1px solid var(--colore-bordo-soft);
    flex-shrink: 0;
    padding: 10px 10px 0 10px;
    gap: 8px;
}

.te-tab {
    background: rgba(29, 78, 216, 0.08);
    border: 1px solid rgba(29, 78, 216, 0.14);
    padding: 8px 12px;
    color: #1e3a8a;
    font-size: 12px;
    font-weight: 700;
    text-transform: none;
    letter-spacing: 0;
    border-radius: 999px;
    transition: all 0.15s;
}

.te-tab:hover {
    background: rgba(29, 78, 216, 0.12);
}

.te-tab--attivo {
    background: var(--colore-primario);
    border-color: var(--colore-primario);
    color: #ffffff;
}

.te-tab-panel {
    display: none;
    flex: 1;
    flex-direction: column;
    min-height: 0;
}

.te-tab-panel--attivo {
    display: flex;
}

/* ---------------------------------------------------------------------
   8. Chat (colonna destra)
   --------------------------------------------------------------------- */
.te-chat__messaggi {
    flex: 1;
    overflow-y: auto;
    padding: var(--spazio-md);
    display: flex;
    flex-direction: column;
    gap: var(--spazio-md);
}

.te-chat__benvenuto {
    background: var(--colore-bg);
    border-left: 3px solid var(--colore-primario);
    padding: var(--spazio-md);
    border-radius: var(--raggio);
    font-size: 13px;
}

.te-chat__benvenuto ul {
    margin-top: var(--spazio-sm);
}

.te-chat__messaggio {
    max-width: 85%;
    padding: var(--spazio-sm) var(--spazio-md);
    border-radius: 10px;
    font-size: 13px;
    word-wrap: break-word;
    line-height: 1.5;
}

.te-chat__messaggio--utente {
    align-self: flex-end;
    background: var(--colore-primario);
    color: white;
    border-bottom-right-radius: 2px;
}

.te-chat__messaggio--assistente {
    align-self: flex-start;
    background: var(--colore-bg);
    color: var(--colore-testo);
    border: 1px solid var(--colore-bordo-soft);
    border-bottom-left-radius: 2px;
}

.te-chat__messaggio pre {
    background: rgba(0, 0, 0, 0.05);
    padding: var(--spazio-sm);
    border-radius: var(--raggio);
    overflow-x: auto;
    font-family: var(--font-mono);
    font-size: 12px;
    margin: var(--spazio-sm) 0;
}

.te-chat__messaggio code {
    font-family: var(--font-mono);
    font-size: 12px;
}

.te-chat__input {
    display: flex;
    gap: var(--spazio-sm);
    padding: var(--spazio-md);
    border-top: 1px solid var(--colore-bordo-soft);
    flex-shrink: 0;
}

.te-chat__input textarea {
    flex: 1;
    border: 1px solid var(--colore-bordo);
    border-radius: var(--raggio);
    padding: var(--spazio-sm);
    resize: vertical;
    min-height: 40px;
    max-height: 120px;
}

.te-chat__input textarea:focus {
    outline: none;
    border-color: var(--colore-primario);
    box-shadow: 0 0 0 3px rgba(0, 112, 210, 0.15);
}

/* ---------------------------------------------------------------------
   9. Modali
   --------------------------------------------------------------------- */
.te-modale {
    display: none;
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 100;
    align-items: center;
    justify-content: center;
    padding: var(--spazio-lg);
}

.te-modale--aperta {
    display: flex;
}

.te-modale__contenuto {
    background: var(--colore-card);
    border-radius: var(--raggio-lg);
    box-shadow: var(--ombra-modale);
    width: 100%;
    max-width: 600px;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
}

.te-modale__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spazio-md) var(--spazio-lg);
    border-bottom: 1px solid var(--colore-bordo-soft);
}

.te-modale__header h3 {
    font-size: 16px;
    font-weight: 700;
}

.te-modale__chiudi {
    background: none;
    border: none;
    font-size: 24px;
    color: var(--colore-help);
    width: 32px;
    height: 32px;
    border-radius: 50%;
}

.te-modale__chiudi:hover {
    background: var(--colore-bg);
}

.te-modale__body {
    padding: var(--spazio-lg);
    overflow-y: auto;
}

.te-debug-pre {
    white-space: pre-wrap;
    word-break: break-word;
    font-family: var(--font-mono);
    font-size: 12px;
    background: var(--colore-bg);
    border: 1px solid var(--colore-bordo-soft);
    border-radius: var(--raggio);
    padding: var(--spazio-md);
    max-height: 65vh;
    overflow: auto;
}

/* ---------------------------------------------------------------------
   10. Form
   --------------------------------------------------------------------- */
.te-form__riga {
    margin-bottom: var(--spazio-md);
}

.te-form__riga label {
    display: block;
    font-size: 12px;
    font-weight: 600;
    color: var(--colore-testo);
    margin-bottom: 4px;
}

.te-form__riga input,
.te-form__riga textarea,
.te-form__riga select {
    width: 100%;
    padding: 8px 12px;
    border: 1px solid var(--colore-bordo);
    border-radius: var(--raggio);
    background: var(--colore-card);
    transition: border-color 0.15s;
}

.te-form__riga input:focus,
.te-form__riga textarea:focus,
.te-form__riga select:focus {
    outline: none;
    border-color: var(--colore-primario);
    box-shadow: 0 0 0 3px rgba(0, 112, 210, 0.15);
}

.te-form__riga--due {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spazio-md);
}

.te-form__azioni {
    display: flex;
    justify-content: flex-end;
    gap: var(--spazio-sm);
    margin-top: var(--spazio-lg);
    padding-top: var(--spazio-md);
    border-top: 1px solid var(--colore-bordo-soft);
}

/* ---------------------------------------------------------------------
   11. Lista pratiche nella modale
   --------------------------------------------------------------------- */
.te-pratica-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spazio-md);
    border: 1px solid var(--colore-bordo);
    border-radius: var(--raggio);
    margin-bottom: var(--spazio-sm);
    cursor: pointer;
    transition: all 0.15s;
}

.te-pratica-item:hover {
    border-color: var(--colore-primario);
    background: var(--colore-bg);
}

.te-pratica-item__info strong {
    display: block;
    color: var(--colore-testo);
    margin-bottom: 4px;
}

.te-pratica-item__info span {
    font-size: 12px;
    color: var(--colore-testo-soft);
}

.te-badge {
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
}

.te-badge--aperta { background: #e0f3ff; color: #0070d2; }
.te-badge--in_corso { background: #fff5d6; color: #c47e00; }
.te-badge--chiusa { background: #e8f5e8; color: #2e844a; }

/* ---------------------------------------------------------------------
   12. Card dati pratica (sinistra)
   --------------------------------------------------------------------- */
.te-dati-griglia {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--spazio-md);
}

.te-dati-griglia__campo label {
    display: block;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    color: var(--colore-testo-soft);
    letter-spacing: 0.04em;
    margin-bottom: 2px;
}

.te-dati-griglia__campo span {
    color: var(--colore-testo);
    font-size: 14px;
}

/* ---------------------------------------------------------------------
   13. Questionario - una "riga" per ogni domanda
   --------------------------------------------------------------------- */
.te-domanda {
    border: 1px solid var(--colore-bordo);
    border-radius: var(--raggio);
    margin-bottom: var(--spazio-md);
    overflow: hidden;
}

.te-domanda__header {
    display: flex;
    align-items: center;
    gap: var(--spazio-sm);
    padding: var(--spazio-sm) var(--spazio-md);
    background: var(--colore-bg);
    border-bottom: 1px solid var(--colore-bordo-soft);
}

.te-domanda__tipo {
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
}

.te-domanda__tipo--domanda_killer { background: #ffe0e0; color: #c23934; }
.te-domanda__tipo--red_flag { background: #fff5d6; color: #c47e00; }
.te-domanda__tipo--check_evidenza { background: #e0f3ff; color: #0070d2; }

.te-domanda__rif {
    font-size: 12px;
    color: var(--colore-testo-soft);
    font-family: var(--font-mono);
}

.te-domanda__body {
    padding: var(--spazio-md);
}

.te-domanda__testo {
    font-weight: 500;
    margin-bottom: var(--spazio-sm);
}

.te-domanda__sugg {
    background: #fffceb;
    border-left: 3px solid var(--colore-warning);
    padding: var(--spazio-sm);
    font-size: 12px;
    color: var(--colore-testo-soft);
    margin-bottom: var(--spazio-sm);
    border-radius: var(--raggio);
}

.te-domanda__risposta {
    width: 100%;
    border: 1px solid var(--colore-bordo);
    border-radius: var(--raggio);
    padding: var(--spazio-sm);
    min-height: 60px;
    margin-bottom: var(--spazio-sm);
}

.te-domanda__azioni {
    display: flex;
    gap: var(--spazio-sm);
    flex-wrap: wrap;
    align-items: center;
}

.te-domanda__valutazione {
    margin-top: var(--spazio-sm);
    padding: var(--spazio-sm);
    background: var(--colore-bg);
    border-radius: var(--raggio);
    font-size: 12px;
    border-left: 3px solid var(--colore-primario);
}

/* ---------------------------------------------------------------------
   14. Rilievi (output Pipeline)
   --------------------------------------------------------------------- */
.te-rilievo {
    border-left: 4px solid var(--colore-bordo);
    padding: var(--spazio-md);
    background: var(--colore-bg);
    border-radius: var(--raggio);
    margin-bottom: var(--spazio-sm);
}

.te-rilievo--NC  { border-left-color: var(--colore-error); }
.te-rilievo--NCm { border-left-color: var(--colore-warning); }
.te-rilievo--OSS { border-left-color: var(--colore-primario); }

.te-rilievo__intestazione {
    display: flex;
    gap: var(--spazio-sm);
    align-items: center;
    margin-bottom: var(--spazio-sm);
}

.te-rilievo__tipo {
    padding: 2px 10px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 700;
    color: white;
}
.te-rilievo__tipo--NC  { background: var(--colore-error); }
.te-rilievo__tipo--NCm { background: var(--colore-warning); }
.te-rilievo__tipo--OSS { background: var(--colore-primario); }

/* ---------------------------------------------------------------------
   15. Toast notifiche
   --------------------------------------------------------------------- */
.te-toast {
    position: fixed;
    bottom: var(--spazio-lg);
    left: 50%;
    transform: translateX(-50%) translateY(100px);
    background: var(--colore-testo);
    color: white;
    padding: var(--spazio-sm) var(--spazio-lg);
    border-radius: var(--raggio);
    font-size: 13px;
    box-shadow: var(--ombra-modale);
    z-index: 200;
    opacity: 0;
    transition: all 0.3s;
    pointer-events: none;
    max-width: 80vw;
}

.te-toast--visibile {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
    pointer-events: auto;
}

.te-toast--errore { background: var(--colore-error); }
.te-toast--successo { background: var(--colore-success); }
.te-toast--info { background: var(--colore-info, #0070d2); }

/* ---------------------------------------------------------------------
   16. Spinner globale
   --------------------------------------------------------------------- */
.te-spinner {
    display: none;
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(255, 255, 255, 0.85);
    z-index: 150;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--spazio-md);
}

.te-spinner--visibile {
    display: flex;
}

.te-spinner__cerchio {
    width: 48px;
    height: 48px;
    border: 4px solid var(--colore-bordo);
    border-top-color: var(--colore-primario);
    border-radius: 50%;
    animation: te-rotazione 0.8s linear infinite;
}

@keyframes te-rotazione {
    to { transform: rotate(360deg); }
}

.te-spinner__testo {
    color: var(--colore-testo);
    font-weight: 600;
}

/* ---------------------------------------------------------------------
   17. Report Markdown rendering
   --------------------------------------------------------------------- */
.te-report {
    padding: var(--spazio-lg);
    overflow-y: auto;
    font-size: 14px;
    line-height: 1.7;
}

.te-report h1, .te-report h2, .te-report h3 {
    margin: var(--spazio-lg) 0 var(--spazio-sm) 0;
    color: var(--colore-testo);
}

.te-report h1 { font-size: 22px; border-bottom: 2px solid var(--colore-primario); padding-bottom: 6px; }
.te-report h2 { font-size: 18px; }
.te-report h3 { font-size: 15px; }

.te-report p { margin-bottom: var(--spazio-md); }

.te-report ul, .te-report ol {
    margin-bottom: var(--spazio-md);
    padding-left: 2em;
}

.te-report code {
    background: var(--colore-bg);
    padding: 1px 6px;
    border-radius: 3px;
    font-family: var(--font-mono);
    font-size: 13px;
}

.te-report pre {
    background: var(--colore-bg);
    padding: var(--spazio-md);
    border-radius: var(--raggio);
    overflow-x: auto;
    margin: var(--spazio-md) 0;
}

.te-report table {
    border-collapse: collapse;
    width: 100%;
    margin: var(--spazio-md) 0;
}

.te-report th, .te-report td {
    border: 1px solid var(--colore-bordo);
    padding: var(--spazio-sm);
    text-align: left;
}

.te-report th {
    background: var(--colore-bg);
    font-weight: 600;
}

/* ---------------------------------------------------------------------
   18. Utility
   --------------------------------------------------------------------- */
.te-flex { display: flex; gap: var(--spazio-sm); align-items: center; }
.te-mt-md { margin-top: var(--spazio-md); }
.te-mb-md { margin-bottom: var(--spazio-md); }
.te-text-soft { color: var(--colore-testo-soft); }
.te-text-help { color: var(--colore-help); font-size: 12px; }

/* ---------------------------------------------------------------------
   19. Classi aggiunte: dati, esiti, valutazioni evidenze, vuoti, msg
   --------------------------------------------------------------------- */
.te-dato {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.te-dato--full { grid-column: 1 / -1; }
.te-dato__label {
    font-size: 11px;
    text-transform: uppercase;
    color: var(--colore-testo-soft);
    letter-spacing: 0.5px;
}
.te-dato__valore {
    font-size: 14px;
    color: var(--colore-testo);
    font-weight: 500;
}
.te-dati-griglia {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spazio-md);
    margin-bottom: var(--spazio-md);
}

/* Upload visura camerale */
.te-upload {
    display: flex;
    align-items: center;
    gap: var(--spazio-sm);
    padding: var(--spazio-sm);
    background: var(--colore-bg);
    border-radius: var(--raggio-md);
}
.te-upload__label {
    font-size: 12px;
    font-weight: 600;
    color: var(--colore-testo-soft);
}
.te-upload__file {
    flex: 1;
    font-size: 13px;
    color: var(--colore-testo);
    word-break: break-all;
}
.te-upload__file--vuoto {
    color: var(--colore-testo-soft);
    font-style: italic;
}

/* Stato vuoto */
.te-vuoto {
    color: var(--colore-testo-soft);
    font-size: 13px;
    text-align: center;
    padding: var(--spazio-md);
    font-style: italic;
}
.te-vuoto-grande {
    text-align: center;
    padding: var(--spazio-xl);
    color: var(--colore-testo-soft);
}
.te-vuoto-grande p {
    margin-bottom: var(--spazio-sm);
    font-size: 14px;
}

/* Gruppi domande questionario */
.te-gruppo-domande {
    margin-bottom: var(--spazio-lg);
}
.te-gruppo-domande__titolo {
    font-size: 13px;
    font-weight: 700;
    color: var(--colore-testo);
    margin-bottom: var(--spazio-sm);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.te-gruppo-domande__lista {
    display: flex;
    flex-direction: column;
    gap: var(--spazio-md);
}

.te-domanda {
    background: var(--colore-bg);
    border: 1px solid var(--colore-bordo-soft);
    border-radius: var(--raggio-md);
    padding: var(--spazio-md);
}
.te-domanda__head {
    margin-bottom: var(--spazio-sm);
}
.te-domanda__testo {
    font-size: 14px;
    color: var(--colore-testo);
    margin-bottom: var(--spazio-sm);
    line-height: 1.5;
}
.te-domanda__suggerimento {
    font-size: 12px;
    color: var(--colore-testo-soft);
    background: #fff7e6;
    padding: var(--spazio-sm);
    border-radius: var(--raggio-sm);
    margin-bottom: var(--spazio-sm);
    border-left: 3px solid #ffc547;
}
.te-domanda__risposta {
    width: 100%;
    min-height: 60px;
    padding: var(--spazio-sm);
    font: inherit;
    font-size: 13px;
    border: 1px solid var(--colore-bordo);
    border-radius: var(--raggio-sm);
    resize: vertical;
    margin-bottom: var(--spazio-sm);
}
.te-domanda__risposta:focus {
    outline: none;
    border-color: var(--colore-primary);
}
.te-domanda__azioni {
    display: flex;
    gap: var(--spazio-sm);
    flex-wrap: wrap;
    align-items: center;
}

/* Badge tipologia domande */
.te-badge--domanda_killer { background: #fde2e2; color: #c0392b; }
.te-badge--red_flag { background: #fff3cd; color: #c47e00; }
.te-badge--check_evidenza { background: #d8f0e1; color: #276848; }
.te-badge--bozza { background: #e0f3ff; color: #0070d2; }
.te-badge--finale { background: #d8f0e1; color: #276848; }

/* Valutazione AI sull'evidenza caricata */
.te-valutazione {
    margin-top: var(--spazio-sm);
    padding: var(--spazio-sm) var(--spazio-md);
    border-radius: var(--raggio-sm);
    font-size: 12px;
    border-left: 3px solid;
}
.te-valutazione strong { display: block; margin-bottom: 4px; }
.te-valutazione p { margin: 4px 0; line-height: 1.4; }
.te-valutazione--ok {
    background: #e8f7ee;
    border-color: var(--colore-success);
    color: #245d33;
}
.te-valutazione--ko {
    background: #fff4e5;
    border-color: #c47e00;
    color: #7a4f00;
}

/* Esiti pipeline / report */
.te-esito--ok { color: var(--colore-success); font-weight: 600; }
.te-esito--warning { color: #c47e00; font-weight: 600; }
.te-esito--ko { color: var(--colore-error); font-weight: 600; }
.te-esito--neutro { color: var(--colore-testo-soft); font-weight: 600; }

/* Card Pipeline a sinistra */
.te-pipeline-stato p {
    font-size: 13px;
    margin-bottom: 6px;
}

/* Report */
.te-report__head {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spazio-sm);
    align-items: center;
    margin-bottom: var(--spazio-md);
    padding-bottom: var(--spazio-sm);
    border-bottom: 1px solid var(--colore-bordo-soft);
}
.te-report__meta {
    font-size: 12px;
    color: var(--colore-testo-soft);
}
.te-report__body {
    line-height: 1.6;
    color: var(--colore-testo);
}
.te-report__body h1, .te-report__body h2, .te-report__body h3 {
    margin-top: var(--spazio-md);
    margin-bottom: var(--spazio-sm);
}

/* Lista pratiche aperta nella modale */
.te-pratica-riga {
    padding: var(--spazio-md);
    border: 1px solid var(--colore-bordo-soft);
    border-radius: var(--raggio-md);
    margin-bottom: var(--spazio-sm);
    cursor: pointer;
    transition: all 0.15s ease;
}
.te-pratica-riga:hover {
    border-color: var(--colore-primary);
    background: var(--colore-bg);
}
.te-pratica-riga__main {
    display: flex;
    gap: var(--spazio-sm);
    align-items: baseline;
    margin-bottom: 4px;
}
.te-pratica-riga__main strong {
    color: var(--colore-primary);
    font-size: 14px;
}
.te-pratica-riga__main span {
    font-size: 14px;
    color: var(--colore-testo);
}
.te-pratica-riga__meta {
    font-size: 12px;
    color: var(--colore-testo-soft);
    display: flex;
    gap: var(--spazio-sm);
    align-items: center;
    flex-wrap: wrap;
}

/* Messaggi chat */
.te-msg { margin-bottom: var(--spazio-md); }
.te-msg--utente { text-align: right; }
.te-msg__bolla {
    display: inline-block;
    max-width: 85%;
    padding: var(--spazio-sm) var(--spazio-md);
    border-radius: var(--raggio-md);
    text-align: left;
    line-height: 1.5;
    font-size: 14px;
}
.te-msg--utente .te-msg__bolla {
    background: var(--colore-primary);
    color: white;
}
.te-msg--assistente .te-msg__bolla {
    background: var(--colore-bg);
    color: var(--colore-testo);
    border: 1px solid var(--colore-bordo-soft);
}
.te-msg--sistema .te-msg__bolla {
    background: #fff7e6;
    color: var(--colore-testo);
    font-style: italic;
    font-size: 12px;
}
.te-msg__bolla p { margin: 0 0 6px; }
.te-msg__bolla p:last-child { margin: 0; }
.te-msg__bolla code {
    background: rgba(0, 0, 0, 0.1);
    padding: 1px 4px;
    border-radius: 3px;
    font-size: 12px;
}
.te-msg--utente .te-msg__bolla code { background: rgba(255, 255, 255, 0.25); }
.te-msg__meta {
    font-size: 11px;
    color: var(--colore-testo-soft);
    margin-top: 4px;
}

.te-chat__benvenuto {
    background: var(--colore-bg);
    padding: var(--spazio-lg);
    border-radius: var(--raggio-md);
    border: 1px dashed var(--colore-bordo);
}
.te-chat__benvenuto h4 {
    margin-bottom: var(--spazio-sm);
    color: var(--colore-primary);
}
.te-chat__benvenuto ul {
    margin: var(--spazio-sm) 0 var(--spazio-sm) var(--spazio-md);
}
.te-chat__benvenuto li {
    margin-bottom: 4px;
    font-size: 13px;
    color: var(--colore-testo);
}

/* Link riusato dalle card */
.te-link {
    background: none;
    border: none;
    color: var(--colore-primary);
    cursor: pointer;
    font: inherit;
    font-size: 13px;
    padding: 0;
}
.te-link:hover { text-decoration: underline; }
