.vsd-5209 .vsd-element.vsd-element-94f42ee{--display:flex;}/* Start custom CSS for html, class: .vsd-element-555918a */.br-filter{
  max-width:980px;
  margin:0 auto 18px;
}

.br-filter-bar{
  display:flex;
  flex-direction:column;
  gap:12px;
  padding:14px;
  background:#fff;
  border:1px solid #e7e7e7;
  border-radius:18px;
  box-shadow:0 8px 24px rgba(0,0,0,.04);
}

.br-filter-search{
  position:relative;
}

.br-filter-search svg{
  position:absolute;
  left:14px;
  top:50%;
  width:18px;
  height:18px;
  transform:translateY(-50%);
  fill:#8a8f98;
  pointer-events:none;
}

.br-filter-search input{
  width:100%;
  height:52px;
  padding:0 16px 0 44px;
  border:1px solid #e5e7eb;
  border-radius:14px;
  background:#fff;
  color:#111;
  font-size:15px;
  box-sizing:border-box;
  outline:none;
  transition:border-color .2s ease, box-shadow .2s ease;
}

.br-filter-search input::placeholder{
  color:#9aa1ab;
}

.br-filter-search input:focus{
  border-color:#cfd5dd;
  box-shadow:0 0 0 4px rgba(17,17,17,.04);
}

.br-filter-controls{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.br-filter-controls select,
.br-filter-reset{
  height:44px;
  padding:0 14px;
  border:1px solid #e5e7eb;
  border-radius:12px;
  background:#fff;
  color:#111;
  font-size:14px;
  box-sizing:border-box;
}

.br-filter-controls select{
  min-width:170px;
  outline:none;
}

.br-filter-controls select:focus{
  border-color:#cfd5dd;
  box-shadow:0 0 0 4px rgba(17,17,17,.04);
}

.br-filter-reset{
  cursor:pointer;
  min-width:100px;
}

.br-filter-reset:hover{
  background:#fafafa;
}

@media (max-width: 760px){
  .br-filter-bar{
    padding:12px;
  }

  .br-filter-controls{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
  }

  .br-filter-controls select,
  .br-filter-reset{
    width:100%;
    min-width:0;
  }
}

@media (max-width: 560px){
  .br-filter-controls{
    grid-template-columns:1fr;
  }
}



.br-filter-reset:hover,
.br-filter-reset:focus,
.br-filter-reset:active{
  background:#fff;
  color:#111;
  border-color:#d9dde3;
  box-shadow:none;
}/* End custom CSS */
/* Start custom CSS for html, class: .vsd-element-5473b36 */.br-books{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
  max-width:980px;
  margin:0 auto;
}

.br-book{
  background:#fff;
  border:1px solid #e7e7e7;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 8px 24px rgba(0,0,0,.04);
  transition:border-color .22s ease, box-shadow .22s ease, background-color .22s ease;
}

.br-book:hover{
  transform:none;
  background:#fff;
  box-shadow:0 8px 24px rgba(0,0,0,.04);
  border-color:#dcdcdc;
}

.br-book-toggle{
  all:unset;
  display:grid;
  grid-template-columns:88px minmax(0,1fr) auto;
  gap:16px;
  align-items:center;
  width:100%;
  box-sizing:border-box;
  padding:16px;
  cursor:pointer;
  background:#fff;
}

.br-book-toggle:hover,
.br-book-toggle:focus,
.br-book-toggle:active{
  background:#fff;
  color:inherit;
}

.br-book-cover{
  width:88px;
  height:124px;
  border-radius:12px;
  overflow:hidden;
  background:#f3f3f3;
  flex-shrink:0;
}

.br-book-cover img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.br-book-main{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:8px;
}

.br-book-top{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
}

.br-book-title{
  margin:0;
  font-size:20px;
  line-height:1.2;
  color:#111;
}

.br-badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  height:28px;
  padding:0 10px;
  border-radius:999px;
  background:#f5f7fb;
  border:1px solid #e8edf5;
  color:#334;
  font-size:12px;
  white-space:nowrap;
}

.br-book-meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.br-book-summary{
  color:#555;
  font-size:14px;
  line-height:1.5;
  margin:0;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

.br-book-side{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:10px;
  flex-shrink:0;
}

.br-rating{
  font-size:28px;
  font-weight:700;
  color:#111;
  line-height:1;
}

.br-rating small{
  font-size:13px;
  font-weight:500;
  color:#777;
}

.br-arrow{
  width:38px;
  height:38px;
  border-radius:999px;
  display:grid;
  place-items:center;
  border:1px solid #e6e6e6;
  background:#fff;
  color:#111;
  transition:.2s ease;
  line-height:1;
  padding-top:0;
  transform:translateY(-2px);
}

.br-book.is-open .br-arrow{
  transform:translateY(-2px) rotate(180deg);
}

.br-book-panel{
  display:none;
  border-top:1px solid #f0f0f0;
  padding:0 16px 16px;
}

.br-book.is-open .br-book-panel{
  display:block;
}

.br-book-grid{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:16px;
  padding-top:16px;
}

.br-box{
  background:#fafafa;
  border:1px solid #efefef;
  border-radius:14px;
  padding:14px;
}

.br-box-title{
  margin:0 0 10px;
  font-size:13px;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:#777;
}

.br-text{
  margin:0;
  color:#222;
  line-height:1.65;
  font-size:14px;
}

.br-list{
  display:grid;
  gap:10px;
}

.br-row{
  display:grid;
  grid-template-columns:140px 1fr;
  gap:10px;
  align-items:start;
  font-size:14px;
}

.br-row-label{
  color:#777;
}

.br-row-value{
  color:#111;
  min-width:0;
}

.br-progress{
  height:10px;
  border-radius:999px;
  background:#eceff3;
  overflow:hidden;
  margin-top:8px;
}

.br-progress-bar{
  height:100%;
  width:72%;
  background:linear-gradient(90deg,#111,#555);
  border-radius:999px;
}

.br-quotes{
  display:grid;
  gap:10px;
}

.br-quote{
  margin:0;
  padding:12px 14px;
  background:#fff;
  border:1px solid #ececec;
  border-radius:12px;
  color:#222;
  font-size:14px;
  line-height:1.6;
}

.br-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:14px;
}

.br-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 14px;
  border-radius:12px;
  text-decoration:none;
  border:1px solid #e5e5e5;
  background:#fff;
  color:#111;
  font-size:14px;
}

.br-link--solid{
  background:#111;
  border-color:#111;
  color:#fff;
}

@media (max-width: 760px){
  .br-book-toggle{
    grid-template-columns:72px minmax(0,1fr);
  }

  .br-book-side{
    grid-column:1 / -1;
    flex-direction:row;
    justify-content:space-between;
    align-items:center;
    margin-left:88px;
  }

  .br-book-grid{
    grid-template-columns:1fr;
  }

  .br-row{
    grid-template-columns:1fr;
    gap:4px;
  }
}


.br-arrow{
  position:relative;
  transform:none;
}

.br-arrow::before{
  content:"⌄";
  position:relative;
  top:-4px;
}

.br-book.is-open .br-arrow{
  transform:rotate(180deg);
}/* End custom CSS */