/* ══════════════════════════════════════════════════════════════════════════════
   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:        #E8E0D4;   /* sfondo pagina — lino naturale */
    --surface-light:       #F7F3EE;   /* card detail e index */
    --surface-soft:        #FAF8F4;   /* formset interni */
    --surface-index:       #F7F3EE;
    --surface-white:       #FEFCFA;   /* bianco caldo */

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

    /* Tipografia */
    --font-serif:  'Source Serif 4', 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;
}

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


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

/* ── Titoli di pagina e modal ─────────────────────────────────────────────── */

h1 {
    font-family: var(--font-serif);
    font-size: 1.5rem;
    font-weight: 500;
    color: var(--color-dark);
    letter-spacing: -0.3px;
    line-height: 1.2;
    min-width: 0;
}

h1 > 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.75rem;
    font-weight: 600;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--color-muted);
}

/*
  text-meta
  Riga di metadati sotto il titolo.
*/
.text-meta {
    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;
}

.text-block {
    text-align: justify;
    hyphens: auto;
}

.text-long {
    font-family: var(--font-serif);
}

.note-content {
    overflow: hidden;
    transition: max-height 0.35s ease;
}

.note-toggle {
    display: block;
    text-align: right;
    font-size: 0.8rem;
}

.note-toggle-icon {
    display: inline-block;
    transition: transform 0.25s ease;
    font-size: 0.7rem;
}

.note-toggle[data-expanded="true"] .note-toggle-icon {
    transform: rotate(180deg);
}

/*
  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 {
    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 {
    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: 0.875rem;
    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: 0.875rem;
    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: 0.875rem;
    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.125rem 0.375rem;
    font-size: 0.875rem;
    line-height: 1.25;
    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);
}

/* btn-tertiary btn-success — azione positiva discreta */
.btn-tertiary.btn-success {
    color: var(--color-success);
}
.btn-tertiary.btn-success:hover {
    color: var(--color-success-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 1.5rem;
    margin-bottom: 1rem;
    font-size: 0.875rem;
}



.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 {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-shrink: 0;
}

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

.order-buttons {
    display: flex;
    flex-direction: column;
    width: 2rem;
    align-self: stretch;
}

.order-btn {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    line-height: 1;
    font-size: 0.65rem;
}


/* ── 8. FILTER FIELDS ROW ────────────────────────────────────────────────── */

/*
  filter-fields-row
  Contenitore per i campi dei filtri di ricerca: massimo 3 per riga,
  i campi si espandono per riempire lo spazio se sono meno di 3.
*/
.filter-fields-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}
.filter-fields-row > * {
    flex: 1 1 calc(33.333% - 0.5rem);
    min-width: 0;
}
.filter-fields-row > * .ts-wrapper {
    width: 100% !important;
}
/* Dropdown TomSelect appesi al body (dropdownParent) devono stare sopra il modal */
body > .ts-dropdown {
    z-index: 1060 !important;
}

.filter-fields-row__date-pair {
    display: flex;
    gap: 0.5rem;
}
.filter-fields-row__date-pair > * {
    flex: 1 1 0;
    min-width: 0;
}
input[type="date"].form-control::-webkit-datetime-edit {
    color: var(--color-muted);
}


/* ── Flatpickr — override stili per integrazione con il tema ─────────────── */
.flatpickr-calendar {
    font-family: var(--font-system);
    font-size: 0.875rem;
    border: var(--border-width) solid var(--border-color-default);
    border-radius: var(--radius-md);
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}
.flatpickr-day.selected,
.flatpickr-day.selected:hover {
    background: var(--color-accent);
    border-color: var(--color-accent);
}
.flatpickr-day:hover {
    background: var(--surface-soft);
}
.flatpickr-months .flatpickr-month,
.flatpickr-weekdays {
    background: var(--surface-light);
    color: var(--color-dark);
}
.flatpickr-current-month .flatpickr-monthDropdown-months,
.flatpickr-current-month input.cur-year {
    font-family: var(--font-system);
    color: var(--color-dark);
}

/* ── 9. PANNELLO FILTRI INDEX ─────────────────────────────────────────────── */

/*
  index-filter-btn--active
  Stato attivo del pulsante filtro (almeno un filtro selezionato).
*/
.index-filter-btn--active {
    color: var(--color-accent);
}
.index-filter-btn--active:hover {
    color: var(--color-primary-dark);
}

/*
  index-filter-panel
  Dropdown che contiene il form di filtro.
*/
.index-filter-panel {
    position: absolute;
    top: calc(100% + 6px);
    right: 0;
    z-index: 300;
    background: var(--surface-light);
    border: var(--border-width) solid var(--border-color-default);
    border-radius: var(--radius-md);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
    padding: 0.75rem;
    min-width: 220px;
    max-width: 290px;
}

