/* =============================================================================
   MOVAT — Design G (tema condiviso)
   Variabili CSS dei token di riferimento (mockup/). Questo file è incluso
   automaticamente tramite {% include "components/head.html" %} e affiancato
   alla config Tailwind inline: quando un componente custom non ha il token
   direttamente nel Tailwind (es. CSS in file esterni o gradienti) usa queste
   variabili.
   ========================================================================= */

:root {
    --mv-bg:        #FAF6EE;
    --mv-surface:   #FFFFFF;
    --mv-cream:     #F3EADB;
    --mv-line:      #E6DDCC;
    --mv-ink:       #231F1C;
    --mv-ink-dim:   #7A6E64;

    --mv-brand:       #4CAE7C;
    --mv-brand-soft:  #DCEEE3;
    --mv-brand-deep:  #2A7A54;

    --mv-terra:       #C8774B;
    --mv-terra-soft:  #F5E2D2;
    --mv-terra-deep:  #8B3E1E;

    --mv-sun:         #E2B24A;
    --mv-sun-soft:    #F7EAC7;
    --mv-sun-deep:    #8B5F12;

    --mv-danger:      #B8422E;
    --mv-danger-soft: #F4DAD3;

    --mv-serif: "Instrument Serif", ui-serif, Georgia, Cambria, serif;
    --mv-sans:  "Inter Tight", Inter, ui-sans-serif, system-ui, sans-serif;
    --mv-mono:  "Geist Mono", ui-monospace, SFMono-Regular, Menlo, monospace;

    --mv-radius-sm: 8px;
    --mv-radius:    12px;
    --mv-radius-lg: 18px;
    --mv-radius-xl: 24px;

    --mv-space-1: 4px;
    --mv-space-2: 8px;
    --mv-space-3: 12px;
    --mv-space-4: 16px;
    --mv-space-5: 24px;
    --mv-space-6: 32px;
    --mv-space-7: 48px;
    --mv-space-8: 64px;

    --mv-shadow-sm: 0 1px 0 rgba(35, 31, 28, 0.04);
    --mv-shadow:    0 2px 8px -2px rgba(35, 31, 28, 0.06);
    --mv-shadow-lg: 0 12px 32px -8px rgba(35, 31, 28, 0.12);
}

/* Dark mode: rimappa i token su palette scura mantenendo il contrasto cream/brand. */
html.dark {
    --mv-bg:        #16130F;
    --mv-surface:   #231F1C;
    --mv-cream:     #2D2824;
    --mv-line:      #3D3730;
    --mv-ink:       #FAF6EE;
    --mv-ink-dim:   #A19287;

    --mv-brand-soft: #1E5C3F;
    --mv-terra-soft: #5C3424;
    --mv-sun-soft:   #5C4420;
    --mv-danger-soft:#5C241C;
}

/* =============================================================================
   Utility classes (usate dai macro ui.html e dai template per coerenza)
   ========================================================================= */
.bg-theme-light { background: var(--mv-bg); }
.bg-theme-dark  { background: var(--mv-bg); }

.text-ink     { color: var(--mv-ink); }
.text-ink-dim { color: var(--mv-ink-dim); }

.border-line  { border-color: var(--mv-line); }

.font-serif   { font-family: var(--mv-serif); font-weight: 400; }
.font-display { font-family: var(--mv-serif); font-weight: 400; letter-spacing: -0.02em; }

/* Titolo serif editoriale (hero) */
.mv-title {
    font-family: var(--mv-serif);
    font-weight: 400;
    letter-spacing: -0.02em;
    line-height: 1.02;
    color: var(--mv-ink);
}

/* Kicker piccolo sopra titoli (MAIUSCOLO + tracking) */
.mv-kicker {
    font-size: 10.5px;
    line-height: 1.2;
    font-weight: 600;
    font-family: var(--mv-sans);
    color: var(--mv-ink-dim);
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

/* =============================================================================
   Scala tipografica
   ========================================================================= */

.mv-display {
    font-family: var(--mv-serif);
    font-size: 56px;
    line-height: 1.0;
    font-weight: 400;
    letter-spacing: -0.02em;
}

.mv-h1 {
    font-family: var(--mv-serif);
    font-size: 40px;
    line-height: 1.05;
    font-weight: 400;
    letter-spacing: -0.02em;
}

.mv-h2 {
    font-family: var(--mv-serif);
    font-size: 28px;
    line-height: 1.1;
    font-weight: 400;
    letter-spacing: -0.015em;
}

.mv-h3 {
    font-family: var(--mv-serif);
    font-size: 20px;
    line-height: 1.2;
    font-weight: 400;
    letter-spacing: -0.01em;
}

.mv-body-lg {
    font-size: 16px;
    line-height: 1.55;
    font-weight: 400;
}

.mv-body {
    font-size: 14px;
    line-height: 1.5;
    font-weight: 400;
}

.mv-body-sm {
    font-size: 13px;
    line-height: 1.45;
    font-weight: 400;
}

.mv-caption {
    font-size: 11.5px;
    line-height: 1.3;
    font-weight: 400;
}

.mv-kpi-num {
    font-family: var(--mv-serif);
    font-size: 60px;
    line-height: 0.9;
    font-weight: 400;
    letter-spacing: -0.03em;
}

/* Card base */
.mv-card {
    background: var(--mv-surface);
    border: 1px solid var(--mv-line);
    border-radius: var(--mv-radius-lg);
}

/* Pulsanti principali (replica mockup: pill nero per primario, pill outline) */
.mv-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 10px 18px;
    border-radius: 9999px;
    font-size: 13px;
    font-weight: 500;
    font-family: inherit;
    cursor: pointer;
    transition: background .15s, color .15s, border-color .15s, transform .1s;
    border: 1px solid transparent;
    white-space: nowrap;
}
.mv-btn:active { transform: translateY(0.5px); }

