@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&family=Cinzel:wght@400;500;600&display=swap');

/* ═══════════════════════════════════════════════════
   MAPPA DEI TALENTI v1.5
   Carte 320x620 — tutto grande e leggibile
═══════════════════════════════════════════════════ */

#mappa-talenti-app {
  --gold: #c9a96e;
  --gold-light: #e8d5a3;
  --gold-dark: #8b6914;
  --ink: #141210;
  --ink-2: #1e1b17;
  --parchment: #f0ede6;
  --parchment-dim: #b0a898;
  --border: rgba(201,169,110,0.3);
  --border-strong: rgba(201,169,110,0.65);
  --purple: #7b5ea7;
  --purple-light: #b8a0e0;

  font-family: 'Cormorant Garamond', Georgia, serif;
  color: var(--parchment);
  background: rgba(20,18,16,0.97);
  border-radius: 14px;
  padding: 2.5rem 2rem 3rem;
  max-width: 1300px;
  margin: 0 auto;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 48px rgba(0,0,0,0.5);
  box-sizing: border-box;
  width: 100%;
  max-width: 100vw;
}

#mappa-talenti-app *, #mappa-talenti-app *::before, #mappa-talenti-app *::after { box-sizing: border-box; }

#mappa-talenti-app::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 80% 40% at 50% 0%, rgba(201,169,110,0.06) 0%, transparent 60%),
    radial-gradient(ellipse 50% 30% at 90% 100%, rgba(123,94,167,0.07) 0%, transparent 55%);
  pointer-events: none; z-index: 0;
}
#mappa-talenti-app > * { position: relative; z-index: 1; }

/* ── FORM ── */
.mt-form-card {
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 1.8rem 2rem;
  margin-bottom: 2.5rem;
}
.mt-form-label {
  font-family: 'Cinzel', serif;
  font-size: .82rem;
  letter-spacing: .22em;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 1.2rem;
}
.mt-form-row { display: flex; gap: 1rem; flex-wrap: wrap; align-items: flex-end; }
.mt-field { display: flex; flex-direction: column; gap: .4rem; }
.mt-field label {
  font-size: .82rem; letter-spacing: .1em;
  color: var(--parchment-dim); text-transform: uppercase;
  font-family: 'Cinzel', serif;
}
.mt-field input {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(201,169,110,0.3);
  border-radius: 5px;
  padding: .65rem .9rem;
  color: var(--parchment);
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.2rem;
  width: 82px; outline: none;
  transition: border-color .2s;
}
.mt-field-year input { width: 108px; }
.mt-field input:focus { border-color: var(--gold); }
.mt-btn {
  font-family: 'Cinzel', serif;
  font-size: .82rem;
  letter-spacing: .15em;
  padding: .72rem 2.2rem;
  border-radius: 5px;
  cursor: pointer;
  text-transform: uppercase;
  transition: all .2s; border: none;
}
.mt-btn-primary {
  background: linear-gradient(135deg, var(--gold-dark), var(--gold));
  color: var(--ink); font-weight: 700;
}
.mt-btn-primary:hover { opacity: .88; transform: translateY(-1px); }
.mt-btn-secondary {
  background: transparent;
  border: 1px solid rgba(201,169,110,0.35);
  color: var(--parchment-dim);
}
.mt-btn-secondary:hover { border-color: var(--gold); color: var(--gold-light); }

/* ── SECTION TITLES ── */
.mt-section-title {
  font-family: 'Cinzel', serif;
  font-size: .82rem;
  letter-spacing: .28em;
  color: var(--gold);
  text-transform: uppercase;
  margin: 2.5rem 0 1.5rem;
  padding-bottom: .6rem;
  border-bottom: 1px solid var(--border-strong);
}
.mt-section-title--purple { color: var(--purple-light); border-color: rgba(123,94,167,0.4); }

/* ── CARD GRID — max 5 colonne ── */
.mt-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1.4rem;
  margin-bottom: 1rem;
  width: 100%;
  box-sizing: border-box;
}

