HTML:
<label for="modal-trigger">Нажми меня</label>

<div class="modal">
<input id="modal-trigger" class="checkbox" type="checkbox">
<div class="modal-overlay">
<label for="modal-trigger" class="o-close"></label>
<div class="modal-wrap">
<label for="modal-trigger" class="close">✖</label>
<div>«Рассказы» — художественный фильм режиссёра Михаила Сегала, состоящий из четырёх разножанровых новелл из жизни современного российского общества, ставящих социальные, этические и культурные проблемы нашего времени: «Мир крепежа», «Круговое движение», «Энергетический кризис» и «Возгорится пламя». Новелла «Мир крепежа» в 2011 году получила главный приз в конкурсе «Кинотавр. Короткий метр». Рукопись молодого писателя попадает в литературное издательство и начинает загадочным образом влиять на членов редакции и всех тех, кто откроет её и прочитает хотя бы страницу. Истории, описанные в книге, начинают происходить в реальности с героями фильма. Фильм состоит из четырёх новелл — тех самых рассказов, которые были в рукописи — снятых в жанрах абсурдистской комедии, социальной сатиры, триллера и мелодрамы. </div>
</div>
</div>
</div>
CSS:
.modal .checkbox {
    display: none;
}

.modal .modal-overlay {
    opacity: 0;
    position: absolute;
    width: 100%;
    height: 100%;
    position: fixed;
    top: 0;
    left: 0;
    z-index: -100;
    visibility: hidden;
    background-color: rgba(0, 0, 0, 0.5);
}

.modal .modal-wrap {
    width: 600px;
    height: 300px;
    margin: auto;
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    border-radius: 10px;
    box-shadow: 0 0 5px 5px #666666;
    background: #e6e6e6;
}

.modal .modal-overlay .close {
    position: absolute;
    right: -15px;
    top: -15px;
    font-size: 30px;
    width: 40px;
    height: 40px;
    z-index: 9999;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    border-radius: 50%;
    background: #e6e6e6;
    text-align: center;
    line-height: 40px;
    cursor: pointer;
}

.modal .modal-overlay .close:hover {
    box-shadow: 0 0 5px 0 #333333;
    background: #f2f2f2
}

.modal .o-close {
    width: 100%;
    height: 100%;
    position: fixed;
    left: 0;
    top: 0;
    z-index: -100;
}

.modal input:checked ~ .o-close {
    z-index: 9998;
}

.modal input:checked ~ .modal-overlay {
    opacity: 1;
    z-index: 9997;
    overflow: auto;
    display: flex;
    visibility: visible;
}

.modal input:checked ~ .modal-overlay .modal-wrap {
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
    z-index: 9998;
}

@media (max-width: 660px) {
    .modal .modal-wrap {
        width: 85%;
        height: 80%;
    }
}