

#documentos {
  background: linear-gradient(140deg, #f5fbff 0%, #eaf4fc 100%);
  overflow-x: clip;
}

.docs-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 330px;
  gap: 1.4rem;
  align-items: start;
}

.docs-layout > * {
  min-width: 0;
}

.docs-main {
  background: #ffffff;
  border: 1px solid color-mix(in srgb, var(--line) 85%, transparent);
  border-radius: 20px;
  box-shadow: 0 16px 38px rgba(10, 38, 56, 0.08);
  padding: clamp(1rem, 2.3vw, 1.55rem);
  min-width: 0;
}

.docs-search {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(180px, 240px) 132px;
  gap: 0.65rem;
  margin-bottom: 1rem;
}

.docs-search > * {
  min-width: 0;
  width: 100%;
}

.docs-search input,
.docs-search select,
.docs-search button {
  height: 46px;
  border: 1px solid var(--line);
  background: #ffffff;
  color: var(--text);
  font: inherit;
  padding: 0 0.85rem;
}

.docs-search input:focus,
.docs-search select:focus,
.docs-search button:focus {
  outline: none;
  border-color: color-mix(in srgb, var(--primary) 70%, #ffffff);
}

.docs-search button {
  border: 1px solid transparent;
  border-radius: 999px;
  background: var(--primary);
  color: #03212e;
  font-weight: 700;
  cursor: pointer;
  transition: transform .2s ease, background-color .2s ease, color .2s ease;
}

.docs-search button:hover {
  transform: translateY(-2px);
  background: #18c0ff;
}

.docs-table-wrap {
  overflow-x: auto;
  width: 100%;
  max-width: 100%;
}

.docs-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 610px;
}

.docs-table th,
.docs-table td {
  text-align: left;
  padding: 0.78rem 0.72rem;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  vertical-align: middle;
}

.docs-table th {
  background: color-mix(in srgb, var(--primary) 14%, #ffffff);
  font-family: "Space Grotesk", sans-serif;
  font-size: 0.9rem;
  letter-spacing: 0.03em;
}

.docs-table td:first-child {
  width: 58px;
  font-weight: 700;
}

.download-link {
  display: inline-flex;
  align-items: center;
  gap: 0.38rem;
  text-decoration: none;
  color: var(--primary-strong);
  font-weight: 700;
}

.download-link::after {
  content: "↓";
  font-size: 1rem;
  line-height: 1;
}

.docs-pagination {
  margin-top: 1rem;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: .45rem;
  flex-wrap: wrap;
}

.docs-page-numbers {
  display: flex;
  align-items: center;
  gap: .45rem;
  flex-wrap: wrap;
}

.docs-page-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 38px;
  height: 38px;
  padding: 0 .8rem;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--primary) 20%, var(--line));
  background: #fff;
  color: var(--text);
  text-decoration: none;
  font-weight: 700;
}

.docs-page-btn.is-active {
  background: var(--primary);
  color: #03212e;
  border-color: transparent;
}

.docs-page-btn.is-disabled {
  opacity: .45;
  cursor: not-allowed;
}

.docs-page-ellipsis {
  color: color-mix(in srgb, var(--text) 70%, #486a7c 30%);
  font-weight: 800;
}

.docs-side {
  display: grid;
  gap: 0.9rem;
  min-width: 0;
}

.docs-media-card {
  min-height: 210px;
  display: grid;
  gap: 0.9rem;
  align-content: start;
  padding: 1rem;
  overflow: hidden;
  border: 1px solid rgba(17, 68, 104, 0.55);
  border-radius: 20px;
  background: linear-gradient(160deg, #0b2b45 0%, #103b5c 100%);
  box-shadow: 0 16px 32px rgba(8, 24, 40, 0.16);
  color: #ffffff;
}

.docs-media-icon {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.12);
  font-size: 1.2rem;
}

.docs-media-overlay {
  display: grid;
  gap: 0.3rem;
  color: #ffffff;
}

.docs-media-count {
  margin: 0;
  font-family: "Space Grotesk", sans-serif;
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  line-height: 1;
  font-weight: 800;
}

.docs-media-count-label {
  margin: 0 0 0.35rem;
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: rgba(255, 255, 255, 0.78);
}

.docs-media-overlay h3 {
  margin: 0;
  font-family: "Space Grotesk", sans-serif;
  font-size: clamp(1.05rem, 2vw, 1.28rem);
  line-height: 1.25;
}

.docs-media-overlay p {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.5;
}

body.dark #documentos {
  background: transparent;
}

body.dark #documentos .docs-main {
  background: #0e2435;
  border-color: rgba(167, 211, 237, 0.22);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.38);
}

body.dark #documentos .docs-search input,
body.dark #documentos .docs-search select,
body.dark #documentos .docs-search button {
  background: #0a1c2c;
  color: #e5f3fb;
  border-color: rgba(167, 211, 237, 0.25);
}

body.dark #documentos .docs-search input::placeholder {
  color: #9eb8ca;
}

body.dark #documentos .docs-search input:focus,
body.dark #documentos .docs-search select:focus,
body.dark #documentos .docs-search button:focus {
  border-color: #4fd4ff;
  box-shadow: 0 0 0 2px rgba(79, 212, 255, 0.22);
}

body.dark #documentos .docs-search button {
  background: var(--primary);
  color: #022336;
}

body.dark #documentos .docs-table th,
body.dark #documentos .docs-table td {
  border-bottom-color: rgba(167, 211, 237, 0.2);
}

body.dark #documentos .docs-table th {
  background: rgba(0, 176, 240, 0.2);
  color: #e8f6ff;
}

body.dark #documentos .download-link {
  color: #6fddff;
}

body.dark #documentos .docs-media-card {
  border-color: rgba(125, 198, 238, 0.35);
  background: linear-gradient(160deg, #0d314d 0%, #123754 100%);
}

@media (max-width: 1040px) {
  .docs-layout {
    grid-template-columns: 1fr;
  }

  .docs-side {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .docs-media-card {
    min-height: 170px;
  }
}

@media (max-width: 860px) {
  .docs-search {
    grid-template-columns: 1fr;
  }

  .docs-table {
    min-width: 560px;
  }

  .docs-side {
    grid-template-columns: 1fr;
  }

  .docs-media-card {
    min-height: 240px;
  }
}

@media (max-width: 520px) {
  #documentos {
    overflow-x: hidden;
  }

  .docs-layout {
    gap: 1rem;
  }

  .docs-main {
    padding: 0.9rem 0.72rem;
  }

  .docs-table {
    min-width: 520px;
  }

  .docs-media-card {
    min-height: 220px;
  }
}