/* ══════════════════════════════════════════════════════════════════════════════
   COMPONENTS.CSS  —  Design system "Scriptorium Moderno"
   ──────────────────────────────────────────────────────────────────────────────
   REGOLA: HTML e Python usano solo classi semantiche definite qui.
           Le classi Bootstrap e i valori numerici si toccano SOLO in questo file.

   STRUTTURA:
     1. Token  — variabili CSS per colori, font, radii, shadow
     2. Base   — body, selezione testo
     3. Tipografia — heading-page, heading-section, text-meta, text-meta-token
     4. Link    — link-content, link-back, link-citation
     5. Bottoni — tre stili base + modificatori colore
                  btn-primary  : CTA, Salva, Pubblica, Nuovo   (pieno)
                  btn-secondary: Annulla, Indietro, Nuova riga  (outline)
                  btn-tertiary : Modifica, Scopri di più        (testo/icona)
                  Modificatori: btn-success, btn-warning, btn-error
     6. Badge / tag — status-badge (+ modificatori), tag
     7. Card di riga formset — card-row, card-row--soft, card-row--compact
                               card-row-header, card-row-title-wrap,
                               card-row-title, card-row-actions
     8. Sezioni form — section-upload, input-readonly
   ══════════════════════════════════════════════════════════════════════════════ */


/* ── 1. TOKEN ─────────────────────────────────────────────────────────────── */

:root {
    /* Colori principali */
    --color-accent:        #A52A2A;   /* vermiglio — accento dominante */
    --color-primary:       #A52A2A;
    --color-primary-dark:  #8B1F1F;
    --color-primary-focus: rgba(165, 42, 42, 0.25);
    --color-danger:        #A52A2A;
    --color-danger-focus:  rgba(165, 42, 42, 0.25);
    --color-secondary:     #6c6860;   /* grigio caldo */
    --color-secondary-dark:#4f4b44;
    --color-secondary-focus: rgba(108, 104, 96, 0.25);
    --color-dark:          #1C1C1C;   /* inchiostro di carbone */
    --color-dark-focus:    rgba(28, 28, 28, 0.25);
    --color-success:       #2C3E6B;   /* blu inchiostro — bottoni primari, Pubblica, dot completo */
    --color-success-dark:  #1E2E52;
    --color-success-focus: rgba(44, 62, 107, 0.25);
    --color-warning:       #c8993a;   /* ocra, coerente con pergamena */
    --color-muted:         #8a8278;

    /* Superfici */
    --surface-page:        #DDD8CF;   /* sfondo pagina — pergamena scura */
    --surface-light:       #F5F2ED;   /* pergamena — card detail e index */
    --surface-soft:        #F9F7F3;   /* pergamena chiara — formset interni */
    --surface-index:       #F5F2ED;
    --surface-white:       #FEFCF9;   /* bianco caldo */

    /* Bordi */
    --border-color-default: #d6d0c8;
    --border-color-row:     #ddd8d0;
    --border-color-concept: #d4d8cc;
    --border-color-document:#d8d3c8;
    --border-width:         0.5px;

    /* Tipografia */
    --font-serif:  'EB Garamond', Georgia, 'Times New Roman', serif;
    --font-system: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

    /* Radii — angoli contenuti, stile carta tagliata */
    --radius-sm:   0.2rem;
    --radius-md:   0.3rem;
    --radius-lg:   0.4rem;
    --radius-pill: 50rem;

    /* Transizione base */
    --transition-btn: color 0.15s ease-in-out, background-color 0.15s ease-in-out,
                      border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;

    /* Etichette di riga */
    --row-label-color: var(--color-muted);
    --row-border-color: var(--border-color-row);
}


/* ── 2. BASE ──────────────────────────────────────────────────────────────── */

body {
    font-family: var(--font-system);
    font-size: 1rem;
    line-height: 1.6;
    color: var(--color-dark);
    background-color: var(--surface-page);
}

/* Sovrascrive text-primary Bootstrap con il vermiglio del design system */
.text-primary {
    color: var(--color-accent) !important;
    font-family: var(--font-serif);
}

::selection {
    background-color: rgba(165, 42, 42, 0.15);
    color: var(--color-dark);
}


