/* NMT tool page additions
   Uses existing design tokens from :root in your base file. */

/* Slightly tighter hero for tool pages */
.hero--tool{
  padding-bottom: clamp(1.2rem, .9rem + 1.6vw, 2.2rem);
}

/* Right hero card */
.nmtSide{
  border-radius: var(--radius2);
  background:
    radial-gradient(700px 320px at 10% 0%, rgba(173,141,242,.22), transparent 60%),
    radial-gradient(700px 320px at 95% 10%, rgba(9,166,3,.14), transparent 60%),
    rgba(255,255,255,.70);
  border: 1px solid rgba(22,36,41,.10);
  box-shadow: var(--shadow);
  backdrop-filter: blur(14px);
  padding: 1.05rem 1.05rem 1rem;
  position: sticky;
  top: 86px; /* under sticky header */
}

.nmtSide__top{
  display:flex;
  align-items: baseline;
  justify-content: space-between;
  gap: .75rem;
  margin-bottom: .85rem;
}
.nmtSide__title{
  font-weight: 860;
  letter-spacing: -.02em;
  font-size: 1.05rem;
}
.nmtSide__tag{
  font-weight: 750;
  font-size: .85rem;
  color: rgba(22,36,41,.62);
  padding: .28rem .55rem;
  border-radius: 999px;
  border: 1px solid rgba(22,36,41,.10);
  background: rgba(255,255,255,.55);
}

/* Steps */
.nmtSteps{
  margin: 0 0 .95rem;
  padding: 0;
  list-style: none;
  display: grid;
  gap: .7rem;
}
.nmtSteps__item{
  display:flex;
  gap: .7rem;
  align-items:flex-start;
  padding: .75rem .75rem .7rem;
  border-radius: 20px;
  border: 1px solid rgba(22,36,41,.08);
  background: rgba(255,255,255,.55);
}
.nmtSteps__n{
  width: 32px;
  height: 32px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  font-weight: 900;
  color: #fff;
  background: var(--grad);
  box-shadow: 0 12px 26px rgba(72,17,191,.14);
  flex: 0 0 auto;
}
.nmtSteps__h{
  font-weight: 820;
  letter-spacing: -.02em;
}
.nmtSteps__t{
  margin-top: .15rem;
  color: rgba(22,36,41,.66);
  font-weight: 520;
  font-size: .95rem;
  line-height: 1.45;
}

/* Mini metrics in hero card */
.nmtMiniGrid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .65rem;
  margin: .85rem 0 1rem;
}
.nmtMini{
  border-radius: 18px;
  border: 1px solid rgba(22,36,41,.10);
  background: rgba(255,255,255,.55);
  padding: .7rem .75rem .65rem;
}
.nmtMini__k{
  font-weight: 880;
  letter-spacing: -.02em;
}
.nmtMini__t{
  margin-top: .1rem;
  color: rgba(22,36,41,.62);
  font-weight: 650;
  font-size: .9rem;
}

.nmtSide__cta{
  display:flex;
  flex-wrap: wrap;
  gap: .55rem;
  margin-top: .2rem;
}
.nmtSide__note{
  margin-top: .85rem;
  padding-top: .85rem;
  border-top: 1px solid rgba(22,36,41,.08);
  color: rgba(22,36,41,.62);
  font-weight: 600;
  font-size: .95rem;
  line-height: 1.45;
}

/* Subject buttons grid */
.nmtGrid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 1.25rem;
}

.nmtBtn{
  border-radius: 26px;
  border: 1px solid rgba(22,36,41,.10);
  background:
    radial-gradient(520px 240px at 10% 0%, rgba(173,141,242,.22), transparent 60%),
    rgba(255,255,255,.78);
  box-shadow: 0 14px 34px rgba(22,36,41,.10);
  padding: 1.05rem 1.05rem 1rem;
  display:flex;
  align-items:center;
  gap: 1rem;
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease, background .12s ease;
}
.nmtBtn:hover{
  transform: translateY(-1px);
  box-shadow: 0 18px 44px rgba(22,36,41,.12);
  border-color: rgba(72,17,191,.18);
  background:
    radial-gradient(520px 240px at 10% 0%, rgba(173,141,242,.26), transparent 60%),
    rgba(255,255,255,.86);
}
.nmtBtn:focus-visible{
  outline: none;
  box-shadow: var(--focus), 0 18px 44px rgba(22,36,41,.12);
}
.nmtBtn__icon{
  width: 54px;
  height: 54px;
  border-radius: 20px;
  display:grid;
  place-items:center;
  border: 1px solid rgba(72,17,191,.18);
  background: rgba(72,17,191,.08);
  color: var(--p1);
  font-weight: 900;
  letter-spacing: -.02em;
  flex: 0 0 auto;
}
.nmtBtn__body{ min-width: 0; }
.nmtBtn__title{
  font-weight: 860;
  letter-spacing: -.02em;
  font-size: 1.1rem;
}
.nmtBtn__meta{
  margin-top: .25rem;
  color: rgba(22,36,41,.66);
  font-weight: 550;
  font-size: .95rem;
  line-height: 1.45;
}
.nmtBtn__go{
  margin-left: auto;
  width: 42px;
  height: 42px;
  border-radius: 16px;
  display:grid;
  place-items:center;
  border: 1px solid rgba(22,36,41,.10);
  background: rgba(255,255,255,.55);
  color: rgba(22,36,41,.70);
  font-weight: 900;
}

