@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

:root {
    --color-primari:       #be3a34;
    --color-primari-fosc:  #9f2f2b;
    --color-primari-clar:  #f4d6d5;
    --color-fons-app:      #f6eceb;
    --color-sidebar:       #fdf6f5;
    --color-topbar:        #ffffff;
    --color-superficie:    #ffffff;
    --color-superficie-tint: #f9edec;
    --color-borde:         #e3b8b7;
    --color-borde-suau:    #eededd;
    --color-text:          #1f1716;
    --color-text-suau:     #6a514f;
    --color-ombra:         rgba(63, 20, 18, 0.10);
    --amplada-sidebar:     260px;
    --alzada-topbar:       64px;
    --radi:                .5rem;
}

*,
*::before,
*::after { box-sizing: border-box; }

body {
    margin: 0;
    background: var(--color-fons-app);
    color: var(--color-text);
    font-family: Inter, "Segoe UI", "Helvetica Neue", Arial, sans-serif;
    font-size: 1rem;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
}

a { color: var(--color-primari); }

/* ─── PÀGINA DE SESSIÓ (login / sense sessió) ────────────────────────────── */

.cos-sessio {
    min-height: 100vh;
    background: var(--color-fons-app);
}

.pantalla-sessio {
    min-height: 100vh;
    display: grid;
    grid-template-columns: minmax(320px, 56%) minmax(380px, 44%);
    background: var(--color-fons-app);
}

.sessio-imatge {
    position: relative;
    min-height: 100vh;
    overflow: hidden;
}

.sessio-imatge::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(160deg, rgba(159,47,43,.18), rgba(35,14,13,.28));
    pointer-events: none;
}

.sessio-imatge img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.sessio-panell {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: clamp(1.5rem, 3.8vw, 3.5rem);
    background: var(--color-superficie);
}

.sessio-panell-contingut {
    width: min(100%, 440px);
}

.sessio-capcalera {
    margin-bottom: clamp(1rem, 2.6vw, 1.8rem);
}

.sessio-logo {
    display: block;
    width: min(100%, 340px);
    height: auto;
}

.sessio-titol {
    margin: 0;
    font-size: clamp(1.25rem, 2vw, 1.75rem);
    font-weight: 700;
    color: var(--color-text);
    line-height: 1.2;
}

.sessio-subtitol {
    margin: .25rem 0 1.1rem;
    font-size: clamp(.9rem, 1.2vw, 1rem);
    color: var(--color-text-suau);
}

.sessio-alerta {
    border-radius: var(--radi);
    margin-bottom: 1.1rem;
}

.formulari-sessio {
    display: flex;
    flex-direction: column;
    gap: 1.1rem;
}

.camp-sessio {
    display: flex;
    flex-direction: column;
    gap: .4rem;
}

.fila-etiqueta-sessio {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: .75rem;
}

.formulari-sessio .form-label {
    margin: 0;
    font-size: .95rem;
    font-weight: 600;
    color: var(--color-text);
}

.enllac-sessio-secundari {
    font-size: .86rem;
    font-weight: 600;
    color: var(--color-primari);
    text-decoration: none;
}

.enllac-sessio-secundari:hover {
    color: var(--color-primari-fosc);
    text-decoration: underline;
}

.formulari-sessio .form-control {
    height: 52px;
    border: 1.5px solid var(--color-borde);
    border-radius: var(--radi);
    background: var(--color-fons-app);
    padding: 0 .9rem;
    font-size: 1rem;
    color: var(--color-text);
    transition: border-color .15s, box-shadow .15s;
}

.formulari-sessio .form-control:focus {
    border-color: var(--color-primari);
    background: var(--color-superficie);
    box-shadow: 0 0 0 .2rem rgba(190, 58, 52, .18);
    outline: none;
}

.sessio-accions {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    margin-top: .25rem;
}

.boto-sessio.btn-primary {
    --bs-btn-color: #fff;
    --bs-btn-bg: var(--color-primari);
    --bs-btn-border-color: var(--color-primari);
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: var(--color-primari-fosc);
    --bs-btn-hover-border-color: var(--color-primari-fosc);
    --bs-btn-active-bg: var(--color-primari-fosc);
    --bs-btn-focus-shadow-rgb: 190, 58, 52;
    min-width: 200px;
    padding: .7rem 1.3rem;
    border-radius: var(--radi);
    font-size: 1rem;
    font-weight: 600;
}

.boto-sessio-secundari.btn {
    min-width: 200px;
    padding: .7rem 1.3rem;
    border-radius: var(--radi);
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-text-suau);
    border-color: var(--color-borde);
}

.boto-sessio-secundari.btn:hover {
    background: var(--color-fons-app);
    border-color: var(--color-primari);
    color: var(--color-primari);
}

/* ─── APP SHELL ──────────────────────────────────────────────────────────── */

.app-shell {
    display: grid;
    grid-template-columns: var(--amplada-sidebar) minmax(0, 1fr);
    min-height: 100vh;
}

