/*
 * oraculum-consultazione.css — «Consultazione Bandi» (2026-06-15)
 * Cockpit cittadino answer-first. Port del mockup CD «Oraculum — Consultazione Bandi».
 * Namespace: ocb-. Usa i token --oc-* (oraculum-tokens.css), non li sostituisce.
 * Font: Lora (display) · Titillium Web (UI) · Roboto Mono (numeri/codici).
 */

.oc-page-consultazione {
    margin: 0;
    background: var(--oc-bg-2);
    color: var(--oc-text);
    font-family: "Titillium Web", system-ui, sans-serif;
    -webkit-font-smoothing: antialiased;
}
.oc-page-consultazione *,
.oc-page-consultazione *::before,
.oc-page-consultazione *::after { box-sizing: border-box; }

/* ───────────── Gov strip + header ───────────── */
.ocb-govstrip {
    display: flex; justify-content: space-between; align-items: center;
    padding: 6px 24px; font-size: 12px; color: var(--oc-text-3);
    background: var(--oc-bg); border-bottom: 1px solid var(--oc-border);
}
.ocb-govstrip strong { color: var(--oc-text-2); font-weight: 600; }
.ocb-govstrip-links { display: flex; gap: 16px; align-items: center; }
.ocb-govstrip-links a { color: var(--oc-accent); text-decoration: none; }
.ocb-lang { font-weight: 600; color: var(--oc-text-2); }

.ocb-header {
    position: sticky; top: 0; z-index: 30;
    display: flex; align-items: center; gap: 24px;
    padding: 12px 24px; background: var(--oc-bg);
    border-bottom: 1px solid var(--oc-border);
}
.ocb-brand { display: flex; align-items: center; gap: 12px; text-decoration: none; flex: 0 0 auto; }
.ocb-brand-mark {
    width: 38px; height: 38px; border-radius: 9px; flex: 0 0 auto;
    display: grid; place-items: center;
    background: var(--oc-primary); color: #fff;
    font-family: "Lora", serif; font-size: 20px; font-weight: 600;
}
.ocb-brand-text { display: flex; flex-direction: column; line-height: 1.2; }
.ocb-brand-name { font-family: "Lora", serif; font-size: 19px; font-weight: 600; color: var(--oc-primary); }
.ocb-brand-sub { font-size: 11.5px; color: var(--oc-text-3); }

.ocb-search-global {
    flex: 1 1 auto; max-width: 620px; margin: 0 auto;
    display: flex; align-items: center; gap: 9px;
    padding: 9px 14px; border-radius: 10px;
    background: var(--oc-bg-2); border: 1px solid var(--oc-border);
    color: var(--oc-text-3);
}
.ocb-search-global input {
    flex: 1; border: 0; background: transparent; outline: none;
    font: inherit; font-size: 14px; color: var(--oc-text);
}
.ocb-search-global kbd {
    font-family: "Roboto Mono", monospace; font-size: 11px;
    padding: 1px 6px; border-radius: 5px; background: var(--oc-bg);
    border: 1px solid var(--oc-border); color: var(--oc-text-3);
}
.ocb-header-right { display: flex; align-items: center; gap: 18px; flex: 0 0 auto; }
.ocb-corpus { display: inline-flex; align-items: center; gap: 7px; font-size: 12.5px; color: var(--oc-text-2);
    background: var(--oc-badge-open-bg); padding: 5px 11px; border-radius: 999px; }