/* Hint */
.nmtHint{
  max-width: 70ch;
  text-align: center;
}

/* Responsive */
@media (max-width: 980px){
  .nmtSide{
    position: relative;
    top: auto;
  }
  .nmtGrid{
    grid-template-columns: 1fr;
  }
}
/* FIX: readability for right-hero steps */
.nmtSide{
  /* трохи більше щільності фону → кращий контраст */
  background:
    radial-gradient(700px 320px at 10% 0%, rgba(173,141,242,.20), transparent 60%),
    radial-gradient(700px 320px at 95% 10%, rgba(9,166,3,.10), transparent 60%),
    rgba(255,255,255,.84);
}

.nmtSteps__item{
  /* світліше/чіткіше під текст */
  background: rgba(255,255,255,.72);
  border-color: rgba(22,36,41,.10);
}

.nmtSteps__h{
  font-size: 1.02rem;
  letter-spacing: -0.01em;
}

.nmtSteps__t{
  /* головне: контраст + кегль + насиченість */
  color: rgba(22,36,41,.78);
  font-weight: 620;
  font-size: 1.02rem;
  line-height: 1.55;

  /* дрібний бонус читабельності */
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
}
/* === PATCH: NMT subject cards (taller + list + local <img>) === */

.nmtGrid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 1.25rem;
}

.nmtBtn{
  border-radius: 26px;
  border: 1px solid rgba(22,36,41,.10);
  background:
    radial-gradient(520px 240px at 10% 0%, rgba(173,141,242,.22), transparent 60%),
    rgba(255,255,255,.78);
  box-shadow: 0 14px 34px rgba(22,36,41,.10);
  padding: 1.15rem 1.15rem 1.05rem;

  display:flex;
  align-items:flex-start; /* важливо: щоб список не “лама”вся */
  gap: 1rem;

  min-height: 178px; /* робимо вищою */
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease, background .12s ease;
}

.nmtBtn:hover{
  transform: translateY(-1px);
  box-shadow: 0 18px 44px rgba(22,36,41,.12);
  border-color: rgba(72,17,191,.18);
  background:
    radial-gradient(520px 240px at 10% 0%, rgba(173,141,242,.26), transparent 60%),
    rgba(255,255,255,.86);
}

.nmtBtn:focus-visible{
  outline: none;
  box-shadow: var(--focus), 0 18px 44px rgba(22,36,41,.12);
}

.nmtBtn__icon{
  width: 62px;
  height: 62px;
  border-radius: 22px;
  display:grid;
  place-items:center;
  border: 1px solid rgba(72,17,191,.18);
  background: rgba(72,17,191,.08);
  flex: 0 0 auto;
  overflow: hidden;
}

.nmtBtn__iconImg{
  width: 44px;
  height: 44px;
  object-fit: contain;
  display:block;
}

.nmtBtn__body{
  min-width: 0;
  flex: 1 1 auto;
}

.nmtBtn__title{
  font-weight: 860;
  letter-spacing: -.02em;
  font-size: 1.12rem;
}

.nmtBtn__meta{
  margin-top: .25rem;
  color: rgba(22,36,41,.66);
  font-weight: 550;
  font-size: .95rem;
  line-height: 1.45;
}

/* NEW: структура тесту */
.nmtBtn__list{
  margin: .65rem 0 0;
  padding-left: 1.05rem;
  color: rgba(22,36,41,.72);
  font-weight: 520;
  font-size: .95rem;
  line-height: 1.45;
}

.nmtBtn__list li{
  margin: .2rem 0;
}