/* ── ARCANO CARD ── */
.mt-card {
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 1.2rem 1rem 1.4rem;
  cursor: pointer;
  text-align: center;
  transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease, background .25s ease;
  opacity: 0;
  transform: translateY(16px) scale(0.97);
}
.mt-card.mt-card--visible { animation: mtCardIn .42s ease forwards; }
.mt-card:hover {
  background: rgba(201,169,110,0.07);
  border-color: var(--gold);
  transform: translateY(-5px);
  box-shadow: 0 10px 32px rgba(201,169,110,0.18);
}
.mt-card.mt-card--active {
  background: rgba(201,169,110,0.1);
  border-color: var(--gold);
  box-shadow: 0 4px 24px rgba(201,169,110,0.22);
}
@keyframes mtCardIn { to { opacity: 1; transform: translateY(0) scale(1); } }

/* Role — etichetta posizione */
.mt-card-role {
  font-family: 'Cinzel', serif;
  font-size: .78rem;
  color: var(--gold);
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  min-height: 2.4em;
  display: flex; align-items: center; justify-content: center;
  line-height: 1.25;
  margin-bottom: .8rem;
}

/* IMMAGINE — proporzione esatta 320x620 */
.mt-card-img-wrap {
  width: 100%;
  aspect-ratio: 320 / 620;
  position: relative;
  overflow: hidden;
  border-radius: 6px;
  margin-bottom: .9rem;
  background: #060606;
  border: 1px solid rgba(201,169,110,0.2);
}
.mt-card-img-wrap img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: contain;
  object-position: center center;
  display: block;
  transition: transform .4s ease;
}
.mt-card:hover .mt-card-img-wrap img { transform: scale(1.03); }

/* Numero */
.mt-card-num {
  font-family: 'Cinzel', serif;
  font-size: .88rem;
  letter-spacing: .12em;
  color: var(--parchment-dim);
  margin-bottom: .35rem;
}

/* Nome arcano */
.mt-card-name {
  font-family: 'Cinzel', serif;
  font-size: 1.15rem;
  color: #fff;
  font-weight: 600;
  line-height: 1.3;
  margin-bottom: .4rem;
  min-height: 2em;
  display: flex; align-items: center; justify-content: center;
}

/* Formula calcolo */
.mt-card-formula {
  font-family: 'Cinzel', serif;
  font-size: .82rem;
  color: rgba(201,169,110,0.75);
  letter-spacing: .04em;
  margin-top: .28rem;
}

/* Significato posizione */
.mt-card-meaning {
  font-family: 'Cormorant Garamond', serif;
  font-size: .92rem;
  color: rgba(240,237,230,0.65);
  margin-top: .45rem;
  line-height: 1.45;
  font-style: italic;
}

/* Sequenze */
.mt-sequenza {
  display: flex; align-items: center; justify-content: center;
  gap: .3rem; margin-top: .65rem; flex-wrap: wrap;
}
.mt-seq-num {
  font-family: 'Cinzel', serif;
  font-size: .78rem;
  color: var(--gold);
  background: rgba(201,169,110,0.1);
  border: 1px solid var(--border-strong);
  border-radius: 4px;
  padding: .12rem .42rem;
  font-weight: 700;
}
.mt-seq-arr { color: var(--gold); font-size: .78rem; opacity: .55; }

/* ── DETAIL PANEL ── */
.mt-detail {
  display: none;
  background: var(--ink-2);
  border: 1px solid var(--border-strong);
  border-radius: 12px;
  margin-bottom: 2.5rem;
  position: relative;
  overflow: hidden;
}
.mt-detail::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
}
.mt-detail.mt-detail--open { display: block; animation: mtDetailIn .32s ease forwards; }
@keyframes mtDetailIn { from { opacity:0; transform:translateY(-10px); } to { opacity:1; transform:translateY(0); } }

.mt-detail-close {
  position: absolute; top: 1.1rem; right: 1.3rem;
  background: none; border: none;
  color: var(--parchment-dim); cursor: pointer;
  font-size: 1.4rem; opacity: .6; transition: opacity .2s; z-index: 10;
}
.mt-detail-close:hover { opacity: 1; color: var(--gold); }

.mt-detail-inner { display: flex; min-height: 480px; }