.mv-btn-primary {
    background: var(--mv-ink);
    color: var(--mv-surface);
}
.mv-btn-primary:hover { background: #2D2824; }

.mv-btn-secondary {
    background: var(--mv-surface);
    color: var(--mv-ink);
    border-color: var(--mv-line);
}
.mv-btn-secondary:hover { background: var(--mv-cream); }

.mv-btn-ghost {
    background: transparent;
    color: var(--mv-ink);
}
.mv-btn-ghost:hover { background: var(--mv-cream); }

.mv-btn-danger {
    background: transparent;
    color: var(--mv-danger);
    border-color: rgba(184, 66, 46, 0.25);
}
.mv-btn-danger:hover { background: var(--mv-danger-soft); }

.mv-btn-brand {
    background: var(--mv-brand);
    color: var(--mv-surface);
}
.mv-btn-brand:hover { background: var(--mv-brand-deep); }

/* Input */
.mv-input {
    width: 100%;
    padding: 11px 14px;
    border: 1px solid var(--mv-line);
    border-radius: var(--mv-radius);
    font-size: 14px;
    font-family: inherit;
    background: var(--mv-surface);
    color: var(--mv-ink);
    transition: border-color .15s, box-shadow .15s;
}
.mv-input::placeholder { color: var(--mv-ink-dim); }
.mv-input:focus {
    outline: none;
    border-color: var(--mv-brand);
    box-shadow: 0 0 0 3px var(--mv-brand-soft);
}

.mv-label {
    display: block;
    font-size: 12px;
    line-height: 1.3;
    font-weight: 600;
    font-family: var(--mv-sans);
    color: var(--mv-ink-dim);
    margin-bottom: 6px;
}

/* Badge / chip */
.mv-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 8px;
    border-radius: 9999px;
    font-size: 10.5px;
    font-weight: 600;
    letter-spacing: 0.01em;
    white-space: nowrap;
}
.mv-badge-green   { background: var(--mv-brand-soft);   color: var(--mv-brand-deep); }
.mv-badge-red     { background: var(--mv-danger-soft);  color: var(--mv-danger); }
.mv-badge-amber   { background: var(--mv-sun-soft);     color: var(--mv-sun-deep); }
.mv-badge-neutral { background: var(--mv-cream);        color: var(--mv-ink-dim); }
.mv-badge-terra   { background: var(--mv-terra-soft);   color: var(--mv-terra-deep); }

/* Chip filter (gruppo a pillole, come mockup) */
.mv-chip {
    padding: 7px 14px;
    border-radius: 9999px;
    border: 1px solid var(--mv-line);
    background: var(--mv-surface);
    color: var(--mv-ink);
    font-size: 12.5px;
    font-family: inherit;
    cursor: pointer;
    white-space: nowrap;
    transition: background .15s, color .15s, border-color .15s;
}
.mv-chip:hover { background: var(--mv-cream); }
.mv-chip.is-active {
    background: var(--mv-ink);
    color: var(--mv-surface);
    border-color: var(--mv-ink);
    font-weight: 500;
}

/* KPI tile (replica mockup VG_Tile) */
.mv-kpi {
    padding: 20px;
    background: var(--mv-surface);
    border: 1px solid var(--mv-line);
    border-radius: var(--mv-radius-lg);
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.mv-kpi__halo {
    position: absolute; top: -18px; right: -18px;
    width: 64px; height: 64px; border-radius: 32px;
    opacity: 0.12;
    pointer-events: none;
}
.mv-kpi__label {
    font-size: 11.5px;
    color: var(--mv-ink-dim);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-weight: 600;
}
.mv-kpi__value {
    font-family: var(--mv-serif);
    font-size: 60px;
    line-height: 0.9;
    letter-spacing: -0.03em;
    color: var(--mv-ink);
}
.mv-kpi__hint {
    font-size: 12px;
    color: var(--mv-ink-dim);
}

/* Progress bar sottile (ingressi pacchetti, occupazione corsi) */
.mv-progress {
    height: 6px;
    background: var(--mv-cream);
    border-radius: 3px;
    overflow: hidden;
}
.mv-progress__bar {
    height: 100%;
    background: var(--mv-brand);
    border-radius: 3px;
    transition: width .3s;
}

/* Divider */
.mv-divider {
    height: 1px;
    background: var(--mv-line);
    width: 100%;
    border: 0;
    margin: 16px 0;
}

/* Tabular numbers default per tabelle */
table, .mv-tabular, .mv-num { font-variant-numeric: tabular-nums; }

/* Scrollbar sottile */
@media (min-width: 768px) {
    ::-webkit-scrollbar { width: 10px; height: 10px; }
    ::-webkit-scrollbar-track { background: transparent; }
    ::-webkit-scrollbar-thumb { background: var(--mv-line); border-radius: 10px; border: 2px solid var(--mv-bg); }
    ::-webkit-scrollbar-thumb:hover { background: var(--mv-ink-dim); }
}