.nmtBtn__list strong{
  font-weight: 860;
  letter-spacing: -.01em;
}

.nmtBtn__listNote{
  list-style: none;
  margin-left: -1.05rem; /* щоб "Максимум..." красиво вирівнявся */
  margin-top: .35rem;
}

.nmtBtn__go{
  margin-left: auto;
  width: 42px;
  height: 42px;
  border-radius: 16px;
  display:grid;
  place-items:center;
  border: 1px solid rgba(22,36,41,.10);
  background: rgba(255,255,255,.55);
  color: rgba(22,36,41,.70);
  font-weight: 900;
  flex: 0 0 auto;
}

/* responsive */
@media (max-width: 760px){
  .nmtGrid{ grid-template-columns: 1fr; }
  .nmtBtn{ min-height: 0; }
}
/* ==========================================================
   CATALOG (Educational games): switches + search + cards
   Drop-in patch for nmt.css
   ========================================================== */

/* Header row above catalog: switches (left) + search (center) + counter (right) */
.toolshead{
  margin-top: 1.15rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

/* SWITCHES (segmented) */
.segmented{
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  padding: .4rem;
  border-radius: 999px;
  border: 1px solid rgba(22,36,41,.10);
  background: rgba(255,255,255,.55);
  box-shadow: 0 10px 24px rgba(22,36,41,.06);
  max-width: 100%;
  overflow-x: auto;
  scrollbar-width: none;
}
.segmented::-webkit-scrollbar{ display: none; }

.segmented__btn{
  appearance: none;
  border: 0;
  background: transparent;
  cursor: pointer;

  display: inline-flex;
  align-items: center;
  gap: .55rem;

  padding: .62rem .95rem;
  border-radius: 999px;

  font-weight: 780;
  letter-spacing: -.01em;
  color: rgba(22,36,41,.78);

  transition: transform .12s ease, background .12s ease, box-shadow .12s ease, color .12s ease;
  white-space: nowrap;
}
.segmented__btn i{
  opacity: .9;
}

.segmented__btn:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.65);
  box-shadow: 0 10px 18px rgba(22,36,41,.06);
}

.segmented__btn.is-active{
  color: #fff;
  background: var(--grad);
  box-shadow: 0 14px 26px rgba(72,17,191,.18);
}
.segmented__btn.is-active i{
  opacity: 1;
}

/* SEARCH */
.search{
  position: relative;
  min-width: 320px;
  flex: 0 1 420px;
}
.search > i{
  position: absolute;
  left: .9rem;
  top: 50%;
  transform: translateY(-50%);
  color: rgba(22,36,41,.55);
  font-size: 1.05rem;
}
.search__input{
  width: 100%;
  padding: .78rem 1rem .78rem 2.6rem;
  border-radius: 18px;
  border: 1px solid rgba(22,36,41,.10);
  background: rgba(255,255,255,.82);
  box-shadow: 0 10px 22px rgba(22,36,41,.06);
  font-weight: 650;
  color: rgba(22,36,41,.85);
}
.search__input::placeholder{
  color: rgba(22,36,41,.50);
  font-weight: 600;
}
.search__input:focus{
  outline: none;
  box-shadow: var(--focus), 0 10px 22px rgba(22,36,41,.06);
}

/* Counter text (right side) */
#gameCount{
  margin-left: auto;
  white-space: nowrap;
}

/* GRID */
.toolgrid{
  margin-top: 1.35rem;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.35rem;
}

/* CARD */
.tool{
  border-radius: 34px;
  border: 1px solid rgba(22,36,41,.10);
  background:
    radial-gradient(680px 280px at 12% 0%, rgba(173,141,242,.22), transparent 62%),
    rgba(255,255,255,.78);
  box-shadow: 0 18px 44px rgba(22,36,41,.10);
  padding: 1.35rem 1.35rem 1.25rem;

  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 1rem;
  align-items: start;

  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease, background .12s ease;
}
.tool:hover{
  transform: translateY(-1px);
  box-shadow: 0 22px 54px rgba(22,36,41,.12);
  border-color: rgba(72,17,191,.18);
  background:
    radial-gradient(680px 280px at 12% 0%, rgba(173,141,242,.26), transparent 62%),
    rgba(255,255,255,.86);
}
.tool:focus-within{
  box-shadow: var(--focus), 0 22px 54px rgba(22,36,41,.12);
}

.tool__ico{
  width: 56px;
  height: 56px;
  border-radius: 20px;
  display: grid;
  place-items: center;

  border: 1px solid rgba(72,17,191,.18);
  background: rgba(72,17,191,.08);
  color: var(--p1);
}
.tool__ico .iconify{
  font-size: 28px;
}