/* LEFT — carta fissa */
.mt-detail-left {
  width: 260px;
  flex-shrink: 0;
  background: rgba(0,0,0,0.3);
  border-right: 1px solid var(--border);
  padding: 2rem 1.6rem;
  display: flex; flex-direction: column;
  align-items: center; gap: .9rem;
  position: sticky; top: 0; align-self: flex-start;
}
.mt-detail-img-wrap {
  width: 100%;
  aspect-ratio: 320 / 620;
  position: relative; overflow: hidden;
  border-radius: 8px;
  background: #000;
  border: 1px solid var(--border-strong);
  box-shadow: 0 6px 28px rgba(0,0,0,0.5);
}
.mt-detail-img-wrap img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: contain;
  object-position: center center;
}
.mt-detail-badge {
  display: inline-block;
  font-family: 'Cinzel', serif;
  font-size: .68rem; letter-spacing: .15em;
  color: var(--gold);
  border: 1px solid var(--border-strong);
  padding: .28rem .85rem; border-radius: 20px;
  text-transform: uppercase; text-align: center;
}
.mt-detail-num {
  font-family: 'Cinzel', serif; font-size: .9rem;
  color: var(--parchment-dim); letter-spacing: .1em; text-align: center;
}
.mt-detail-name {
  font-family: 'Cinzel', serif; font-size: 1.35rem;
  color: var(--gold-light); font-weight: 600;
  letter-spacing: .06em; text-align: center; line-height: 1.2;
}
.mt-detail-formula {
  font-size: .82rem; color: var(--parchment-dim);
  font-style: italic; text-align: center; opacity: .7;
}
/* meta-col per mobile */
.mt-detail-meta-col {
  display: flex; flex-direction: column; gap: .45rem; align-items: center;
}

/* RIGHT */
.mt-detail-right {
  flex: 1;
  padding: 2rem 2.5rem;
  overflow-y: auto;
  max-height: 82vh;
}

/* ── TABS ── */
.mt-tabs {
  display: flex; gap: .4rem; flex-wrap: wrap;
  margin-bottom: 1.8rem;
  padding-bottom: 1.1rem;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}
.mt-tab-btn {
  font-family: 'Cinzel', serif;
  font-size: .7rem; letter-spacing: .12em;
  padding: .52rem 1.3rem;
  border: 1px solid rgba(201,169,110,0.3);
  background: transparent; color: var(--parchment-dim);
  cursor: pointer; border-radius: 20px;
  text-transform: uppercase; transition: all .2s;
}
.mt-tab-btn:hover { border-color: var(--gold); color: var(--gold-light); }
.mt-tab-btn.mt-tab-btn--active {
  background: var(--gold); border-color: var(--gold);
  color: var(--ink); font-weight: 700;
}
.mt-tab-content { display: none; }
.mt-tab-content.mt-tab-content--active { display: block; }
.mt-tab-text { font-size: 1.15rem; line-height: 1.95; color: rgba(240,237,230,0.9); text-align: left !important; }

