/* Pillerilista */
.pill-stack{
  display: grid;
  gap: 14px;
  max-width: 1000px;
  margin: 20px auto 3rem;
  padding: 0 1rem;
}

.pill{
  all: unset;
  display: block;
  cursor: pointer;
  padding: 16px 20px;
  border-radius: 25px;
  background: var(--color-TurkoosiTapiola);
  color: #0F262B;
  font-family: "Hepta Slab", system-ui, sans-serif;
  font-weight: 700;
  font-size: clamp(16px, 2.2vw, 22px);
  line-height: 1.2;
  box-shadow: 0 8px 16px rgba(0,0,0,.12);
  transition: transform .12s ease, box-shadow .12s ease;
}

.pill:hover{
  transform: translateY(-1px);
  box-shadow: 0 12px 22px rgba(0,0,0,.18);
}

.pill:focus-visible{
  outline: 3px solid #94c5f1;
  outline-offset: 3px;
}

/* Modal */
.pill-modal{
  position: fixed;
  inset: 0;
  z-index: 3000;
  display: none;
}
.pill-modal.is-open{ display: block; }

.pill-modal__overlay{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.55);
}

body.pill-modal-open{ overflow: hidden; }

.pill-modal__dialog{
  position: relative;
  max-width: min(1000px, 85vw);
  max-height: min(88vh, 1000px);
  margin: 6vh auto;
  background: var(--color-LuonnonValkoinen);
  color: #24353a;
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0,0,0,.35);
  overflow: auto;
  padding: clamp(16px, 2.4vw, 28px);
}

#pillModalTitle{
  font-family: "Expletus Sans", system-ui, sans-serif;
  font-weight: 800;
  font-size: clamp(1.4rem, 3.6vw, 2rem);
  margin: 0 0 1rem 0;
  padding-right: 46px;
  overflow-wrap: anywhere;
}

.pill-modal__content{
  line-height: 1.65;
}
.pill-modal__content p{ margin: .6rem 0; }
.pill-modal__content ul,
.pill-modal__content ol{
  margin: .6rem 0 .8rem 1.2rem;
}

/* Sulkunappi */
.pill-modal__close{
  position: sticky;
  top: 0;
  left: 100%;
  transform: translate(-8px, 8px);
  border: none;
  background: var(--color-SininenTumma);
  color: var(--color-LuonnonValkoinen);
  width: 40px;
  height: 40px;
  border-radius: 50%;
  font-size: 1.2rem;
  cursor: pointer;
}

/* Nuolinapit */
.pill-modal__arrow{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 40px;
  height: 40px;
  border: none;
  border-radius: 50%;
  background: var(--color-LuonnonValkoinen);
  box-shadow: 0 2px 10px rgba(0,0,0,.2);
  cursor: pointer;
  z-index: 3001;
  display: grid;
  place-items: center;
  font-size: 26px;
}

.pill-modal__prev{ left: clamp(8px, 2vw, 16px); }
.pill-modal__next{ right: clamp(8px, 2vw, 16px); }

@media (max-width: 700px){
  .pill-modal__arrow{ width: 36px; height: 36px; font-size: 22px; }
  .pill-modal__content{ font-size: 14px; }
}


.text-link{
  color: var(--color-SininenTumma);
  text-decoration: underline;
  text-underline-offset: 2px;
  font-weight: 600;
}

.text-link:hover{
  color: var(--accent);
  text-decoration-thickness: 2px;
}

.text-link:visited{
  color: var(--color-SininenTumma); /* estää violetti-vierailtu */
}

.text-link:focus-visible{
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.pill-modal,
.pill-modal__dialog{
  overscroll-behavior: contain;
}

.pill-modal__dialog{
  -webkit-overflow-scrolling: touch;
}

/* overlay ei ota “kuminauhaa” */
.pill-modal__overlay{
  touch-action: none;
}

.pill-modal__arrow:disabled{
  cursor: default;
  pointer-events: none;
}

.pill-modal h4 {
  font-family: "Expletus Sans", system-ui, sans-serif;
  font-weight: 800;
  font-size: 20px;
  line-height: 1.25;
  margin: 0;
  color: var(--color-TurkoosiTumma);
}