.app-sidebar {
    background: var(--color-sidebar);
    border-right: 1px solid var(--color-borde);
    padding: 1.25rem 1rem;
    display: flex;
    flex-direction: column;
}

.app-brand {
    display: flex;
    align-items: center;
    gap: .75rem;
    text-decoration: none;
    font-weight: 700;
    font-size: 1.05rem;
    color: var(--color-text);
    min-height: 2.5rem;
    padding: .25rem .5rem;
}

.app-brand-icona {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.2rem;
    height: 2.2rem;
    border-radius: .45rem;
    background: var(--color-primari);
    color: #fff;
    font-size: 1.1rem;
    flex-shrink: 0;
}

.app-nav {
    display: flex;
    flex-direction: column;
    gap: .2rem;
    margin-top: 1.75rem;
    flex: 1;
}

.app-nav a {
    display: flex;
    align-items: center;
    gap: .65rem;
    color: var(--color-text-suau);
    text-decoration: none;
    padding: .6rem .75rem;
    border-radius: var(--radi);
    font-size: .95rem;
    font-weight: 500;
    transition: background .12s, color .12s;
}

.app-nav a:hover {
    background: var(--color-primari-clar);
    color: var(--color-primari-fosc);
}

.app-nav a.app-nav-sub {
    margin-left: .55rem;
    padding-left: 1rem;
    font-size: .9rem;
}

.app-nav a.app-nav-sub i {
    font-size: .95rem;
}

.app-nav a.actiu {
    background: var(--color-primari-clar);
    color: var(--color-primari);
    font-weight: 600;
}

.app-nav a.actiu i {
    color: var(--color-primari);
}

.app-nav-separador {
    display: block;
    height: 1px;
    margin: .6rem .5rem;
    background: var(--color-borde);
}

.app-main {
    min-width: 0;
    display: flex;
    flex-direction: column;
}

.app-topbar {
    height: var(--alzada-topbar);
    background: var(--color-topbar);
    border-bottom: 1px solid var(--color-borde);
    padding: 0 1.5rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    position: sticky;
    top: 0;
    z-index: 100;
}

.topbar-titol {
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--color-text);
}

.topbar-subt {
    font-size: .82rem;
    color: var(--color-text-suau);
}

.topbar-usuari {
    display: flex;
    align-items: center;
    gap: .85rem;
}

.llancador-aplicacions {
    flex-shrink: 0;
}

.llancador-aplicacions-boto {
    width: 2.35rem;
    height: 2.35rem;
    display: inline-grid;
    place-items: center;
    border: 0;
    border-radius: var(--radi);
    background: var(--color-primari);
    color: #fff;
    padding: 0;
    box-shadow: 0 2px 8px var(--color-ombra);
    transition: background .12s, transform .12s;
}

.llancador-aplicacions-boto:hover,
.llancador-aplicacions-boto:focus-visible {
    background: var(--color-primari-fosc);
    transform: translateY(-1px);
    outline: none;
}

.llancador-punts {
    width: 1.05rem;
    height: 1.05rem;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: .22rem;
}

.llancador-punts span {
    width: .18rem;
    height: .18rem;
    border-radius: 50%;
    background: currentColor;
}

.llancador-aplicacions-menu {
    width: min(20rem, calc(100vw - 2rem));
    border: 1px solid var(--color-borde);
    border-radius: var(--radi);
    box-shadow: 0 12px 30px rgba(63, 20, 18, .16);
    padding: .65rem;
}

.llancador-aplicacions-titol {
    padding: .25rem .35rem .6rem;
    font-size: .82rem;
    font-weight: 700;
    color: var(--color-text-suau);
    text-transform: uppercase;
    letter-spacing: .03em;
}

.llancador-aplicacions-element {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: .75rem;
    padding: .7rem;
    border-radius: var(--radi);
    color: var(--color-text);
    text-decoration: none;
}

.llancador-aplicacions-element:hover,
.llancador-aplicacions-element:focus-visible {
    background: var(--color-fons-app);
    color: var(--color-text);
    outline: none;
}

.llancador-aplicacions-element.es-actual {
    background: var(--color-superficie-tint);
}

.llancador-aplicacions-icona {
    width: 2rem;
    height: 2rem;
    display: inline-grid;
    place-items: center;
    border-radius: var(--radi);
    background: var(--color-primari-clar);
    color: var(--color-primari-fosc);
}

.llancador-aplicacions-text {
    min-width: 0;
    display: grid;
    line-height: 1.2;
    font-weight: 650;
}

.llancador-aplicacions-text small {
    color: var(--color-text-suau);
    font-weight: 400;
}

.llancador-aplicacions-actual {
    padding: .16rem .45rem;
    border-radius: 999px;
    background: var(--color-primari);
    color: #fff;
    font-size: .72rem;
    font-weight: 700;
}

.topbar-avatar {
    width: 2.1rem;
    height: 2.1rem;
    border-radius: 50%;
    background: var(--color-primari);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: .9rem;
    flex-shrink: 0;
}