/* ── CONFLITTO PANEL ── */
.cf { font-family: 'Cormorant Garamond', serif; color: rgba(240,237,230,0.88); }
.cf-intro-block { margin-bottom: 2rem; }
.cf-block-eyebrow {
  font-family: 'Cinzel', serif; font-size: .8rem;
  letter-spacing: .25em; text-transform: uppercase;
  color: var(--gold); margin-bottom: .8rem; font-weight: 600;
}
.cf-intro-text {
  font-size: 1.12rem; line-height: 1.95; font-style: italic;
  color: rgba(200,195,185,0.85);
  padding: 1.2rem 1.5rem;
  border-left: 2px solid var(--gold);
  background: rgba(201,169,110,0.04);
  border-radius: 0 6px 6px 0;
}
.cf-subtitle { font-size: 1rem; color: var(--parchment-dim); font-style: italic; margin-bottom: 1.3rem; margin-top: -.5rem; }
.cf-divider { display: flex; align-items: center; gap: .9rem; margin: 2.5rem 0 1.8rem; }
.cf-divider-line { flex: 1; height: 1px; background: rgba(201,169,110,0.18); }
.cf-divider-ornament {
  font-family: 'Cinzel', serif; font-size: .72rem;
  letter-spacing: .25em; color: var(--gold); white-space: nowrap;
  padding: .38rem 1.1rem; border: 1px solid var(--border-strong);
  border-radius: 20px; background: rgba(201,169,110,0.05);
}
.cf-section-title {
  font-family: 'Cinzel', serif; font-size: 1.05rem;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--gold-light); margin-bottom: 1.1rem;
  padding-bottom: .6rem; border-bottom: 1px solid rgba(255,255,255,0.07);
  font-weight: 500;
}
.cf-mech-text { font-size: 1.12rem; line-height: 1.95; color: rgba(220,215,205,0.88); margin-bottom: 1.4rem; }
.cf-nodo {
  background: rgba(26,18,0,0.55); border: 1px solid rgba(201,169,110,0.45);
  border-radius: 8px; padding: 1rem 1.4rem; text-align: center; margin-bottom: 1.2rem;
}
.cf-nodo-label { font-family: 'Cinzel', serif; font-size: .68rem; letter-spacing: .2em; color: var(--gold-dark); margin-bottom: .3rem; text-transform: uppercase; }
.cf-nodo-text { font-family: 'Cinzel', serif; font-size: 1rem; color: var(--gold-light); font-weight: 600; line-height: 1.4; }
.cf-box { border: 1px solid rgba(255,255,255,0.06); border-radius: 8px; padding: 1rem 1.3rem; margin-bottom: 1.1rem; background: rgba(255,255,255,0.02); }
.cf-box-title { font-family: 'Cinzel', serif; font-size: .72rem; letter-spacing: .18em; color: var(--parchment-dim); text-transform: uppercase; margin-bottom: .7rem; font-weight: 600; }
.cf-flusso { display: flex; flex-wrap: wrap; align-items: center; gap: .4rem; }
.cf-passo { font-size: .95rem; color: rgba(220,215,205,0.8); padding: .28rem .75rem; border: 1px solid rgba(255,255,255,0.09); border-radius: 20px; background: rgba(255,255,255,0.025); }
.cf-arr { color: var(--gold); font-size: .85rem; opacity: .55; }
.cf-fattore-text { font-size: 1.05rem; line-height: 1.78; color: rgba(220,215,205,0.85); }
.cf-tre-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 1rem; margin-bottom: 1.3rem; }
.cf-blocco { border-radius: 8px; padding: 1rem 1.1rem; border: 1px solid rgba(160,160,240,0.22); background: rgba(70,70,150,0.1); }
.cf-blocco-title { font-family: 'Cinzel', serif; font-size: .7rem; letter-spacing: .12em; text-transform: uppercase; margin-bottom: .6rem; color: rgba(170,170,240,0.88); font-weight: 700; }
.cf-blo-item { font-size: 1rem; line-height: 1.58; margin-bottom: .3rem; display: flex; gap: 7px; align-items: flex-start; color: rgba(200,200,240,0.88); }
.cf-blo-sep { font-size: .65rem; margin-top: 5px; flex-shrink: 0; color: rgba(140,140,220,0.65); }
.cf-lo-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-bottom: 1.2rem; }
.cf-luce { border-radius: 8px; padding: 1rem 1.1rem; border: 1px solid rgba(201,169,110,0.28); background: rgba(201,169,110,0.06); }
.cf-ombra { border-radius: 8px; padding: 1rem 1.1rem; border: 1px solid rgba(100,100,140,0.28); background: rgba(18,18,28,0.55); }
.cf-lo-title { font-family: 'Cinzel', serif; font-size: .7rem; letter-spacing: .15em; text-transform: uppercase; margin-bottom: .6rem; display: flex; align-items: center; gap: 5px; font-weight: 700; }
.cf-luce .cf-lo-title { color: var(--gold); }
.cf-ombra .cf-lo-title { color: rgba(155,155,195,0.88); }
.cf-dot-luce { width: 6px; height: 6px; border-radius: 50%; background: var(--gold); flex-shrink: 0; }
.cf-dot-ombra { width: 6px; height: 6px; border-radius: 50%; background: rgba(125,125,180,0.75); flex-shrink: 0; }
.cf-lo-item { font-size: 1rem; line-height: 1.58; margin-bottom: .3rem; display: flex; gap: 7px; align-items: flex-start; }
.cf-luce .cf-lo-item { color: rgba(230,210,140,0.9); }
.cf-ombra .cf-lo-item { color: rgba(175,175,210,0.88); }
.cf-sep { font-size: .65rem; margin-top: 5px; flex-shrink: 0; opacity: .7; }
.cf-luce .cf-sep { color: var(--gold); }
.cf-ombra .cf-sep { color: rgba(125,125,180,0.85); }
.cf-chiave { border-left: 2px solid var(--gold); padding: .95rem 1.4rem; background: rgba(201,169,110,0.04); border-radius: 0 6px 6px 0; margin-bottom: 1.1rem; font-style: italic; font-size: 1.1rem; color: rgba(230,210,140,0.9); line-height: 1.75; }
.cf-trasf { border: 1px solid rgba(201,169,110,0.32); border-radius: 8px; padding: 1rem 1.4rem; text-align: center; margin-bottom: 1rem; background: rgba(255,255,255,0.02); }
.cf-trasf-label { font-family: 'Cinzel', serif; font-size: .68rem; letter-spacing: .2em; color: var(--gold); text-transform: uppercase; margin-bottom: .5rem; }
.cf-trasf-da { font-size: .95rem; color: rgba(200,195,185,0.38); text-decoration: line-through; font-style: italic; }
.cf-trasf-arr { color: var(--gold); font-size: 1.2rem; margin: .25rem 0; display: block; }
.cf-trasf-a { font-size: 1.05rem; color: rgba(240,237,230,0.9); font-weight: 500; }
.cf-schema-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .9rem; margin-bottom: 1.1rem; }
.cf-schema-box { border-radius: 8px; padding: .9rem 1rem; border: 1px solid; }
.cf-schema-box.astro:nth-child(1){background:#1a1030;border-color:#4a3068;color:#c8b8f0}
.cf-schema-box.astro:nth-child(2){background:#221540;border-color:#5a3880;color:#c0aaec}
.cf-schema-box.astro:nth-child(3){background:#2a1a50;border-color:#6a4898;color:#b8a0e8}
.cf-schema-box.astro:nth-child(4){background:#321e60;border-color:#7a58a8;color:#b098e0}
.cf-schema-box.astro:nth-child(5){background:#6040a0;border-color:#9070c0;color:#f0e8ff}
.cf-schema-box.astro:nth-child(6){background:#7a50b8;border-color:#a880d0;color:#f8f0ff}
.cf-schema-box.kab:nth-child(1){background:#081a10;border-color:#1a4828;color:#90d4b0}
.cf-schema-box.kab:nth-child(2){background:#0a2015;border-color:#205830;color:#88ccaa}
.cf-schema-box.kab:nth-child(3){background:#0c2818;border-color:#286838;color:#80c8a4}
.cf-schema-box.kab:nth-child(4){background:#0e3020;border-color:#308040;color:#78c09e}
.cf-schema-box.kab:nth-child(5){background:#206040;border-color:#3a9858;color:#e0fff0}
.cf-schema-box.kab:nth-child(6){background:#1a8048;border-color:#28b060;color:#f0fff8}
.cf-schema-box-title { font-family: 'Cinzel', serif; font-size: .7rem; letter-spacing: .12em; text-transform: uppercase; margin-bottom: .5rem; font-weight: 700; }
.cf-schema-item { font-size: .95rem; line-height: 1.55; margin-bottom: .22rem; display: flex; gap: 5px; align-items: flex-start; }
.cf-schema-bullet { font-size: .65rem; margin-top: 4px; flex-shrink: 0; opacity: .65; }
.cf-nodo.astro{background:rgba(80,40,140,0.22);border-color:rgba(150,120,220,0.38)}
.cf-nodo.astro .cf-nodo-label{color:var(--purple-light)}
.cf-nodo.astro .cf-nodo-text{color:rgba(220,200,255,0.9)}
.cf-nodo.kab{background:rgba(20,80,50,0.28);border-color:rgba(60,160,100,0.38)}
.cf-nodo.kab .cf-nodo-label{color:#6ad4a0}
.cf-nodo.kab .cf-nodo-text{color:rgba(180,240,210,0.9)}
.cf-trasf.astro{border-color:rgba(150,120,220,0.32)}
.cf-trasf.astro .cf-trasf-label{color:var(--purple-light)}
.cf-trasf.astro .cf-trasf-arr{color:var(--purple-light)}
.cf-trasf.kab{border-color:rgba(60,160,100,0.32)}
.cf-trasf.kab .cf-trasf-label{color:#6ad4a0}
.cf-trasf.kab .cf-trasf-arr{color:#6ad4a0}
.cf-frase{border-radius:8px;padding:.9rem 1.3rem;text-align:center;margin-bottom:1rem}
.cf-frase.astro{background:rgba(80,40,140,0.18);border:1px solid rgba(150,120,220,0.28)}
.cf-frase.astro .cf-frase-label{color:var(--purple-light)}
.cf-frase.kab{background:rgba(20,80,50,0.18);border:1px solid rgba(60,160,100,0.28)}
.cf-frase.kab .cf-frase-label{color:#6ad4a0}
.cf-frase-label{font-family:'Cinzel',serif;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:.4rem;display:block;font-weight:600}
.cf-frase-text{font-style:italic;font-size:1.1rem;color:rgba(240,237,230,0.9);line-height:1.65;font-weight:500}

/* MAPPA 2 */
.mt-mappa2-wrap{border:1px solid rgba(123,94,167,0.28);border-radius:12px;padding:1.8rem;margin-top:1.5rem;background:rgba(80,40,140,0.05)}

/* SUMMARY */
.mt-summary-card{background:rgba(255,255,255,0.02);border:1px solid var(--border);border-radius:10px;padding:1.5rem 2rem;margin-bottom:1.5rem}
.mt-summary{width:100%;border-collapse:collapse}
.mt-summary tr{border-bottom:1px solid rgba(201,169,110,0.1)}
.mt-summary tr:last-child{border-bottom:none}
.mt-summary td{padding:.75rem .5rem;vertical-align:middle}
.mt-summary td:first-child{color:var(--parchment-dim);font-size:.95rem;letter-spacing:.04em;width:38%;font-family:'Cinzel',serif}
.mt-summary td:nth-child(2){color:var(--gold-light);font-family:'Cinzel',serif;font-size:1.05rem;letter-spacing:.04em;font-weight:600;width:32%}
.mt-summary td:last-child{color:rgba(201,169,110,0.55);font-size:.88rem;font-style:italic}


/* ── TAB POSIZIONE ── */
.mt-tab-posizione {
  font-size: 1.12rem;
  line-height: 1.95;
  color: rgba(240,237,230,0.9);
  text-align: left !important;
}
.mt-tab-posizione p {
  margin-bottom: 1.1rem;
  text-align: left !important;
}
.mt-tab-posizione p:last-child { margin-bottom: 0; }
.mt-tab-posizione strong {
  color: var(--gold-light);
  font-weight: 600;
}
.mt-tab-posizione em {
  color: rgba(232,213,163,0.85);
  font-style: italic;
}
.mt-pos-header {
  margin-bottom: 1.2rem;
  padding-bottom: .8rem;
  border-bottom: 1px solid var(--border);
}
.mt-pos-title {
  font-family: 'Cinzel', serif;
  font-size: 1.1rem;
  color: var(--gold-light);
  font-weight: 600;
  letter-spacing: .08em;
}

.mt-results{display:none}
.mt-results.mt-results--visible{display:block}

/* ═══════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════ */

/* Tablet largo: 4 colonne */
@media(max-width:1100px){
  .mt-grid{grid-template-columns:repeat(4,1fr)}
}

/* Tablet: 3 colonne */
@media(max-width:820px){
  #mappa-talenti-app{padding:1.8rem 1.2rem 2.5rem}
  .mt-grid{grid-template-columns:repeat(3,1fr);gap:1.1rem}
}

/* Mobile: tutto in colonna */
@media(max-width:600px){
  #mappa-talenti-app{padding:1rem .7rem 2rem;border-radius:10px;overflow-x:hidden;width:100%;box-sizing:border-box}

  /* 2 colonne su mobile */
  .mt-grid{grid-template-columns:calc(50% - .4rem) calc(50% - .4rem);gap:.8rem}

  /* Card */
  .mt-card{padding:1rem .85rem 1.1rem;border-radius:10px}
  .mt-card-role{font-size:.72rem;min-height:2em;margin-bottom:.6rem}
  .mt-card-name{font-size:1rem;min-height:auto}
  .mt-card-num{font-size:.8rem}
  .mt-card-formula{font-size:.75rem}
  .mt-card-meaning{font-size:.82rem}

  /* Detail: verticale */
  .mt-detail-inner{flex-direction:column}
  .mt-detail-left{
    width:100%;
    flex-direction:row;
    flex-wrap:nowrap;
    align-items:center;
    gap:1rem;
    padding:1.2rem;
    border-right:none;
    border-bottom:1px solid var(--border);
    position:static;
  }
  .mt-detail-img-wrap{
    width:100px;
    aspect-ratio:320/620;
    flex-shrink:0;
  }
  .mt-detail-meta-col{
    flex:1;
    align-items:flex-start;
  }
  .mt-detail-name{font-size:1.1rem;text-align:left}
  .mt-detail-badge,.mt-detail-num,.mt-detail-formula{text-align:left}
  .mt-detail-right{padding:1.2rem;max-height:none}

  /* CF grids: 1 col */
  .cf-tre-grid,.cf-lo-grid,.cf-schema-grid{grid-template-columns:1fr}

  /* Form */
  .mt-form-row{flex-direction:column;align-items:stretch;gap:.85rem}
  .mt-field input,.mt-field-year input{width:100%}
  .mt-btn{width:100%;text-align:center}

  /* Summary */
  .mt-summary td{font-size:.85rem;padding:.6rem .3rem}
  .mt-summary td:nth-child(2){font-size:.9rem}
}

/* Extra small */
@media(max-width:360px){
  .mt-grid{grid-template-columns:1fr 1fr;gap:.65rem}
  .mt-card{padding:.85rem .7rem 1rem}
  .mt-card-name{font-size:.88rem}
}

/* Override tema — paragrafi sempre allineati a sinistra */
#mappa-talenti-app .mt-tab-text p,
#mappa-talenti-app .mt-tab-text { text-align: left !important; }
#mappa-talenti-app .mt-tab-text p { margin-bottom: 1rem; }
#mappa-talenti-app .mt-tab-text strong { color: var(--gold-light); }
#mappa-talenti-app .mt-tab-text em { color: rgba(232,213,163,0.85); }

/* ── CARTE DOMINANTI ── */
.mt-section-title--dominant {
  color: var(--gold-light);
  border-color: var(--gold);
}

.mt-card--dominant {
  border-color: rgba(201,169,110,0.6) !important;
  background: rgba(201,169,110,0.06) !important;
}

.mt-card-dominant-badge {
  font-family: 'Cinzel', serif;
  font-size: .65rem;
  letter-spacing: .15em;
  color: var(--gold);
  background: rgba(201,169,110,0.12);
  border: 1px solid rgba(201,169,110,0.4);
  border-radius: 20px;
  padding: .18rem .65rem;
  margin-bottom: .5rem;
  display: inline-block;
  text-transform: uppercase;
}

.mt-dominant-inner {
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
  margin-bottom: 1rem;
}

.mt-dom-card {
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(201,169,110,0.45);
  border-radius: 12px;
  overflow: hidden;
}

.mt-dom-card-header {
  display: flex;
  gap: 1.5rem;
  padding: 1.4rem 1.8rem;
  align-items: center;
  background: rgba(201,169,110,0.04);
  border-bottom: 1px solid rgba(201,169,110,0.15);
}

.mt-dom-img-wrap {
  width: 70px;
  aspect-ratio: 320 / 620;
  flex-shrink: 0;
  border-radius: 5px;
  overflow: hidden;
  background: #000;
  border: 1px solid var(--border-strong);
}

.mt-dom-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.mt-dom-meta {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: .4rem;
}

.mt-dom-badge {
  font-family: 'Cinzel', serif;
  font-size: .65rem;
  letter-spacing: .15em;
  color: var(--gold);
  text-transform: uppercase;
}

.mt-dom-name {
  font-family: 'Cinzel', serif;
  font-size: 1.3rem;
  color: var(--gold-light);
  font-weight: 600;
  letter-spacing: .06em;
}

.mt-dom-positions {
  font-size: .88rem;
  color: var(--parchment-dim);
  font-style: italic;
}

.mt-dom-text {
  padding: 1.4rem 1.8rem;
  font-size: 1.08rem;
  line-height: 1.92;
  color: rgba(240,237,230,0.88);
}

.mt-dom-text p { margin-bottom: 1rem; }
.mt-dom-text p:last-child { margin-bottom: 0; }
.mt-dom-text strong { color: var(--gold-light); }
.mt-dom-text--default { font-style: italic; color: rgba(240,237,230,0.75); }

/* Mobile */
@media(max-width:600px){
  .mt-dom-card-header { flex-direction: row; gap: 1rem; padding: 1rem; }
  .mt-dom-img-wrap { width: 55px; }
  .mt-dom-name { font-size: 1.1rem; }
  .mt-dom-text { padding: 1rem; font-size: 1rem; }
}