/* ── 3. TIPOGRAFIA ────────────────────────────────────────────────────────── */

/*
  heading-page
  Titolo principale di una pagina di dettaglio (h1).
*/
.heading-page {
    font-family: var(--font-serif);
    font-weight: 500;
    color: var(--color-dark);
    letter-spacing: -0.3px;
    line-height: 1.2;
    min-width: 0;
}

.heading-page > strong {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
}

/*
  heading-section
  Etichetta di sezione in maiuscolo sopra i blocchi di contenuto.
  Drop cap via ::first-letter sul primo paragrafo figlio (se presente).
*/
.heading-section {
    display: block;
    margin-bottom: 0.5rem;
    font-family: var(--font-system);
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--color-muted);
}

/*
  text-meta
  Riga di metadati sotto il titolo.
*/
.text-meta {
    font-size: 0.875rem;
    color: var(--color-secondary);
    margin-top: 0.25rem;
    font-family: var(--font-system);
}

/*
  text-meta-token
  Singolo token nella riga meta (es. "TERM", "IT", "NOUN").
*/
.text-meta-token {
    font-size: 0.75rem;
    letter-spacing: 0.8px;
    text-transform: uppercase;
    font-family: var(--font-system);
}

/*
  text-citation
  Testo piccolo corsivo per riferimenti bibliografici inline.
*/
.text-citation {
    font-size: 0.875em;
    color: var(--color-accent);
    font-family: var(--font-serif);
}

/*
  section-block
  Blocchi di testo lungo (note, definizioni, attestazioni, trascrizioni).
*/
.section-block {
    text-align: justify;
    hyphens: auto;
}

/*
  form-hint
  Messaggio contestuale nei form (istruzioni, avvisi inline).
  Sostituisce: alert alert-light/alert-info border border-dashed + classi Bootstrap varie.
*/
.form-hint {
    display: block;
    padding: 0.5rem 0.75rem;
    font-size: 0.875rem;
    color: var(--color-muted);
    background-color: var(--surface-soft);
    border: var(--border-width) dashed var(--border-color-default);
    border-radius: var(--radius-md);
    text-align: center;
}


/* ── 4. LINK ──────────────────────────────────────────────────────────────── */

/*
  link-content
  Link interno all'applicazione.
*/
.link-content {
    font-family: var(--font-serif);
    color: var(--color-accent);
    text-decoration: none;
}
.link-content:hover {
    text-decoration: underline;
    color: var(--color-primary-dark);
}

/*
  link-disabled
  Testo non cliccabile per record non accessibili agli utenti anonimi
  (draft, deprecated, external). Nessun colore di accento, nessun cursore pointer.
*/
.link-disabled {
    font-family: var(--font-serif);
    color: var(--color-secondary);
    cursor: default;
}

/*
  link-back
  Link di navigazione "← Torna alla lista" (stile testo, non bottone).
*/
.link-back {
    font-size: 0.875rem;
    color: var(--color-secondary);
    text-decoration: none;
}
.link-back:hover {
    color: var(--color-dark);
}


/* ── 5. BOTTONI ───────────────────────────────────────────────────────────── */

/*
  BASE CONDIVISA (non usare direttamente in HTML)
  Tre stili base: btn-primary, btn-secondary, btn-tertiary
  Modificatori colore: btn-success, btn-warning, btn-error
*/
.btn-primary,
.btn-secondary,
.btn-tertiary {
    display: inline-block;
    font-family: var(--font-system);
    font-weight: 500;
    line-height: 1.5;
    text-align: center;
    text-decoration: none;
    vertical-align: middle;
    cursor: pointer;
    user-select: none;
    border: 1px solid transparent;
    transition: var(--transition-btn);
    box-shadow: none;
}

/*
  btn-primary
  CTA, Salva, Pubblica, Nuovo — pieno, colore dominante (blu inchiostro).
  Con modificatori: btn-success (verde), btn-warning (ocra), btn-error (vermiglio).
*/
.btn-primary {
    padding: 0.375rem 1.5rem;
    font-size: 1rem;
    border-radius: var(--radius-md);
    color: #fff;
    background-color: var(--color-success);
    border-color: var(--color-success);
}
.btn-primary:hover {
    color: #fff;
    background-color: var(--color-success-dark);
    border-color: var(--color-success-dark);
}
.btn-primary:focus {
    color: #fff;
    background-color: var(--color-success-dark);
    border-color: var(--color-success-dark);
    box-shadow: 0 0 0 0.2rem var(--color-success-focus);
    outline: 0;
}

