/* =================================================
   LE PAROLE GIUSTE — page styles
   ================================================= */
.hd__active{background:var(--primary-soft)!important;color:var(--primary)!important}

/* =================================================
   PAGE HERO
   ================================================= */
.pgh{
  position:relative;overflow:hidden;
  padding:clamp(48px, 5vw, 96px) 0 clamp(40px, 4vw, 72px);
  background:radial-gradient(45% 80% at 100% 0%, color-mix(in oklab, var(--primary) 16%, transparent), transparent 60%);
}
.pgh__inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
.crumbs{
  display:flex;align-items:center;gap:10px;
  font-family:var(--font-mono);font-size:12px;color:var(--muted);letter-spacing:0.04em;
  margin-bottom:32px;
}
.crumbs a:hover{color:var(--primary)}
.crumbs span[aria-hidden]{opacity:.5}

.pgh__row{
  display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(40px, 4vw, 96px);align-items:center;
  margin-bottom:clamp(48px, 5vw, 96px);
}

.pgh__h{
  font-size:clamp(64px, 7.5vw, 140px);
  margin:14px 0 26px;line-height:0.95;
}
.pgh__h em{font-style:italic;color:var(--primary)}
.pgh__sub{
  font-size:clamp(17px, 1.3vw, 21px);
  line-height:1.5;color:var(--muted);max-width:50ch;margin:0;
}
.pgh__sub strong{font-weight:600;color:var(--ink)}

/* Hero illustration slot (replaces the old text panel) */
.pgh__media{position:relative}
.pgh__slot{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
}
.pgh__slot image-slot{width:100%;height:100%;display:block}

/* Legacy panel styles — kept in case still needed */
.pgh__intro{
  padding:24px 28px;border-radius:var(--r-lg);
  background:var(--surface);box-shadow:inset 0 0 0 1px var(--border);
}
.pgh__introHead{
  display:flex;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.08em;
  text-transform:uppercase;color:var(--muted);
  padding-bottom:14px;border-bottom:1px dashed var(--border);
  margin-bottom:16px;
}
.pgh__introHead .ico{display:grid;place-items:center;color:var(--primary)}
.pgh__introBody{
  position:relative;
  max-height:8.5em;overflow:hidden;
  transition:max-height .35s ease;
}
.pgh__introBody.is-expanded{max-height:9999px}
.pgh__introBody p{
  font-size:14.5px;line-height:1.65;color:var(--ink);margin:0 0 12px;
}
.pgh__expand{
  display:inline-flex;align-items:center;gap:6px;
  margin-top:8px;font-size:13.5px;font-weight:500;color:var(--primary);
}
.pgh__expand:hover{text-decoration:underline}

/* =================================================
   INTRO BAND (full-width, between hero and glossary)
   ================================================= */
.iband{
  padding:clamp(40px, 4vw, 72px) 0;
  background:color-mix(in oklab, var(--primary-soft) 35%, var(--bg));
  border-bottom:1px solid var(--border);
}
.iband__inner{
  max-width:var(--maxw);margin:0 auto;
  padding:0 var(--gutter);
}
.iband__head{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  margin-bottom:24px;
}
.iband__lbl{
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.08em;
  text-transform:uppercase;color:var(--primary);font-weight:600;
}
.iband__sep{width:1px;height:14px;background:var(--border)}
.iband__src{
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.04em;
  color:var(--muted);
}
.iband__body{
  position:relative;
  column-count:2;
  column-gap:clamp(32px, 4vw, 80px);
  max-height:11em;overflow:hidden;
  transition:max-height .35s ease;
}
.iband__body.is-expanded{max-height:9999px}
.iband__body::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:4em;
  background:linear-gradient(180deg, transparent, color-mix(in oklab, var(--primary-soft) 35%, var(--bg)));
  pointer-events:none;transition:opacity .25s;
}
.iband__body.is-expanded::after{opacity:0}
.iband__body p{
  font-size:clamp(15px, 1.05vw, 17px);
  line-height:1.7;color:var(--ink);
  margin:0 0 14px;
  break-inside:avoid;
}
.iband__more{
  display:inline-flex;align-items:center;gap:6px;
  margin-top:14px;font-size:14px;font-weight:500;color:var(--primary);
  padding:8px 0;
}
.iband__more:hover{text-decoration:underline}

@media (max-width:900px){
  .iband__body{column-count:1;max-height:13em}
}

.pgh__stats{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--border);
}
.bigstat{
  padding:24px 18px 24px 0;
  border-right:1px solid var(--border);
}
.bigstat:last-child{border-right:0}
.bigstat:not(:first-child){padding-left:18px}
.bigstat__n{
  font-family:var(--font-display);font-weight:400;
  font-size:clamp(40px, 4vw, 64px);line-height:1;letter-spacing:-0.02em;
  color:var(--primary);
}
.bigstat__n span{font-size:.55em;vertical-align:.35em;margin-left:1px}
.bigstat__l{
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.06em;
  text-transform:uppercase;color:var(--muted);margin-top:14px;line-height:1.4;
}