.ocb-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--oc-success); }
.ocb-user { display: flex; align-items: center; gap: 9px; }
.ocb-user-avatar { width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center;
    background: var(--oc-accent); color: #fff; font-weight: 600; font-size: 13px; }
.ocb-user-meta { display: flex; flex-direction: column; line-height: 1.25; }
.ocb-user-name { font-size: 13px; font-weight: 600; color: var(--oc-text); }
.ocb-user-sub { font-size: 11px; color: var(--oc-text-3); }

/* ───────────── Layout 3 zone ───────────── */
.ocb-layout {
    display: grid;
    grid-template-columns: 340px minmax(0, 1fr) 400px;
    height: calc(100vh - 96px);
    overflow: hidden;
}
.ocb-nav, .ocb-cockpit, .ocb-chat { height: 100%; overflow-y: auto; }
.ocb-nav { border-right: 1px solid var(--oc-border); background: var(--oc-bg); padding: 18px 16px 40px; }
.ocb-cockpit { padding: 26px 32px 60px; }
.ocb-chat { border-left: 1px solid var(--oc-border); background: var(--oc-bg); display: flex; flex-direction: column; }

/* ───────────── Nav (sinistra) ───────────── */
.ocb-nav-search { display: flex; align-items: center; gap: 8px; padding: 9px 12px; border-radius: 9px;
    background: var(--oc-bg-2); border: 1px solid var(--oc-border); color: var(--oc-text-3); margin-bottom: 18px; }
.ocb-nav-search input { flex: 1; border: 0; background: transparent; outline: none; font: inherit; font-size: 13.5px; color: var(--oc-text); }

.ocb-facet { margin-bottom: 18px; }
.ocb-facet-title { font-size: 11px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase;
    color: var(--oc-text-3); margin-bottom: 9px; }
.ocb-categorie { display: flex; flex-direction: column; gap: 2px; }
.ocb-cat-tile { display: flex; align-items: center; gap: 9px; width: 100%; text-align: left;
    padding: 8px 10px; border: 0; border-radius: 8px; background: transparent; cursor: pointer;
    font: inherit; font-size: 13.5px; color: var(--oc-text-2); }
.ocb-cat-tile:hover { background: var(--oc-bg-2); }
.ocb-cat-tile.is-active { background: var(--oc-accent-light); color: var(--oc-primary); font-weight: 600; }
.ocb-cat-dot { width: 9px; height: 9px; border-radius: 50%; flex: 0 0 auto; background: var(--oc-accent); }
.ocb-cat-name { flex: 1; line-height: 1.25; }
.ocb-cat-count { font-family: "Roboto Mono", monospace; font-size: 12px; color: var(--oc-text-3); }
.ocb-cat-tile.is-active .ocb-cat-count { color: var(--oc-accent-dark); }

.ocb-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.ocb-chip { padding: 5px 11px; border-radius: 999px; border: 1px solid var(--oc-border);
    background: var(--oc-bg); cursor: pointer; font: inherit; font-size: 12.5px; color: var(--oc-text-2); }
.ocb-chip:hover { border-color: var(--oc-border-2); }
.ocb-chip.is-active { background: var(--oc-primary); border-color: var(--oc-primary); color: #fff; }

.ocb-bandi-head { display: flex; justify-content: space-between; align-items: baseline;
    margin: 4px 0 10px; font-size: 11px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--oc-text-3); }
.ocb-count { font-family: "Roboto Mono", monospace; letter-spacing: 0; }

.ocb-bandi-list { display: flex; flex-direction: column; gap: 9px; }
.ocb-bando-card { text-align: left; width: 100%; cursor: pointer; font: inherit;
    border: 1px solid var(--oc-border); border-radius: 11px; background: var(--oc-bg);
    padding: 12px 13px; transition: border-color .12s, box-shadow .12s; }
.ocb-bando-card:hover { border-color: var(--oc-accent); }
.ocb-bando-card.is-selected { border-color: var(--oc-accent); box-shadow: 0 0 0 2px var(--oc-accent-light); background: #fff; }
.ocb-bando-card-top { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; margin-bottom: 7px; }
.ocb-bando-card-kicker { font-size: 10.5px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--oc-text-3); margin-bottom: 3px; }
.ocb-bando-card-title { font-family: "Lora", serif; font-size: 15px; font-weight: 600; line-height: 1.28; color: var(--oc-primary); margin: 0 0 6px; }
.ocb-bando-card-benef { font-size: 12px; color: var(--oc-text-3); line-height: 1.35; margin-bottom: 9px; }
.ocb-bando-card-foot { display: flex; justify-content: space-between; align-items: center; gap: 8px;
    border-top: 1px solid var(--oc-bg-3); padding-top: 8px; }
.ocb-bando-card-dot { font-size: 11px; color: var(--oc-text-3); }
.ocb-bando-card-dot b { font-family: "Roboto Mono", monospace; font-weight: 500; color: var(--oc-text); }

/* ───────────── Badge (riuso mappa token) ───────────── */
.ocb-badge { display: inline-flex; align-items: center; gap: 5px; font-size: 10.5px; font-weight: 700;
    letter-spacing: .03em; text-transform: uppercase; padding: 3px 8px; border-radius: 6px;
    background: var(--oc-bg-3); color: var(--oc-text-2); }
.ocb-badge.fesr { background: var(--oc-badge-fesr-bg); color: var(--oc-badge-fesr-fg); }
.ocb-badge.fse, .ocb-badge.fse\+ { background: var(--oc-badge-fse-bg); color: var(--oc-badge-fse-fg); }
.ocb-badge.feasr, .ocb-badge.psr, .ocb-badge.psr\/feasr { background: var(--oc-badge-feasr-bg); color: var(--oc-badge-feasr-fg); }
.ocb-badge.corpus { background: var(--oc-badge-open-bg); color: var(--oc-badge-open-fg); }
.ocb-badge.aperto { background: var(--oc-badge-open-bg); color: var(--oc-badge-open-fg); }
.ocb-status { font-size: 11px; font-weight: 600; }
.ocb-status.aperto { color: var(--oc-success); }
.ocb-status.urgente { color: var(--oc-danger); }
.ocb-status.soon { color: var(--oc-warning); }
/* ATECO non applicabile: chip discreto (bandi persona/status/ente) */
.ocb-ateco-na { font-size: 10.5px; font-weight: 600; letter-spacing: .02em; padding: 2px 8px;
    border-radius: 999px; background: var(--oc-bg-3); color: var(--oc-text-3);
    border: 1px solid var(--oc-border); cursor: help; white-space: nowrap; }

/* ───────────── Cockpit (centro) ───────────── */
.ocb-cockpit-empty { max-width: 420px; margin: 18vh auto 0; text-align: center; color: var(--oc-text-3); }
.ocb-cockpit-empty-mark { width: 54px; height: 54px; border-radius: 13px; margin: 0 auto 18px;
    display: grid; place-items: center; background: var(--oc-bg-3); color: var(--oc-accent);
    font-family: "Lora", serif; font-size: 28px; }
.ocb-cockpit-empty h2 { font-family: "Lora", serif; color: var(--oc-primary); margin: 0 0 8px; font-size: 22px; }
.ocb-cockpit-empty p { font-size: 14px; line-height: 1.5; margin: 0; }

.ocb-ck-breadcrumb { display: flex; flex-wrap: wrap; gap: 7px; align-items: center;
    font-size: 11px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--oc-text-3); margin-bottom: 10px; }