/* btn-primary btn-success — Pubblica */
.btn-primary.btn-success {
    background-color: var(--color-success);
    border-color: var(--color-success);
}
.btn-primary.btn-success:hover {
    background-color: var(--color-success-dark);
    border-color: var(--color-success-dark);
}
.btn-primary.btn-success:focus {
    background-color: var(--color-success-dark);
    border-color: var(--color-success-dark);
    box-shadow: 0 0 0 0.2rem var(--color-success-focus);
    outline: 0;
}

/* btn-primary btn-warning — Modifica (pagina dettaglio) */
.btn-primary.btn-warning {
    background-color: var(--color-warning);
    border-color: var(--color-warning);
}
.btn-primary.btn-warning:hover {
    background-color: #b3862e;
    border-color: #a87c2b;
}
.btn-primary.btn-warning:focus {
    background-color: #b3862e;
    border-color: #a87c2b;
    box-shadow: 0 0 0 0.2rem rgba(200, 153, 58, 0.35);
    outline: 0;
}

/* btn-primary btn-error — Azione distruttiva confermata (es. Confirm nel modal) */
.btn-primary.btn-error {
    background-color: var(--color-danger);
    border-color: var(--color-danger);
}
.btn-primary.btn-error:hover {
    background-color: var(--color-primary-dark);
    border-color: var(--color-primary-dark);
}
.btn-primary.btn-error:focus {
    background-color: var(--color-primary-dark);
    border-color: var(--color-primary-dark);
    box-shadow: 0 0 0 0.2rem var(--color-danger-focus);
    outline: 0;
}

/* Split dropdown companion nel btn-group */
.btn-group > .btn-primary.dropdown-toggle-split {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
    border-left: 1px solid rgba(255, 255, 255, 0.3);
}

/* Raccordo border-radius nei btn-group */
.btn-group > .btn-primary:not(.dropdown-toggle-split) {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}
.btn-group > .btn-primary.dropdown-toggle-split {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

/*
  btn-secondary
  Annulla, Indietro, Nuova riga — outline, grigio caldo.
  Con modificatori: btn-error (vermiglio outline, es. elimina riga formset).
*/
.btn-secondary {
    padding: 0.375rem 0.75rem;
    font-size: 1rem;
    border-radius: var(--radius-md);
    color: var(--color-secondary);
    background-color: transparent;
    border-color: var(--color-secondary);
}
.btn-secondary:hover {
    color: var(--color-dark);
    background-color: transparent;
    border-color: var(--color-dark);
}
.btn-secondary:focus {
    box-shadow: 0 0 0 0.2rem var(--color-secondary-focus);
    outline: 0;
}

/* btn-secondary btn-error — outline vermiglio, dimensione standard */
.btn-secondary.btn-error {
    padding: 0.375rem 0.75rem;
    font-size: 1rem;
    border-radius: var(--radius-md);
    color: var(--color-danger);
    border-color: var(--color-danger);
}

/* btn-secondary btn-error btn-sm — variante piccola per icone inline (es. Delete PDF, elimina riga formset) */
.btn-secondary.btn-error.btn-sm {
    padding: 0.25rem 0.5rem;
    font-size: 0.875rem;
    border-radius: var(--radius-sm);
}
.btn-secondary.btn-error:hover {
    color: #fff;
    background-color: var(--color-danger);
    border-color: var(--color-danger);
}
.btn-secondary.btn-error:focus {
    box-shadow: 0 0 0 0.2rem var(--color-danger-focus);
    outline: 0;
}

/*
  btn-tertiary
  Modifica inline, Scopri di più — molto discreto, solo testo o icona cliccabile,
  nessun bordo né sfondo visibile a riposo.
*/
.btn-tertiary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.25rem 0.375rem;
    font-size: 0.875rem;
    border-radius: var(--radius-sm);
    color: var(--color-secondary);
    background-color: transparent;
    border: none;
    cursor: pointer;
}
.btn-tertiary:hover {
    color: var(--color-dark);
    background-color: transparent;
    border-color: transparent;
    text-decoration: underline;
}
.btn-tertiary:focus {
    box-shadow: 0 0 0 0.2rem var(--color-secondary-focus);
    outline: 0;
}