@media (max-width:1024px){
  .pgh__row{grid-template-columns:1fr}
  .pgh__stats{grid-template-columns:repeat(2,1fr)}
  .bigstat:nth-child(2){border-right:0}
}
@media (max-width:600px){.pgh__stats{grid-template-columns:1fr}}

/* =================================================
   A-Z NAVIGATOR (sticky)
   ================================================= */
.az{
  position:sticky;top:60px;z-index:20;
  background:color-mix(in oklab, var(--bg) 80%, transparent);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.az__inner{
  max-width:var(--maxw);margin:0 auto;
  padding:14px var(--gutter);
  display:flex;align-items:center;gap:18px;
}
.az__lbl{
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.08em;
  text-transform:uppercase;color:var(--muted);flex-shrink:0;
}
.az__bar{
  display:flex;gap:4px;flex-wrap:wrap;
}
.az__btn{
  display:grid;place-items:center;
  min-width:32px;height:32px;padding:0 8px;border-radius:8px;
  font-family:var(--font-display);font-size:18px;color:var(--ink);
  letter-spacing:-0.01em;
  transition:background .15s, color .15s, transform .1s;
}
.az__btn:hover{background:var(--primary-soft);color:var(--primary)}
.az__btn.is-active{
  background:var(--primary);color:#fff;transform:scale(1.05);
}

/* =================================================
   GLOSSARY
   ================================================= */
.gloss{padding:clamp(40px, 4vw, 72px) 0 clamp(80px, 6vw, 140px)}
.gloss__inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}