.index-filter-panel__label {
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--color-muted);
    margin: 0.6rem 0 0.3rem;
}
.index-filter-panel__label:first-child {
    margin-top: 0;
}

.index-filter-panel__group {
    display: flex;
    flex-wrap: wrap;
    gap: 0.2rem 0.75rem;
}

.index-filter-panel__check {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.82rem;
    color: var(--color-dark);
    cursor: pointer;
    user-select: none;
    white-space: nowrap;
}
.index-filter-panel__check input {
    flex-shrink: 0;
    cursor: pointer;
    accent-color: var(--color-accent);
    width: 0.85rem;
    height: 0.85rem;
}

.index-filter-panel__select {
    width: 100%;
    font-size: 0.82rem;
    font-family: var(--font-system);
    color: var(--color-dark);
    background-color: var(--surface-white);
    border: var(--border-width) solid var(--border-color-default);
    border-radius: var(--radius-sm);
    padding: 0.2rem 0;
    outline: none;
}
.index-filter-panel__select option {
    padding: 0.2rem 0.5rem;
}
.index-filter-panel__select option:checked {
    background-color: rgba(165, 42, 42, 0.12);
    color: var(--color-dark);
}

.index-filter-panel__actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 0.75rem;
    padding-top: 0.6rem;
    border-top: var(--border-width) solid var(--border-color-default);
    gap: 0.5rem;
}


/* ── 9. 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;
}


/* ── 10. HOME PAGE ────────────────────────────────────────────────────────── */

.home-hero {
    padding-top: 2rem;
    padding-bottom: 1.5rem;
}

.home-hero__ornament {
    font-size: 1rem;
    color: var(--color-accent);
    opacity: 0.6;
    letter-spacing: 0.5em;
    margin-bottom: 0.5rem;
}

.home-hero__title {
    font-size: 2.4rem;
    font-weight: 700;
    letter-spacing: -0.5px;
}

.home-hero__tagline {
    font-family: var(--font-serif);
    font-size: 1rem;
    font-style: italic;
    color: var(--color-secondary);
    margin-top: 0.3rem;
    margin-bottom: 0;
}

.home-stat-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.15rem;
    padding: 1.25rem 1rem;
    height: 100%;
    background-color: var(--surface-light);
    border: var(--border-width) solid var(--border-color-default);
    border-radius: var(--radius-md);
    text-decoration: none;
    color: inherit;
    transition: background-color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
    text-align: center;
}

.home-stat-card:hover {
    background-color: var(--surface-soft);
    border-color: var(--color-secondary);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
    color: inherit;
    text-decoration: none;
}

.home-stat-card__count {
    font-family: var(--font-serif);
    font-size: 2.4rem;
    font-weight: 500;
    line-height: 1;
    color: var(--color-dark);
}

.home-stat-card__label {
    font-family: var(--font-system);
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--color-muted);
    margin-top: 0.3rem;
}


/* ── 11. TEXTAREA EXPAND MODAL + BUTTON ──────────────────────────────────── */

/* Modal dimensione fissa */
.textarea-expand-dialog {
    height: 80vh;
    max-height: 80vh;
}

.textarea-expand-content {
    height: 100%;
    display: flex;
    flex-direction: column;
}

.textarea-expand-body {
    flex: 1 1 0;
    min-height: 0;
    display: flex;
    flex-direction: column;
    padding-bottom: 0.5rem;
}

.textarea-expand-editor {
    flex: 1 1 0;
    min-height: 0;
    width: 100%;
    resize: none;
    overflow-y: auto;
}



/* ── 12. TEXTAREA EXPAND BUTTON ──────────────────────────────────────────── */

.textarea-expand-wrap {
    position: relative;
}

.btn-textarea-expand {
    position: absolute;
    bottom: 0.2rem;
    right: 0.2rem;
    z-index: 2;
    font-size: 0.65rem;
    padding: 0.1rem 0.25rem;
    background-color: white;
}

.btn-textarea-expand--scrollbar {
    right: 1rem;
}


/* ── 12. BACK TO TOP ──────────────────────────────────────────────────────── */

.back-to-top {
    position: fixed;
    bottom: 1.5rem;
    right: 1.5rem;
    z-index: 500;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease;
    background: var(--surface-page);
    border-radius: var(--radius-sm, 4px);
    padding: 0.25rem 0.5rem;
}

.back-to-top.is-visible {
    opacity: 1;
    pointer-events: auto;
}

.back-to-top:hover,
.back-to-top:focus,
.back-to-top:active {
    background: var(--surface-page) !important;
}

@media (max-width: 767.98px) {
    .back-to-top {
        right: auto;
        left: 1.5rem;
    }
}