.app-content {
    padding: 1.5rem;
    flex: 1;
}

/* ─── BOTONS CORPORATIUS ─────────────────────────────────────────────────── */

.btn-primary {
    --bs-btn-color: #fff;
    --bs-btn-bg: var(--color-primari);
    --bs-btn-border-color: var(--color-primari);
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: var(--color-primari-fosc);
    --bs-btn-hover-border-color: var(--color-primari-fosc);
    --bs-btn-active-bg: var(--color-primari-fosc);
    --bs-btn-focus-shadow-rgb: 190, 58, 52;
}

.btn-outline-primary {
    --bs-btn-color: var(--color-primari);
    --bs-btn-border-color: var(--color-primari);
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: var(--color-primari);
    --bs-btn-hover-border-color: var(--color-primari);
    --bs-btn-active-bg: var(--color-primari-fosc);
}

/* ─── TARGETES I PANELLS ─────────────────────────────────────────────────── */

.panel {
    background: var(--color-superficie);
    border: 1px solid var(--color-borde);
    border-radius: var(--radi);
    overflow: hidden;
}

.panel-header {
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--color-borde);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
}

.panel-header h2 {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
}

.panel-cos {
    padding: 1.25rem;
}

/* ─── RESUM (tiles) ──────────────────────────────────────────────────────── */

.resum-graella {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: .75rem;
}

.resum-tile {
    background: var(--color-superficie);
    border: 1px solid var(--color-borde);
    border-radius: var(--radi);
    padding: 1rem 1.1rem;
    display: flex;
    flex-direction: column;
    gap: .2rem;
}

.resum-tile {
    cursor: pointer;
    transition: box-shadow .12s, border-color .12s;
}

.resum-tile:hover {
    box-shadow: 0 2px 8px var(--color-ombra);
}

.resum-tile--actiu {
    border-left: 3px solid var(--color-primari);
}

.resum-tile--seleccionat {
    border-left: 3px solid var(--color-primari);
    background: var(--color-primari-clar);
}

.resum-etiqueta {
    font-size: .8rem;
    font-weight: 500;
    color: var(--color-text-suau);
    text-transform: uppercase;
    letter-spacing: .03em;
}

.resum-valor {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.1;
    color: var(--color-text);
}

.summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: .75rem;
}

.summary-tile {
    min-height: 5.75rem;
    background: var(--color-superficie);
    border: 1px solid var(--color-borde);
    border-radius: var(--radi);
    padding: 1rem 1.1rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: .2rem;
}

.summary-value {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.1;
    color: var(--color-text);
}

/* ─── LLISTA D'INCIDÈNCIES ───────────────────────────────────────────────── */

.inc-llista {
    background: var(--color-superficie);
    border: 1px solid var(--color-borde);
    border-radius: var(--radi);
    overflow: hidden;
}

.inc-llista-cap {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: .65rem 1.1rem;
    border-bottom: 1px solid var(--color-borde);
    background: var(--color-fons-app);
}

.inc-llista-total {
    font-size: .82rem;
    font-weight: 600;
    color: var(--color-text-suau);
}

.inc-llista-cerca-activa {
    font-size: .8rem;
    color: var(--color-primari);
    font-style: italic;
}

.inc-llista-llegenda {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: .9rem;
}

.inc-llegenda-item {
    display: flex;
    align-items: center;
    gap: .3rem;
    font-size: .74rem;
    color: var(--color-text-suau);
}

.inc-llegenda-color {
    width: .6rem;
    height: .6rem;
    border-radius: 99px;
    flex-shrink: 0;
}

.inc-fila {
    display: flex;
    align-items: center;
    gap: .9rem;
    padding: .9rem 1.1rem .9rem 0;
    border-bottom: 1px solid var(--color-borde-suau);
    border-left: 4px solid transparent;
    text-decoration: none;
    color: inherit;
    transition: background .1s;
}

.inc-fila:last-child  { border-bottom: none; }
.inc-fila:hover       { background: var(--color-superficie-tint); text-decoration: none; color: inherit; }