/* Search bar (reused pattern) */
.gloss__search{margin-bottom:48px}
.srch__bar{
  display:flex;align-items:center;gap:14px;
  padding:6px 14px 6px 20px;border-radius:999px;
  background:var(--surface);
  box-shadow:inset 0 0 0 1px var(--border),
             0 8px 24px -16px color-mix(in oklab, var(--ink) 20%, transparent);
  transition:box-shadow .2s;
}
.srch__bar:focus-within{
  box-shadow:inset 0 0 0 2px var(--primary),
             0 12px 32px -16px color-mix(in oklab, var(--primary) 30%, transparent);
}
.srch__icon{display:grid;place-items:center;color:var(--muted);flex-shrink:0}
.srch__bar input{
  flex:1;border:0;outline:0;background:transparent;font:inherit;font-size:15.5px;
  color:var(--ink);padding:12px 0;
}
.srch__bar input::placeholder{color:color-mix(in oklab, var(--muted) 80%, transparent)}
.srch__clear{
  display:grid;place-items:center;width:30px;height:30px;border-radius:50%;
  background:var(--chip);color:var(--muted);
}
.srch__clear:hover{background:var(--primary);color:#fff}
.srch__count{
  font-family:var(--font-mono);font-size:12px;letter-spacing:0.04em;
  color:var(--muted);padding:0 12px 0 6px;border-left:1px solid var(--border);flex-shrink:0;
}
.srch__count strong{color:var(--primary)}

/* Letter group */
.lgroup{
  margin-bottom:48px;scroll-margin-top:140px;
}
.lgroup__head{
  display:flex;align-items:flex-end;gap:24px;
  padding-bottom:18px;margin-bottom:24px;
  border-bottom:1px solid var(--border);
}
.lgroup__big{
  font-family:var(--font-display);font-weight:400;
  font-size:clamp(80px, 9vw, 160px);line-height:0.85;letter-spacing:-0.04em;
  color:var(--primary);
  margin:0;padding:0;
  /* trim the inherent line-box descent so the visual bottom of the letter
     aligns flush with the small meta text */
}
.lgroup__meta{
  padding-bottom:6px;
}
.lgroup__lbl{
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.08em;
  text-transform:uppercase;color:var(--muted);
  line-height:1;
}
.lgroup__count{
  font-size:15px;font-weight:500;color:var(--ink);margin-top:6px;
  line-height:1;
}
.lgroup__entries{display:grid;gap:16px}

/* Entry card — new "wrong → right → description" layout */
.ent{
  display:grid;gap:28px;
  padding:40px;border-radius:var(--r-lg);
  background:var(--surface);
  box-shadow:inset 0 0 0 1px var(--border);
  transition:box-shadow .25s;
}
.ent:hover{
  box-shadow:inset 0 0 0 1px color-mix(in oklab, var(--primary) 20%, transparent),
             0 20px 40px -28px color-mix(in oklab, var(--primary) 25%, transparent);
}

.ent__swap{
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto minmax(0, 1.1fr);
  gap:24px;
  align-items:center;
}

.ent__col{display:flex;flex-direction:column;gap:12px}

.ent__lbl{
  display:inline-flex;align-items:center;gap:6px;align-self:flex-start;
  padding:4px 10px;border-radius:6px;
  font-family:var(--font-mono);font-size:10.5px;letter-spacing:0.06em;
  text-transform:uppercase;font-weight:600;
}
.ent__lblIco{display:grid;place-items:center}
.ent__lbl--no{
  color:oklch(0.5 0.16 25);
  background:color-mix(in oklab, oklch(0.95 0.04 25) 75%, transparent);
}
.ent__lbl--yes{
  color:oklch(0.42 0.14 145);
  background:color-mix(in oklab, oklch(0.95 0.05 145) 75%, transparent);
}

/* Wrong terms: inline row, smaller, separated by middle dot */
.ent__terms--no{
  list-style:none;padding:0;margin:0;
  display:flex;flex-wrap:wrap;align-items:baseline;gap:6px 14px;
}
.ent__terms--no li{
  font-family:var(--font-display);font-weight:400;
  font-size:clamp(20px, 1.6vw, 28px);line-height:1.2;letter-spacing:-0.005em;
  color:oklch(0.45 0.07 25);
  position:relative;padding-right:14px;
}
.ent__terms--no li::after{
  content:"·";position:absolute;right:0;top:0;
  color:oklch(0.7 0.04 25);opacity:.7;
}
.ent__terms--no li:last-child{padding-right:0}
.ent__terms--no li:last-child::after{content:""}

/* Right terms: still stacked block — they are longer phrases */
.ent__terms--yes{
  list-style:none;padding:0;margin:0;display:grid;gap:8px;
}
.ent__terms--yes li{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(26px, 2.2vw, 38px);line-height:1.15;letter-spacing:-0.005em;
  color:var(--primary);text-wrap:balance;
}
.ent__terms--yes li::before{
  content:"";display:inline-block;
  width:6px;height:6px;border-radius:50%;
  background:oklch(0.55 0.14 145);
  margin-right:10px;vertical-align:middle;
  transform:translateY(-3px);
}

.ent__arrow{
  display:grid;place-items:center;
  width:44px;height:44px;border-radius:50%;
  background:var(--primary-soft);color:var(--primary);
  align-self:center;
  flex-shrink:0;
}

.ent__desc{
  padding-top:20px;border-top:1px dashed var(--border);
}
.ent__descLbl{
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.08em;
  text-transform:uppercase;color:var(--muted);margin-bottom:10px;
}
.ent__descBody{
  font-size:clamp(15.5px, 1.1vw, 17.5px);line-height:1.7;color:var(--ink);
}
.ent__descBody em.hl{
  font-style:normal;font-weight:500;
  color:var(--primary);
  background:linear-gradient(180deg, transparent 60%, color-mix(in oklab, var(--primary-soft) 80%, transparent) 60%);
  padding:0 1px;
}

.ent__more{
  display:inline-flex;align-items:center;gap:6px;
  margin-top:10px;font-size:13.5px;font-weight:500;color:var(--primary);
  padding:6px 0;
}
.ent__more:hover{text-decoration:underline}

mark{
  background:color-mix(in oklab, var(--primary) 25%, transparent);
  color:inherit;padding:0 2px;border-radius:3px;
}

@media (max-width:900px){
  .ent__swap{
    grid-template-columns:1fr;gap:18px;
  }
  .ent__arrow{
    transform:rotate(90deg);
    margin-top:0;justify-self:center;
    width:40px;height:40px;
  }
  .ent{padding:24px}
}

/* Empty state */
.empty{
  text-align:center;padding:56px 24px;
  border-radius:var(--r-lg);background:var(--surface);
  box-shadow:inset 0 0 0 1px var(--border);
}
.empty__t{font-family:var(--font-display);font-size:26px;letter-spacing:-0.01em;margin-bottom:6px}
.empty__s{font-size:14.5px;color:var(--muted);max-width:46ch;margin:0 auto 20px;line-height:1.5}
.empty__cta{display:inline-flex;gap:8px;flex-wrap:wrap;justify-content:center}

/* =================================================
   BOT CTA (same pattern as other pages)
   ================================================= */
.rel{padding:0 0 clamp(80px, 6vw, 140px)}
.rel__inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
.alist__bot{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px, 4vw, 80px);
  padding:clamp(40px, 4vw, 72px);
  border-radius:var(--r-lg);
  background:linear-gradient(135deg, color-mix(in oklab, var(--primary-soft) 70%, transparent), transparent 60%), var(--surface);
  box-shadow:inset 0 0 0 1px var(--border);
  align-items:center;
}
.bot__copy .h2{margin-top:8px}
.bot__viz{display:flex;flex-direction:column;gap:8px}
.bot__bubble{
  padding:14px 16px;border-radius:18px;
  font-size:14.5px;line-height:1.45;max-width:80%;
  animation:bubbleIn .5s cubic-bezier(.2,.7,.2,1) backwards;
}
.bot__bubble--u{align-self:flex-end;background:var(--primary);color:#fff;border-bottom-right-radius:6px;animation-delay:.1s}
.bot__bubble--b{align-self:flex-start;background:var(--surface);box-shadow:inset 0 0 0 1px var(--border);border-bottom-left-radius:6px;animation-delay:.3s}
.bot__bubble--small{font-size:13px;animation-delay:.5s;opacity:.85}
.bot__bubble--small.bot__bubble--b{animation-delay:.7s}
@media (max-width:900px){.alist__bot{grid-template-columns:1fr}}
