.layout-sticky-footer{
  min-height:100vh;
  display:flex;
  flex-direction:column;
}
.layout-sticky-footer main{flex:1 0 auto;}
.layout-sticky-footer footer{flex-shrink:0;}

.dl-toolbar{
  margin:18px auto 14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}

.dl-count{
  font-weight:950;
  color:rgba(16,24,40,.72);
}

.dl-search{
  position:relative;
  width:min(420px, 68vw);
}
.dl-search input{
  width:100%;
  height:46px;
  border-radius:16px;
  border:1px solid rgba(16,24,40,.12);
  padding:0 46px 0 44px;
  outline:none;
  background:rgba(255,255,255,.92);
  box-shadow:0 14px 28px rgba(16,24,40,.08);
  text-align:left;
  font-weight:900;
  color:rgba(16,24,40,.92);
  transition:border-color .18s ease, box-shadow .18s ease, transform .12s ease;
}
.dl-search input::placeholder{
  color:rgba(16,24,40,.45);
  font-weight:850;
}
.dl-search input:focus{
  border-color:rgba(244,123,32,.32);
  box-shadow:0 18px 34px rgba(16,24,40,.10);
  transform:translateY(-1px);
}
.dl-search::before{
  content:"";
  position:absolute;
  left:14px;
  top:50%;
  width:18px;
  height:18px;
  transform:translateY(-50%);
  opacity:.55;
  background:currentColor;
  -webkit-mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none"><path d="M21 21l-4.3-4.3m1.3-5.2a7.5 7.5 0 11-15 0 7.5 7.5 0 0115 0z" stroke="%23000" stroke-width="2" stroke-linecap="round"/></svg>') center/contain no-repeat;
          mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none"><path d="M21 21l-4.3-4.3m1.3-5.2a7.5 7.5 0 11-15 0 7.5 7.5 0 0115 0z" stroke="%23000" stroke-width="2" stroke-linecap="round"/></svg>') center/contain no-repeat;
}

.dl-board{
  background:transparent;
}

.dl-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0 12px;
}

.dl-table thead th{
  font-size:13px;
  font-weight:1000;
  color:rgba(16,24,40,.72);
  padding:10px 14px;
  text-align:center;
}

.dl-table tbody tr{
  background:#fff;
  border-radius:18px;
  box-shadow:0 14px 32px rgba(16,24,40,.06);
  overflow:hidden;
}

.dl-table tbody td{
  padding:16px 18px;
  vertical-align:middle;
  border-top:1px solid rgba(16,24,40,.08);
  border-bottom:1px solid rgba(16,24,40,.08);
}

.dl-table tbody td:first-child{
  border-left:1px solid rgba(16,24,40,.08);
  border-top-left-radius:18px;
  border-bottom-left-radius:18px;
}
.dl-table tbody td:last-child{
  border-right:1px solid rgba(16,24,40,.08);
  border-top-right-radius:18px;
  border-bottom-right-radius:18px;
}

.dl-table tbody tr:hover td{
  border-color:rgba(244,123,32,.18);
  background:rgba(16,24,40,.01);
}

.col-no{width:120px; white-space:nowrap;}
.col-size{width:150px; white-space:nowrap;}
.col-cat{width:170px; white-space:nowrap;}
.col-title{width:auto;}

.dl-link{
  font-weight:950;
  color:rgba(16,24,40,.94);
  display:inline-block;
  max-width:100%;
  white-space:normal;
  word-break:break-word;
  line-height:1.55;
  padding:2px 0;
}
.dl-link:hover{
  text-decoration:underline;
}

.dl-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(244,123,32,.24);
  background:rgba(244,123,32,.10);
  font-weight:950;
  font-size:12px;
  color:rgba(16,24,40,.88);
}

.dl-empty{
  margin-top:14px;
  padding:22px 14px;
  color:rgba(16,24,40,.62);
  font-weight:900;
  border:1px solid rgba(16,24,40,.10);
  border-radius:18px;
  background:#fff;
  box-shadow:0 14px 32px rgba(16,24,40,.06);
}

.dl-pager{
  margin:16px auto 0;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  flex-wrap:wrap;
}

.dl-nav{
  width:44px;
  height:44px;
  border-radius:14px;
  border:1px solid rgba(16,24,40,.12);
  background:#fff;
  font-weight:1000;
  cursor:pointer;
  box-shadow:0 12px 20px rgba(16,24,40,.08);
  transition:transform .12s ease, box-shadow .18s ease, border-color .18s ease;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.dl-nav:hover{
  transform:translateY(-1px);
  box-shadow:0 18px 28px rgba(16,24,40,.10);
  border-color:rgba(244,123,32,.24);
}
.dl-pages{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  justify-content:center;
}

.dl-page{
  width:44px;
  height:44px;
  border-radius:14px;
  border:1px solid rgba(16,24,40,.12);
  background:#fff;
  font-weight:950;
  cursor:pointer;
  box-shadow:0 12px 20px rgba(16,24,40,.08);
  transition:transform .12s ease, box-shadow .18s ease, border-color .18s ease;
}
.dl-page:hover{
  transform:translateY(-1px);
  box-shadow:0 18px 28px rgba(16,24,40,.10);
  border-color:rgba(244,123,32,.24);
}
.dl-page.is-active{
  border-color:rgba(244,123,32,.42);
  background:linear-gradient(135deg, var(--accent), var(--accent-2));
  color:#111;
}

.dl-jump{
  width:44px;
  height:44px;
  border-radius:14px;
  border:1px solid rgba(16,24,40,.10);
  background:rgba(255,255,255,.70);
  font-weight:1000;
  cursor:pointer;
  box-shadow:0 10px 18px rgba(16,24,40,.06);
}

@media (max-width:820px){
  .dl-toolbar{flex-direction:column; align-items:stretch;}
  .dl-search{width:100%;}
  .dl-search input{text-align:center;}
}

@media (max-width:560px){
  .dl-table thead{display:none;}
  .dl-table{border-spacing:0 10px;}
  .dl-table tbody td{
    padding:14px 14px;
  }
  .col-no{width:90px}
  .col-size{width:110px}
  .col-cat{width:120px}
}