.ocb-ck-breadcrumb .sep { color: var(--oc-border-2); }
.ocb-ck-fondo-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--oc-accent); }
.ocb-ck-title { font-family: "Lora", serif; font-size: 28px; line-height: 1.2; font-weight: 600;
    color: var(--oc-primary); margin: 0 0 14px; }
.ocb-ck-badges { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; margin-bottom: 16px; }
.ocb-stamp { display: inline-flex; align-items: center; gap: 6px; font-size: 11px; font-weight: 700;
    letter-spacing: .03em; text-transform: uppercase; padding: 5px 10px; border-radius: 7px; }
.ocb-stamp.validata { background: #FBF1D6; color: var(--oc-signal-demo-dark); border: 1px solid #E9D49A; }
.ocb-stamp.parziale { background: var(--oc-bg-3); color: var(--oc-text-2); border: 1px solid var(--oc-border-2); }
.ocb-stamp-note { font-size: 11.5px; color: var(--oc-text-3); font-weight: 500; text-transform: none; letter-spacing: 0; }

.ocb-ck-actions { display: flex; gap: 10px; margin-bottom: 24px; }
.ocb-btn { display: inline-flex; align-items: center; gap: 7px; font: inherit; font-size: 13px; font-weight: 600;
    padding: 9px 15px; border-radius: 9px; cursor: pointer; text-decoration: none; border: 1px solid transparent; }
.ocb-btn-primary { background: var(--oc-primary); color: #fff; }
.ocb-btn-primary:hover { background: var(--oc-primary-hover); }
.ocb-btn-ghost { background: var(--oc-bg); color: var(--oc-text-2); border-color: var(--oc-border); }
.ocb-btn-ghost:hover { border-color: var(--oc-border-2); }

/* Dati essenziali */
.ocb-dati-head { display: flex; justify-content: space-between; align-items: baseline; gap: 16px; margin: 6px 0 12px; }
.ocb-dati-head h3 { font-family: "Lora", serif; font-size: 20px; font-weight: 600; color: var(--oc-primary); margin: 0; }
.ocb-dati-head .ocb-dati-claim { font-size: 12px; color: var(--oc-text-3); }

.ocb-legend { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; padding: 10px 14px;
    background: var(--oc-bg); border: 1px solid var(--oc-border); border-radius: 10px; margin-bottom: 16px; font-size: 12px; color: var(--oc-text-2); }
.ocb-legend-item { display: inline-flex; align-items: center; gap: 7px; }
.ocb-legend-swatch { width: 13px; height: 13px; border-radius: 50%; flex: 0 0 auto; }
.ocb-legend-swatch.alta { background: var(--oc-gold); }
.ocb-legend-swatch.media { background: #DCC07A; }
.ocb-legend-swatch.bassa { background: transparent; border: 2px solid var(--oc-gold); }
.ocb-legend-swatch.missing { background: transparent; border: 2px dashed var(--oc-border-2); }

.ocb-dati-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 13px; }
.ocb-dato { border: 1px solid var(--oc-border); border-radius: 12px; padding: 15px 16px; background: var(--oc-bg); }
.ocb-dato.span2 { grid-column: 1 / -1; }
.ocb-dato.is-primary { border-color: var(--oc-border-2); }
.ocb-dato-label { font-size: 10.5px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--oc-text-3); margin-bottom: 8px; }
.ocb-dato-value { font-family: "Lora", serif; font-size: 24px; font-weight: 600; line-height: 1.15; color: var(--oc-primary); }
.ocb-dato-value .num { font-family: "Roboto Mono", monospace; font-weight: 500; }
.ocb-dato-value .unit { font-family: "Titillium Web", sans-serif; font-size: 17px; color: var(--oc-text-2); }
.ocb-dato-sub { font-size: 12.5px; color: var(--oc-text-2); margin-top: 3px; }

.ocb-dato-conf { display: flex; align-items: center; gap: 8px; margin-top: 11px; }
.ocb-ring { --pct: 0; --ring: var(--oc-gold);
    width: 28px; height: 28px; border-radius: 50%; flex: 0 0 auto; position: relative;
    background: conic-gradient(var(--ring) calc(var(--pct) * 1%), var(--oc-bg-3) 0); }
.ocb-ring::after { content: ""; position: absolute; inset: 4px; border-radius: 50%; background: var(--oc-bg); }
.ocb-ring.media { --ring: #DCC07A; }
.ocb-ring.bassa { background: none; border: 2px solid var(--oc-gold); }
.ocb-ring.bassa::after { display: none; }
.ocb-conf-text { font-size: 12px; color: var(--oc-text-2); }
.ocb-conf-text b { font-family: "Roboto Mono", monospace; font-weight: 500; color: var(--oc-text); }

.ocb-dato-actions { display: flex; gap: 14px; align-items: center; margin-top: 12px; padding-top: 11px; border-top: 1px solid var(--oc-bg-3); }
.ocb-link { display: inline-flex; align-items: center; gap: 5px; font-size: 12.5px; font-weight: 600;
    color: var(--oc-accent); background: none; border: 0; cursor: pointer; font-family: inherit; padding: 0; text-decoration: none; }
.ocb-link:hover { color: var(--oc-accent-dark); text-decoration: underline; }
.ocb-link svg { flex: 0 0 auto; }
.ocb-quote { display: none; margin-top: 11px; padding: 11px 14px; border-left: 3px solid var(--oc-accent);
    background: #FBF7EE; border-radius: 0 8px 8px 0; }
.ocb-quote.is-open { display: block; }
.ocb-quote-tag { font-size: 10px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; color: var(--oc-text-3); margin-bottom: 5px; }
.ocb-quote-text { font-family: "Lora", serif; font-style: italic; font-size: 13.5px; line-height: 1.5; color: var(--oc-text); }

/* campo non presente — onesto, niente confidence finta */
.ocb-dato.is-missing { background: var(--oc-bg-2); border-style: dashed; }
.ocb-dato.is-missing .ocb-dato-value { font-family: "Titillium Web", sans-serif; font-size: 15px; font-weight: 600; color: var(--oc-text-2); }
.ocb-dato-missing-note { display: flex; gap: 7px; align-items: flex-start; margin-top: 9px; font-size: 12px; color: var(--oc-text-3); line-height: 1.4; }

/* sportello — trattamento positivo, non un buco */
.ocb-sportello { margin-top: 10px; padding: 9px 12px; border-radius: 9px; background: var(--oc-badge-open-bg);
    color: var(--oc-badge-open-fg); font-size: 12px; line-height: 1.45; }
.ocb-sportello b { font-weight: 700; }

/* Sezioni */
.ocb-section { margin-top: 30px; }
.ocb-section h3 { font-family: "Lora", serif; font-size: 19px; font-weight: 600; color: var(--oc-primary);
    margin: 0 0 13px; padding-bottom: 8px; border-bottom: 1px solid var(--oc-border); }
.ocb-benef-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 12px; }
.ocb-benef { border: 1px solid var(--oc-border); border-radius: 11px; padding: 13px 15px; background: var(--oc-bg); }
.ocb-benef-tipo { font-weight: 700; font-size: 14px; color: var(--oc-text); margin-bottom: 4px; }
.ocb-benef-det { font-size: 12.5px; color: var(--oc-text-3); line-height: 1.45; }
.ocb-benef-common { margin-top: 12px; padding: 10px 13px; border-radius: 9px; background: var(--oc-bg-2);
    font-size: 12.5px; color: var(--oc-text-2); display: flex; gap: 8px; }

.ocb-spese-list { display: flex; flex-wrap: wrap; gap: 8px; }
.ocb-spesa { padding: 7px 12px; border-radius: 8px; background: var(--oc-bg); border: 1px solid var(--oc-border);
    font-size: 13px; color: var(--oc-text-2); }

.ocb-appro { display: flex; flex-direction: column; gap: 8px; }
.ocb-appro-item { border: 1px solid var(--oc-border); border-radius: 10px; overflow: hidden; background: var(--oc-bg); }
.ocb-appro-head { display: flex; justify-content: space-between; align-items: center; width: 100%;
    padding: 13px 15px; border: 0; background: transparent; cursor: pointer; font: inherit; font-size: 14px; font-weight: 600; color: var(--oc-text); }
.ocb-appro-head:hover { background: var(--oc-bg-2); }
.ocb-appro-head .chev { transition: transform .15s; color: var(--oc-text-3); }
.ocb-appro-item.is-open .ocb-appro-head .chev { transform: rotate(180deg); }
.ocb-appro-body { display: none; padding: 0 15px 15px; font-size: 13.5px; line-height: 1.6; color: var(--oc-text-2); }
.ocb-appro-item.is-open .ocb-appro-body { display: block; }
.ocb-appro-body ul { margin: 0; padding-left: 18px; }

/* ───────────── Chat (destra) ───────────── */
.ocb-chat-idle { padding: 24px; color: var(--oc-text-3); font-size: 13px; line-height: 1.5; }
.ocb-chat-head { padding: 16px 18px 12px; border-bottom: 1px solid var(--oc-border); }
.ocb-chat-head h2 { display: flex; align-items: center; gap: 8px; font-family: "Lora", serif; font-size: 16px; font-weight: 600; color: var(--oc-primary); margin: 0 0 5px; }
.ocb-chat-head h2 .mk { width: 22px; height: 22px; border-radius: 6px; display: grid; place-items: center; background: var(--oc-primary); color: #fff; font-family: "Lora", serif; font-size: 12px; }
.ocb-chat-scope { font-size: 12px; color: var(--oc-text-3); line-height: 1.4; }
.ocb-chat-scope b { color: var(--oc-text-2); }
.ocb-msgs { flex: 1; overflow-y: auto; padding: 16px 18px; display: flex; flex-direction: column; gap: 16px; }
.ocb-msg-user { align-self: flex-end; max-width: 88%; background: var(--oc-accent-light); color: var(--oc-primary);
    padding: 9px 13px; border-radius: 13px 13px 4px 13px; font-size: 13.5px; line-height: 1.45; }
.ocb-msg-bot { align-self: flex-start; max-width: 96%; }
.ocb-msg-bot-who { display: flex; align-items: center; gap: 7px; font-size: 12px; font-weight: 600; color: var(--oc-text-2); margin-bottom: 6px; }
.ocb-msg-bot-who .mk { width: 19px; height: 19px; border-radius: 5px; display: grid; place-items: center; background: var(--oc-primary); color: #fff; font-family: "Lora", serif; font-size: 11px; }
.ocb-consulted { display: inline-flex; align-items: center; gap: 7px; font-size: 11.5px; color: var(--oc-text-3);
    background: var(--oc-bg-2); padding: 5px 10px; border-radius: 999px; margin-bottom: 8px; }
.ocb-consulted b { color: var(--oc-text-2); font-weight: 600; }
.ocb-msg-text { font-size: 13.5px; line-height: 1.55; color: var(--oc-text); }
.ocb-msg-text p { margin: 0 0 8px; }
.ocb-cite-ref { font-family: "Roboto Mono", monospace; font-size: 10px; vertical-align: super;
    background: var(--oc-accent-light); color: var(--oc-accent-dark); padding: 0 4px; border-radius: 4px; margin: 0 1px; }
.ocb-cites { margin-top: 10px; display: flex; flex-direction: column; gap: 6px; }
.ocb-cite { display: flex; gap: 8px; align-items: flex-start; padding: 8px 10px; border: 1px solid var(--oc-border);
    border-radius: 8px; background: var(--oc-bg-2); font-size: 12px; text-decoration: none; color: inherit; }
.ocb-cite:hover { border-color: var(--oc-accent); }
.ocb-cite-n { font-family: "Roboto Mono", monospace; font-size: 11px; width: 18px; height: 18px; flex: 0 0 auto;
    display: grid; place-items: center; border-radius: 5px; background: var(--oc-accent-light); color: var(--oc-accent-dark); }
.ocb-cite-t { color: var(--oc-text); font-weight: 600; }
.ocb-cite-s { color: var(--oc-text-3); }

.ocb-suggest { padding: 0 18px 12px; }
.ocb-suggest-title { font-size: 10.5px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; color: var(--oc-text-3); margin-bottom: 8px; }
.ocb-suggest-chips { display: flex; flex-wrap: wrap; gap: 7px; }
.ocb-suggest-chip { font: inherit; font-size: 12.5px; padding: 6px 12px; border-radius: 999px; cursor: pointer;
    background: var(--oc-bg); border: 1px solid var(--oc-border); color: var(--oc-text-2); }
.ocb-suggest-chip:hover { border-color: var(--oc-accent); color: var(--oc-accent-dark); }

.ocb-composer { padding: 12px 16px 8px; border-top: 1px solid var(--oc-border); }
.ocb-composer-box { display: flex; align-items: flex-end; gap: 8px; padding: 8px 10px; border-radius: 11px;
    border: 1px solid var(--oc-border); background: var(--oc-bg); }
.ocb-composer-box:focus-within { border-color: var(--oc-accent); }
.ocb-composer textarea { flex: 1; border: 0; outline: none; resize: none; font: inherit; font-size: 13.5px;
    line-height: 1.4; max-height: 110px; color: var(--oc-text); background: transparent; }
.ocb-send { flex: 0 0 auto; display: inline-flex; align-items: center; gap: 5px; font: inherit; font-size: 13px; font-weight: 600;
    padding: 7px 13px; border-radius: 8px; border: 0; cursor: pointer; background: var(--oc-primary); color: #fff; }
.ocb-send:disabled { opacity: .5; cursor: default; }
.ocb-composer-hint { font-size: 11px; color: var(--oc-text-4); padding: 6px 4px 0; }
.ocb-trust { padding: 9px 18px 16px; font-size: 11px; color: var(--oc-text-4); line-height: 1.45;
    display: flex; gap: 7px; align-items: flex-start; }

/* ───────────── Skeleton ───────────── */
.ocb-skel { background: linear-gradient(90deg, var(--oc-bg-3) 25%, var(--oc-bg-2) 50%, var(--oc-bg-3) 75%);
    background-size: 200% 100%; animation: ocb-shimmer 1.3s infinite; border-radius: 9px; }
.ocb-skel-tile { height: 34px; margin-bottom: 4px; }
.ocb-skel-card { height: 92px; }
@keyframes ocb-shimmer { from { background-position: 200% 0; } to { background-position: -200% 0; } }

/* typing dots */
.ocb-typing { display: inline-flex; gap: 4px; padding: 4px 0; }
.ocb-typing span { width: 6px; height: 6px; border-radius: 50%; background: var(--oc-text-4); animation: ocb-blink 1.2s infinite both; }
.ocb-typing span:nth-child(2) { animation-delay: .2s; }
.ocb-typing span:nth-child(3) { animation-delay: .4s; }
@keyframes ocb-blink { 0%, 80%, 100% { opacity: .25; } 40% { opacity: 1; } }

/* ───────────── Responsive (sotto 1100px → stack) ───────────── */
@media (max-width: 1100px) {
    .ocb-layout { grid-template-columns: 1fr; height: auto; overflow: visible; }
    .ocb-nav, .ocb-cockpit, .ocb-chat { height: auto; overflow: visible; border: 0; }
    .ocb-nav { border-bottom: 1px solid var(--oc-border); }
    .ocb-chat { border-top: 1px solid var(--oc-border); }
    .ocb-search-global { display: none; }
    .ocb-dati-grid { grid-template-columns: 1fr; }
}