.tool__title{
  margin: .15rem 0 0;
  font-weight: 880;
  letter-spacing: -.02em;
  font-size: 1.15rem;
  line-height: 1.2;
}

.tool__desc{
  margin: .45rem 0 .9rem;
  color: rgba(22,36,41,.62);
  font-weight: 600;
  line-height: 1.5;
}

/* chips inside cards */
.chips{
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  margin: .2rem 0 1rem;
}
.chip{
  display: inline-flex;
  align-items: center;
  gap: .45rem;

  padding: .5rem .75rem;
  border-radius: 999px;

  border: 1px solid rgba(22,36,41,.10);
  background: rgba(255,255,255,.62);
  color: rgba(22,36,41,.72);

  font-weight: 720;
  line-height: 1;
  white-space: nowrap;
}
.chip i{
  opacity: .85;
}
.chip--brand{
  border-color: rgba(140,92,242,.25);
  background: rgba(140,92,242,.14);
  color: rgba(72,17,191,.95);
}
.chip--ok{
  border-color: rgba(9,166,3,.25);
  background: rgba(9,166,3,.12);
  color: rgba(9,120,3,.95);
}

/* CTA */
.tool__actions{
  display: flex;
  align-items: center;
  gap: .75rem;
  margin-top: .2rem;
}
.tool__cta{
  display: inline-flex;
  align-items: center;
  gap: .55rem;

  padding: .68rem .95rem;
  border-radius: 999px;

  border: 1px solid rgba(22,36,41,.10);
  background: rgba(255,255,255,.66);
  color: rgba(22,36,41,.86);

  font-weight: 820;
  transition: transform .12s ease, box-shadow .12s ease, background .12s ease;
}
.tool__cta:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.82);
  box-shadow: 0 12px 22px rgba(22,36,41,.08);
}
.tool__cta:active{
  transform: translateY(0px);
}

/* RESPONSIVE */
@media (max-width: 1100px){
  .toolgrid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 760px){
  .toolshead{
    justify-content: center;
  }
  #gameCount{
    margin-left: 0;
    width: 100%;
    text-align: center;
    white-space: normal;
  }
  .search{
    min-width: 0;
    flex: 1 1 100%;
  }
  .toolgrid{ grid-template-columns: 1fr; }
  .tool{
    grid-template-columns: 52px 1fr;
    padding: 1.15rem 1.15rem 1.05rem;
  }
}
/* === FIX: Games catalog / desktop switch width (no jitter) === */
@media (min-width: 980px) {
  .toolshead{
    width: 100%;
    align-items: flex-start;
    flex-wrap: nowrap;              /* не переносимо рядки на десктопі */
    justify-content: space-between;
    gap: 1.4rem;
  }

  .toolshead__left{
    flex: 0 0 860px;                /* фіксована ширина “свіча” */
    max-width: 860px;
  }

  /* робимо 5 однакових кнопок, щоб не “смикалось” через різні написи */
  .toolshead__left .segmented{
    width: 100%;
    display: grid;
    grid-template-columns: repeat(5, 1fr);
  }

  .toolshead__left .segmented__btn{
    justify-content: center;
    white-space: nowrap;
  }

  #gameCount{
    margin: .65rem 0 0 .2rem;       /* під свічами, як на макеті */
    white-space: nowrap;
  }

  .toolshead .search{
    flex: 0 0 520px;                /* стабільна ширина пошуку справа */
    max-width: 520px;
    margin-top: 0;
  }
}

/* якщо nmtNote зараз не стилізований — ось легкий стиль під вашу систему */
.nmtNote{
  margin-top: 1rem;
  display: flex;
  gap: .65rem;
  align-items: flex-start;
  padding: .85rem .9rem;
  border-radius: 16px;
  border: 1px solid rgba(22,36,41,.10);
  background: rgba(255,255,255,.62);
  box-shadow: 0 10px 24px rgba(22,36,41,.06);
}
.nmtNote__badge{
  display: inline-flex;
  align-items: center;
  padding: .3rem .55rem;
  border-radius: 999px;
  border: 1px solid rgba(72,17,191,.18);
  background: rgba(140,92,242,.14);
  color: rgba(72,17,191,.95);
  font-weight: 750;
  font-size: .82rem;
  line-height: 1;
}
.nmtNote__text{
  color: rgba(22,36,41,.74);
  font-weight: 600;
}