/* btn-tertiary icona quadrata (es. btn-edit-icon) */
.btn-tertiary.btn-icon {
    width: 2rem;
    height: 2rem;
    padding: 0;
    flex-shrink: 0;
    text-decoration: none;
}
.btn-tertiary.btn-icon:hover {
    text-decoration: none;
}


/* btn-tertiary btn-error — azione distruttiva discreta (es. Logout) */
.btn-tertiary.btn-error {
    color: var(--color-danger);
}
.btn-tertiary.btn-error:hover {
    color: var(--color-primary-dark);
}


/* ── 6. BADGE / TAG ───────────────────────────────────────────────────────── */

/* Base badge */
.status-badge,
.tag {
    display: inline-block;
    padding: 0.25em 0.6em;
    font-family: var(--font-system);
    font-size: 0.7em;
    font-weight: 600;
    letter-spacing: 0.5px;
    line-height: 1;
    text-align: center;
    text-transform: uppercase;
    white-space: nowrap;
    vertical-align: baseline;
    border-radius: var(--radius-sm);
    border: 1px solid transparent;
    color: #fff;
}

.status-badge--published {
    background-color: var(--color-success);
    border-color: var(--color-success);
}
.status-badge--draft {
    background-color: var(--color-warning);
    border-color: var(--color-warning);
}
.status-badge--deprecated {
    background-color: var(--color-secondary);
    border-color: var(--color-secondary);
}
.status-badge--external {
    background-color: var(--color-secondary);
    border-color: var(--color-secondary);
}

/*
  tag
  Etichetta generica (luoghi, domini, tassonomie).
*/
.tag {
    background-color: var(--surface-soft);
    color: var(--color-dark);
    border: var(--border-width) solid var(--border-color-default);
}


/* ── 7. CARD DI RIGA FORMSET ──────────────────────────────────────────────── */

.card-row {
    --row-label-color: var(--color-muted);
    --row-border-color: var(--border-color-row);
}

.card-row--soft {
    border: var(--border-width) solid var(--row-border-color);
    border-radius: var(--radius-md);
    background-color: var(--surface-soft);
    padding: 1rem;
    margin-bottom: 1rem;
}

.card-row--compact {
    border: var(--border-width) solid var(--border-color-default);
    border-radius: var(--radius-sm);
    background-color: var(--surface-light);
    padding: 0.5rem;
    margin-bottom: 0.5rem;
}

/* Riduzione margini interni */
.card-row .mb-3,
.card-row .mb-2 {
    margin-bottom: 0.5rem !important;
}

/* Label compatte */
.card-row .form-label,
.card-row .form-check-label {
    margin-bottom: 0.2rem;
    letter-spacing: 0.01em;
    text-transform: none;
    color: var(--row-label-color);
}

.card-row .form-control,
.card-row .form-select,
.card-row .ts-control {
    min-height: calc(1.5em + 0.6rem + 2px);
    padding-top: 0.3rem;
    padding-bottom: 0.3rem;
    font-size: 0.92rem;
}

.card-row textarea.form-control {
    min-height: 74px;
    line-height: 1.4;
}

.card-row-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.85rem;
}

.card-row-title-wrap {
    min-width: 0;
}

.card-row-title {
    display: inline-block;
    font-family: var(--font-system);
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--color-dark);
}

.card-row-actions {
    flex-shrink: 0;
}

.card-row-actions .btn-secondary.btn-error {
    width: auto;
    min-width: 2.5rem;
    padding-left: 0.7rem;
    padding-right: 0.7rem;
}


/* ── 8. SEZIONI FORM ──────────────────────────────────────────────────────── */

.section-upload {
    margin-bottom: 1.5rem;
    padding: 1rem;
    background-color: var(--surface-soft);
    border: var(--border-width) solid var(--border-color-default);
    border-radius: var(--radius-md);
}

.input-readonly {
    background-color: var(--surface-light) !important;
}