.inc-prioritat--baixa  { border-left-color: #d1d5db; }
.inc-prioritat--normal { border-left-color: #3b82f6; }
.inc-prioritat--alta   { border-left-color: #f97316; }
.inc-prioritat--urgent { border-left-color: #ef4444; }

.inc-id {
    font-size: .75rem;
    font-weight: 700;
    color: var(--color-text-suau);
    min-width: 2.8rem;
    padding-left: .85rem;
    flex-shrink: 0;
}

.inc-principal { flex: 1; min-width: 0; }

.inc-titol {
    font-weight: 600;
    font-size: .94rem;
    color: var(--color-text);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.inc-sub {
    font-size: .78rem;
    color: var(--color-text-suau);
    margin-top: .1rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.inc-sub-sep { margin: 0 .3rem; opacity: .5; }

.inc-badges {
    display: flex;
    align-items: center;
    gap: .4rem;
    flex-shrink: 0;
}

.inc-avatar {
    width: 1.85rem;
    height: 1.85rem;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .68rem;
    font-weight: 700;
    flex-shrink: 0;
}

.inc-avatar--assignat {
    background: var(--color-primari-clar);
    color: var(--color-primari-fosc);
}

.inc-avatar--buit {
    border: 1.5px dashed var(--color-borde);
    color: var(--color-text-suau);
}

.inc-data {
    font-size: .76rem;
    color: var(--color-text-suau);
    flex-shrink: 0;
    min-width: 5rem;
    text-align: right;
}

.inc-buit {
    text-align: center;
    padding: 3.5rem 1rem;
    color: var(--color-text-suau);
}

.inc-buit i {
    font-size: 2.4rem;
    display: block;
    margin-bottom: .75rem;
    opacity: .3;
}

.inc-buit p { margin: 0; font-size: .92rem; }

/* ─── BADGES D'ESTAT I PRIORITAT ─────────────────────────────────────────── */

.badge-estat {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    padding: .25rem .65rem;
    border-radius: 99px;
    font-size: .78rem;
    font-weight: 600;
    white-space: nowrap;
}

.badge-estat--obert        { background: #dcfce7; color: #166534; }
.badge-estat--en-proces    { background: #dbeafe; color: #1e40af; }
.badge-estat--pendent      { background: #fef9c3; color: #854d0e; }
.badge-estat--resolta      { background: #f3f4f6; color: #374151; }
.badge-estat--tancada      { background: #f3f4f6; color: #9ca3af; }

.badge-prioritat {
    display: inline-flex;
    padding: .2rem .55rem;
    border-radius: 99px;
    font-size: .75rem;
    font-weight: 600;
    white-space: nowrap;
}

.badge-prioritat--baixa    { background: #f0fdf4; color: #15803d; }
.badge-prioritat--normal   { background: #eff6ff; color: #1d4ed8; }
.badge-prioritat--alta     { background: #fff7ed; color: #c2410c; }
.badge-prioritat--urgent   { background: #fef2f2; color: #991b1b; }

/* ─── FORMULARI PRINCIPAL ────────────────────────────────────────────────── */

.formulari-panell {
    display: grid;
    gap: 1.1rem;
}

.formulari-panell .form-label {
    font-size: .92rem;
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: .3rem;
}

.formulari-panell .form-control,
.formulari-panell .form-select {
    border: 1.5px solid var(--color-borde);
    border-radius: var(--radi);
    background: var(--color-fons-app);
    color: var(--color-text);
    font-size: .97rem;
    transition: border-color .15s, box-shadow .15s;
}

.formulari-panell .form-control:focus,
.formulari-panell .form-select:focus {
    border-color: var(--color-primari);
    background: var(--color-superficie);
    box-shadow: 0 0 0 .18rem rgba(190, 58, 52, .15);
    outline: none;
}

/* ─── PETICIONS ──────────────────────────────────────────────────────────── */

.peticions-tipus-selector {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: .65rem;
}

.peticions-tipus-opcio {
    min-height: 4.4rem;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: .75rem;
    padding: .75rem .85rem;
    border: 1px solid var(--color-borde);
    border-radius: var(--radi);
    background: var(--color-superficie);
    color: var(--color-text);
    text-decoration: none;
    transition: border-color .12s, box-shadow .12s, background .12s;
}

.peticions-tipus-opcio:hover {
    border-color: var(--color-primari);
    box-shadow: 0 2px 8px var(--color-ombra);
    color: var(--color-text);
}

.peticions-tipus-opcio--activa {
    border-color: var(--color-primari);
    background: var(--color-primari-clar);
}

.peticions-tipus-icona {
    width: 2.25rem;
    height: 2.25rem;
    display: inline-grid;
    place-items: center;
    border-radius: var(--radi);
    background: var(--color-fons-app);
    color: var(--color-primari);
    font-size: 1.1rem;
}

.peticions-tipus-text {
    min-width: 0;
    display: grid;
    gap: .1rem;
    font-weight: 650;
    line-height: 1.2;
}

.peticions-tipus-text small {
    color: var(--color-text-suau);
    font-weight: 400;
    line-height: 1.25;
    overflow-wrap: anywhere;
}

.peticions-tipus-comptador {
    min-width: 1.9rem;
    height: 1.9rem;
    display: inline-grid;
    place-items: center;
    border-radius: 999px;
    background: var(--color-fons-app);
    color: var(--color-text-suau);
    font-size: .82rem;
    font-weight: 700;
}

.peticions-formulari {
    border: 1px solid var(--color-borde);
    border-radius: var(--radi);
    background: var(--color-fons-app);
    padding: 1rem;
}

/* ─── DETALL D'INCIDÈNCIA ────────────────────────────────────────────────── */

.det-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
}

.det-nav-tornar {
    font-size: .88rem;
    color: var(--color-text-suau);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    transition: color .12s;
}

.det-nav-tornar:hover { color: var(--color-primari); }

.det-capcalera {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    margin-bottom: 1.5rem;
}

.det-capcalera-id {
    font-size: .78rem;
    font-weight: 700;
    color: var(--color-text-suau);
    background: var(--color-fons-app);
    border: 1px solid var(--color-borde);
    border-radius: var(--radi);
    padding: .3rem .65rem;
    white-space: nowrap;
    flex-shrink: 0;
    margin-top: .2rem;
}

.det-capcalera-cos { flex: 1; min-width: 0; }

.det-titol {
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--color-text);
    margin: 0 0 .5rem;
    line-height: 1.3;
}

.det-meta-linia {
    display: flex;
    flex-wrap: wrap;
    gap: .45rem;
    align-items: center;
}

.det-meta-sep { color: var(--color-borde); }

.det-meta-text {
    font-size: .85rem;
    color: var(--color-text-suau);
}

.det-descripcio {
    font-size: .95rem;
    line-height: 1.65;
    color: var(--color-text);
    white-space: pre-wrap;
}

/* ─── COMENTARIS EN TIMELINE ─────────────────────────────────────────────── */

.badge-privat {
    background: var(--color-primari-clar);
    color: var(--color-primari-fosc);
    font-size: .7rem;
    font-weight: 600;
    padding: .12rem .45rem;
    border-radius: 99px;
}

.tl-com-cap {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: .5rem .9rem;
    background: var(--color-fons-app);
    border-bottom: 1px solid var(--color-borde-suau);
    font-size: .84rem;
}

.tl-com-autor {
    font-weight: 600;
    color: var(--color-text);
    display: flex;
    align-items: center;
}

.tl-com-data {
    font-size: .78rem;
    color: var(--color-text-suau);
    flex-shrink: 0;
}

.tl-com-cos {
    padding: .75rem .9rem;
    font-size: .9rem;
    line-height: 1.55;
    color: var(--color-text);
    white-space: pre-wrap;
}

/* ─── FORMULARI NOU COMENTARI ────────────────────────────────────────────── */

.tl-nou-comentari {
    display: flex;
    gap: .85rem;
    align-items: flex-start;
}

.tl-nou-cos { flex: 1; min-width: 0; }

.tl-nou-textarea {
    width: 100%;
    border: 1.5px solid var(--color-borde);
    border-radius: var(--radi);
    padding: .6rem .85rem;
    font-size: .92rem;
    font-family: inherit;
    resize: vertical;
    min-height: 88px;
    color: var(--color-text);
    background: var(--color-superficie);
    transition: border-color .15s, box-shadow .15s;
}

.tl-nou-textarea:focus {
    border-color: var(--color-primari);
    box-shadow: 0 0 0 .18rem rgba(190, 58, 52, .15);
    outline: none;
}

.tl-nou-accions {
    display: flex;
    align-items: center;
    gap: .65rem;
    flex-wrap: wrap;
    margin-top: .5rem;
}

/* ─── SIDEBAR DETALL (dsb-) ──────────────────────────────────────────────── */

.dsb-panell {
    background: var(--color-superficie);
    border: 1px solid var(--color-borde);
    border-radius: var(--radi);
    overflow: hidden;
    position: sticky;
    top: calc(var(--alzada-topbar) + 1.25rem);
}

.dsb-seccio {
    padding: .7rem 1rem;
    border-bottom: 1px solid var(--color-borde-suau);
}

.dsb-seccio:last-child { border-bottom: none; }

.dsb-etiqueta {
    font-size: .71rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--color-text-suau);
    margin-bottom: .35rem;
    display: flex;
    align-items: center;
    gap: .3rem;
}

.dsb-valor {
    font-size: .9rem;
    color: var(--color-text);
}

.dsb-valor-persona {
    display: flex;
    align-items: center;
    gap: .55rem;
    font-size: .9rem;
}

.dsb-avatar {
    width: 1.7rem;
    height: 1.7rem;
    border-radius: 50%;
    background: var(--color-primari-clar);
    color: var(--color-primari-fosc);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .67rem;
    font-weight: 700;
    flex-shrink: 0;
}

.dsb-avatar--tecnic {
    background: #dbeafe;
    color: #1e40af;
}

.dsb-divider {
    height: 5px;
    background: var(--color-fons-app);
    border-top: 1px solid var(--color-borde-suau);
    border-bottom: 1px solid var(--color-borde-suau);
}

.dsb-form-accio {
    display: flex;
    gap: .4rem;
    align-items: center;
}

.dsb-select {
    flex: 1;
    border: 1.5px solid var(--color-borde) !important;
    font-size: .84rem !important;
    background: var(--color-fons-app) !important;
}

.dsb-btn-ok {
    flex-shrink: 0;
    padding: .28rem .55rem;
    line-height: 1;
}

.dsb-adjunts {
    display: flex;
    flex-direction: column;
    gap: .25rem;
    margin-bottom: .5rem;
}

.dsb-adjunt-fila {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: .35rem;
}

.dsb-adjunt {
    display: flex;
    align-items: center;
    gap: .5rem;
    padding: .3rem .4rem;
    border-radius: .35rem;
    font-size: .82rem;
    color: var(--color-text);
    text-decoration: none;
    transition: background .1s;
}

.dsb-adjunt:hover { background: var(--color-superficie-tint); color: var(--color-primari); }

.dsb-adjunt-ico  { color: var(--color-primari); font-size: 1rem; flex-shrink: 0; }
.dsb-adjunt-nom  { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dsb-adjunt-mida { font-size: .75rem; color: var(--color-text-suau); flex-shrink: 0; }

.dsb-buit-text {
    font-size: .82rem;
    color: var(--color-text-suau);
    margin: 0 0 .5rem;
}

.dsb-upload { display: flex; flex-direction: column; gap: .25rem; }

.dsb-upload-label {
    display: block;
    text-align: center;
    padding: .45rem .75rem;
    border: 1.5px dashed var(--color-borde);
    border-radius: var(--radi);
    font-size: .82rem;
    color: var(--color-text-suau);
    cursor: pointer;
    transition: border-color .15s, color .15s;
}

.dsb-upload-label:hover {
    border-color: var(--color-primari);
    color: var(--color-primari);
}

.dsb-upload-hint {
    font-size: .73rem;
    color: var(--color-text-suau);
    text-align: center;
    opacity: .75;
}

/* ─── CAPÇALERA DE PÀGINA ────────────────────────────────────────────────── */

.cap-pagina {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1.25rem;
}

.cap-pagina h1 {
    font-size: 1.35rem;
    font-weight: 700;
    margin: 0 0 .2rem;
}

.cap-pagina p {
    margin: 0;
    color: var(--color-text-suau);
    font-size: .92rem;
}

/* ─── MISSATGES FLASH ────────────────────────────────────────────────────── */

.missatge-flash {
    border-radius: var(--radi);
    margin-bottom: 1rem;
    font-size: .95rem;
}

/* ─── FILTRES ────────────────────────────────────────────────────────────── */

.barra-filtres {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    align-items: center;
}

.barra-filtres-cerca {
    position: relative;
    flex-shrink: 0;
}

.barra-filtres-cerca-icona {
    position: absolute;
    left: .7rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-text-suau);
    font-size: .85rem;
    pointer-events: none;
}

.barra-filtres-cerca-input {
    height: 36px;
    width: 220px;
    padding: 0 .8rem 0 2.1rem;
    border: 1.5px solid var(--color-borde);
    border-radius: var(--radi);
    background: var(--color-superficie);
    color: var(--color-text);
    font-size: .88rem;
    font-family: inherit;
    transition: border-color .15s, box-shadow .15s;
}

.barra-filtres-cerca-input:focus {
    border-color: var(--color-primari);
    box-shadow: 0 0 0 .15rem rgba(190, 58, 52, .15);
    outline: none;
}

.barra-filtres-select {
    height: 36px;
    font-size: .88rem !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    border: 1.5px solid var(--color-borde) !important;
    border-radius: var(--radi) !important;
    background: var(--color-superficie) !important;
    color: var(--color-text) !important;
    width: auto !important;
}

.barra-filtres-select:focus {
    border-color: var(--color-primari) !important;
    box-shadow: 0 0 0 .15rem rgba(190, 58, 52, .15) !important;
    outline: none !important;
}

.barra-filtres .form-select,
.barra-filtres .form-control {
    font-size: .88rem;
    height: 36px;
    padding-top: 0;
    padding-bottom: 0;
    border: 1.5px solid var(--color-borde);
    border-radius: var(--radi);
    background: var(--color-superficie);
    color: var(--color-text);
}

.barra-filtres .form-select:focus,
.barra-filtres .form-control:focus {
    border-color: var(--color-primari);
    box-shadow: 0 0 0 .15rem rgba(190, 58, 52, .15);
    outline: none;
}

/* ─── SLA (temps d'obertura) ─────────────────────────────────────────────── */

.sla-badge {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    padding: .18rem .55rem;
    border-radius: 99px;
    font-size: .75rem;
    font-weight: 600;
    white-space: nowrap;
}

.sla-ok     { background: #dcfce7; color: #166534; }
.sla-avís   { background: #fef9c3; color: #854d0e; }
.sla-crític { background: #fef2f2; color: #991b1b; }

/* ─── TIMELINE D'ACTIVITAT ───────────────────────────────────────────────── */

.timeline {
    display: flex;
    flex-direction: column;
    position: relative;
}

.timeline::before {
    content: "";
    position: absolute;
    left: 1.05rem;
    top: .5rem;
    bottom: .5rem;
    width: 2px;
    background: var(--color-borde);
    border-radius: 2px;
}

.timeline-entrada {
    display: flex;
    gap: .85rem;
    align-items: flex-start;
    padding: .65rem 0;
    position: relative;
}

.timeline-icona {
    flex-shrink: 0;
    width: 2.1rem;
    height: 2.1rem;
    border-radius: 50%;
    background: var(--color-superficie);
    border: 2px solid var(--color-borde);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .88rem;
    z-index: 1;
}

.timeline-avatar {
    flex-shrink: 0;
    width: 2.1rem;
    height: 2.1rem;
    border-radius: 50%;
    background: var(--color-primari);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .75rem;
    font-weight: 700;
    z-index: 1;
}

.timeline-cos {
    flex: 1;
    min-width: 0;
    padding-top: .25rem;
}

.timeline-meta {
    font-size: .79rem;
    color: var(--color-text-suau);
    margin-bottom: .2rem;
}

.timeline-descripcio {
    font-size: .9rem;
    color: var(--color-text);
}

.timeline-canvi {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    font-size: .82rem;
    margin-top: .3rem;
    flex-wrap: wrap;
}

.timeline-valor-ant {
    background: #fee2e2;
    color: #991b1b;
    padding: .1rem .45rem;
    border-radius: 99px;
    text-decoration: line-through;
    opacity: .85;
}

.timeline-valor-nou {
    background: #dcfce7;
    color: #166534;
    padding: .1rem .45rem;
    border-radius: 99px;
    font-weight: 600;
}

.timeline-cos-comentari {
    flex: 1;
    min-width: 0;
    background: var(--color-superficie);
    border: 1px solid var(--color-borde);
    border-radius: var(--radi);
    overflow: hidden;
}

.timeline-comentari--privat > .timeline-cos-comentari {
    border-left: 3px solid var(--color-primari);
    background: var(--color-superficie-tint);
}

/* ─── GRAELLA D'INFO (detall incidència) ─────────────────────────────────── */

.info-dl {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: .45rem 1rem;
    font-size: .9rem;
}

.info-dl dt {
    font-weight: 600;
    color: var(--color-text-suau);
    white-space: nowrap;
}

.info-dl dd {
    margin: 0;
    color: var(--color-text);
}

/* ─── RESPONSIVE ─────────────────────────────────────────────────────────── */

@media (max-width: 900px) {
    .app-shell {
        grid-template-columns: 1fr;
    }

    .app-sidebar {
        border-right: none;
        border-bottom: 1px solid var(--color-borde);
    }

    .app-nav {
        flex-direction: row;
        flex-wrap: wrap;
        margin-top: .75rem;
    }

    .app-nav-separador {
        display: none;
    }

    .resum-graella {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .pantalla-sessio {
        grid-template-columns: 1fr;
    }

    .sessio-imatge {
        min-height: 240px;
        max-height: 36vh;
    }

    .sessio-panell {
        align-items: flex-start;
        padding-top: 1.5rem;
        padding-bottom: 2rem;
    }
}

@media (max-width: 560px) {
    .boto-sessio.btn-primary,
    .boto-sessio-secundari.btn {
        width: 100%;
        min-width: 0;
    }

    .sessio-imatge {
        min-height: 200px;
        max-height: 28vh;
    }

    .resum-graella {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .app-content {
        padding: 1rem;
    }
}

/* ─── ASSISTENT D'INCIDÈNCIA (alta guiada) ───────────────────────────────── */

.assistent {
    display: grid;
    grid-template-columns: 260px minmax(0, 1fr);
    gap: 1.5rem;
    align-items: start;
}

.assistent-lateral {
    position: sticky;
    top: 1rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.assistent-progres {
    height: 6px;
    border-radius: 999px;
    background: var(--color-primari-clar);
    overflow: hidden;
}

.assistent-progres > span {
    display: block;
    height: 100%;
    width: 16.66%;
    background: var(--color-primari);
    border-radius: 999px;
    transition: width .25s ease;
}

.assistent-passos {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: .35rem;
}

.assistent-passos button {
    width: 100%;
    display: flex;
    align-items: center;
    gap: .6rem;
    padding: .55rem .7rem;
    border: 1px solid transparent;
    border-radius: var(--radi);
    background: transparent;
    color: var(--color-text-suau);
    font-size: .9rem;
    font-weight: 500;
    text-align: left;
    cursor: pointer;
    transition: background .15s, color .15s, border-color .15s;
}

.assistent-passos button > span {
    flex: none;
    width: 26px;
    height: 26px;
    display: grid;
    place-items: center;
    border-radius: 50%;
    background: var(--color-superficie-tint);
    border: 1px solid var(--color-borde);
    font-size: .82rem;
    font-weight: 700;
}

.assistent-passos button:hover { background: var(--color-superficie-tint); }

.assistent-passos button.is-active {
    background: var(--color-superficie);
    border-color: var(--color-borde);
    color: var(--color-text);
}

.assistent-passos button.is-active > span {
    background: var(--color-primari);
    border-color: var(--color-primari);
    color: #fff;
}

.assistent-passos button.is-complete > span {
    background: var(--color-primari-clar);
    border-color: var(--color-borde);
    color: var(--color-primari-fosc);
}

.assistent-consells {
    background: var(--color-superficie-tint);
    border: 1px solid var(--color-borde-suau);
    border-radius: var(--radi);
    padding: .9rem 1rem;
    font-size: .85rem;
    color: var(--color-text-suau);
}

.assistent-consells strong { color: var(--color-text); }

.assistent-panells {
    background: var(--color-superficie);
    border: 1px solid var(--color-borde);
    border-radius: var(--radi);
    padding: 1.5rem;
}

.assistent-panell { display: none; }

.assistent-panell.is-active {
    display: block;
    animation: assistent-fade .2s ease;
}

@keyframes assistent-fade {
    from { opacity: 0; transform: translateY(4px); }
    to   { opacity: 1; transform: none; }
}

.assistent-panell-cap { margin-bottom: 1.25rem; }

.assistent-panell-cap .eyebrow {
    margin: 0;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--color-primari);
}

.assistent-panell-cap h2 { margin: .15rem 0 .25rem; font-size: 1.25rem; font-weight: 700; }
.assistent-panell-cap p { margin: 0; color: var(--color-text-suau); font-size: .92rem; }

.assistent-camp { margin-bottom: 1rem; }
.assistent-camp .form-label { font-weight: 600; }

.assistent-tria {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: .75rem;
    margin-bottom: 1rem;
}

.assistent-tria-targeta {
    position: relative;
    display: block;
    border: 1.5px solid var(--color-borde);
    border-radius: var(--radi);
    padding: .9rem 1rem;
    cursor: pointer;
    transition: border-color .15s, box-shadow .15s, background .15s;
}

.assistent-tria-targeta input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.assistent-tria-targeta strong { display: block; font-size: .98rem; }
.assistent-tria-targeta small { color: var(--color-text-suau); font-size: .82rem; }
.assistent-tria-targeta:hover { background: var(--color-superficie-tint); }

.assistent-tria-targeta.is-selected,
.assistent-tria-targeta:has(input:checked) {
    border-color: var(--color-primari);
    background: var(--color-superficie-tint);
    box-shadow: 0 0 0 .18rem rgba(190, 58, 52, .15);
}

.assistent-dropzone {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: .35rem;
    text-align: center;
    border: 2px dashed var(--color-borde);
    border-radius: var(--radi);
    padding: 2rem 1rem;
    cursor: pointer;
    color: var(--color-text-suau);
    transition: border-color .15s, background .15s;
}

.assistent-dropzone input { display: none; }

.assistent-dropzone:hover,
.assistent-dropzone.is-dragover {
    border-color: var(--color-primari);
    background: var(--color-superficie-tint);
}

.assistent-dropzone strong { color: var(--color-text); }

.assistent-fitxers {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: .6rem;
    margin-top: .9rem;
}

.assistent-fitxer {
    display: flex;
    align-items: center;
    gap: .65rem;
    border: 1px solid var(--color-borde-suau);
    border-radius: var(--radi);
    padding: .55rem .7rem;
    background: var(--color-superficie-tint);
}

.assistent-fitxer img {
    width: 38px;
    height: 38px;
    object-fit: cover;
    border-radius: .35rem;
    flex: none;
}

.assistent-fitxer-icona {
    width: 38px;
    height: 38px;
    display: grid;
    place-items: center;
    border-radius: .35rem;
    background: var(--color-primari-clar);
    color: var(--color-primari-fosc);
    flex: none;
}

.assistent-fitxer strong { display: block; font-size: .85rem; word-break: break-word; }
.assistent-fitxer span { font-size: .78rem; color: var(--color-text-suau); }

.assistent-revisio {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: .75rem;
    margin-bottom: 1rem;
}

.assistent-revisio article,
.assistent-revisio-bloc {
    border: 1px solid var(--color-borde-suau);
    border-radius: var(--radi);
    padding: .7rem .85rem;
    background: var(--color-superficie-tint);
}

.assistent-revisio article span,
.assistent-revisio-bloc span {
    display: block;
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--color-text-suau);
    margin-bottom: .15rem;
}

.assistent-revisio-bloc { margin-bottom: .75rem; }
.assistent-revisio-bloc p { margin: 0; white-space: pre-wrap; }

.assistent-buit {
    border: 1px dashed var(--color-borde);
    border-radius: var(--radi);
    padding: 1rem;
    text-align: center;
    color: var(--color-text-suau);
}

.assistent-buit strong { display: block; color: var(--color-text); }

.assistent-navegacio {
    display: flex;
    justify-content: space-between;
    gap: .75rem;
    margin-top: 1.5rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--color-borde-suau);
}

.assistent .has-error .form-control,
.assistent .has-error .form-select { border-color: var(--color-primari); }

@media (max-width: 820px) {
    .assistent { grid-template-columns: 1fr; }
    .assistent-lateral { position: static; }
    .assistent-passos { flex-direction: row; flex-wrap: wrap; }
    .assistent-passos li { flex: 1 1 auto; }
}
