* {
  box-sizing: border-box;
}

:root {
  --rtve-orange: #ff6a00;
  --rtve-orange-dark: #e65c00;
  --rtve-black: #000000;
  --gray-50: #fafafa;
  --gray-100: #f3f4f6;
  --gray-200: #e5e7eb;
  --gray-300: #d1d5db;
  --gray-600: #4b5563;
  --gray-900: #111827;
  --card: #ffffff;
  --line: var(--gray-200);
  --header-height: 64px;
}

body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
  color: var(--gray-900);
  background: var(--gray-50);
  min-height: 100vh;
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
}

html {
  scroll-behavior: smooth;
}

.app-header,.header-content,.app-footer,.footer-content {display:none;}

.container {
  width: 100%;
  max-width: 1320px;
  margin: 16px auto;
  padding: 16px;
  /*flex: 1 1 auto;*/
}


.page-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 12px;
}

.page-header h2 {
  margin: 0;
  font-size: 20px;
}

.page-header p {
  margin: 0;
  color: var(--gray-600);
}

.back-link-row {
  margin: 0 0 10px;
}

.detail-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 0 0 12px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--card);
}

.detail-nav-bottom {
  margin-top: 50px;
}

.back-to-list-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 12px;
  border-radius: 10px;
  border: 1px solid var(--rtve-orange);
  background: var(--rtve-orange);
  color: #fff;
  font-size:12px;
  text-transform:uppercase;
  font-weight: 700;
  white-space: nowrap;
  align-self:flex-start;
}

.back-to-list-button:hover {
  border-color: var(--rtve-orange-dark);
  background: var(--rtve-orange-dark);
  color: #fff;
  text-decoration: none;
}

.back-to-top-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 10px;
  border: 1px solid var(--rtve-orange);
  background: #fff4ec;
  color: var(--rtve-orange-dark);
  font-size: 24px;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
}

.back-to-top-link:hover {
  border-color: var(--rtve-orange-dark);
  background: #ffe9db;
  color: var(--rtve-orange-dark);
  text-decoration: none;
}

.detail-nav-title {
  margin: 0;
  font-size: 20px;
  font-weight: 700;
  color: var(--gray-900);
  align-self:flex-start;
  white-space:nowrap;
}

.detail-nav-pager {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.nav-doc-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 92px;
  min-height: 38px;
  padding: 8px 12px;
  border: 1px solid #bad7ea;
  border-radius: 8px;
  background: #f5fafe;
  color: #0f4d73;
  font-weight: 600;
  text-decoration: none;
}

.nav-doc-button:hover {
  background: #eaf5fc;
  color: #0f4d73;
  text-decoration: none;
}

.nav-doc-button.disabled,
.nav-doc-button.disabled:hover {
  border-color: var(--gray-300);
  background: var(--gray-100);
  color: var(--gray-600);
  pointer-events: none;
}

.nav-position {
  display: inline-block;
  min-width: 155px;
  text-align: center;
  color: var(--gray-600);
  font-size: 13px;
  font-weight: 600;
}

.filters {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 14px;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 12px;
}

.search-input-wrap {
  position: relative;
  flex: 0 1 clamp(320px, 42vw, 620px);
  min-width: 240px;
  max-width: 100%;
}

.search-input-wrap input {
  width: 100%;
  padding-right: 34px;
  font-size: 15px;
  color: #000;
}

.search-input-wrap input::placeholder {
  font-size: 15px;
}

.search-clear-link {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 22px;
  height: 22px;
  border-radius: 999px;
  color: #9ca3af;
  font-size: 20px;
  line-height: 22px;
  text-align: center;
  text-decoration: none;
}

.search-clear-link:hover {
  background: #f3f4f6;
  color: #6b7280;
  text-decoration: none;
}

.filters-results {
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
  color: #0f4d73;
  font-style: italic;
  font-size: 14px;
}

.filters-inline-actions {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.advanced-search-toggle {
  display: inline-flex;
  align-items: center;
  padding: 0;
  border: 0;
  background: transparent;
  color: #0f4d73;
  font-weight: 600;
  font-size: 14px;
  white-space: nowrap;
  cursor: pointer;
  text-decoration: none;
}

.advanced-search-toggle:hover {
  color: #0b3f5d;
  text-decoration: none;
}

.advanced-search-toggle.is-active {
  color: #005f96;
  text-decoration: none;
}

.page-size-select {
  margin-left: auto;
  min-width: 120px;
  color: var(--gray-600);
  font-size: 13px;
  font-weight: 600;
}

.advanced-search-panel {
  flex: 1 0 100%;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-top: 4px;
  padding-top: 10px;
  border-top: 1px dashed var(--line);
}

.advanced-search-panel.is-hidden {
  display: none;
}

.advanced-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}

.advanced-field span {
  color: var(--gray-600);
  font-size: 12px;
  font-weight: 600;
}

.advanced-field input {
  width: 100%;
}

.advanced-token-editor {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  min-height: 40px;
  padding: 5px 8px;
  border: 1px solid var(--gray-300);
  border-radius: 8px;
  background: #fff;
  cursor: text;
}

.advanced-token-editor:focus-within {
  border-color: #0f4d73;
}

.token-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.token-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  max-width: 100%;
  padding: 3px 8px;
  border-radius: 999px;
  border: 1px solid #bad7ea;
  background: #eaf5fc;
  color: #0f4d73;
  font-size: 14px;
  line-height: 1.2;
}

.token-chip-label {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.token-chip-remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: #0f4d73;
  font-size: 15px;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
}

.token-chip-remove:hover {
  background: rgba(15, 77, 115, 0.14);
}

.advanced-token-editor .token-text-input {
  flex: 1 1 120px;
  min-width: 120px;
  width: auto;
  margin: 0;
  padding: 4px 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  outline: none;
  font-size: 14px;
}

.advanced-token-editor .token-text-input:focus {
  outline: none;
}

input,
select,
button {
  padding: 8px 10px;
  border: 1px solid var(--gray-300);
  border-radius: 8px;
  background: #fff;
  font: inherit;
}

button[type="submit"] {
  background: var(--rtve-orange);
  border-color: var(--rtve-orange);
  color: #fff;
  font-weight: 600;
  cursor: pointer;
}

button[type="submit"]:hover {
  background: var(--rtve-orange-dark);
  border-color: var(--rtve-orange-dark);
}

a {
  color: #0f4d73;
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

table {
  width: 100%;
  border-collapse: collapse;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 12px;
  overflow: hidden;
  table-layout: fixed;
}

.empty-results {
  margin: 0;
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  color: var(--gray-600);
}

th,
td {
  padding: 9px 10px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  vertical-align: top;
  word-wrap: break-word;
}

th {
  background: var(--gray-100);
  color: var(--gray-600);
  font-size: 13px;
  font-weight: 700;
}

tbody tr:hover {
  background: #fff8f3;
}

.w-name {
  width: 300px;
}

.w-pages {
  width: 80px;
}

.w-size {
  width: 90px;
}

/* Oculta la columna de tamaño (KB) en el listado. */
main.container table th.w-size,
main.container table td:nth-child(3) {
  display: none;
}

.w-summary {
  width: 34%;
}

.summary-cell {
  font-size: 15px;
}

.link-button {
  display: inline-block;
  width: 100%;
  border: 0;
  background: transparent;
  padding: 0;
  margin: 0;
  color: #0f4d73;
  cursor: pointer;
  text-align: left;
  font: inherit;
  font-size: 15px;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.link-button:hover {
  color: var(--rtve-orange);
  text-decoration: underline;
}

.tag-chip {
  display: inline-block;
  margin: 2px 4px 2px 0;
  padding: 3px 8px;
  border-radius: 999px;
  border: 1px solid #ffd7bf;
  background: #fff4ec;
  color: #8a3f00;
  font-size: 12px;
}

.pager {
  display: flex;
  gap: 16px;
  align-items: center;
  margin: 14px 0;
}

.pager span {
  color: var(--gray-600);
}

.muted {
  color: var(--gray-600);
}

.text-box {
  white-space: pre-wrap;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  max-height: 38vh;
  overflow: auto;
}

.text-box-large {
  height: 692px;
  max-height: none;
  overflow: auto;
}

.detail-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 10px;
}

.page-detail-grid {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 10px;
  margin-bottom: 12px;
}

.detail-section {
  margin-bottom: 14px;
}

.detail-section h3 {
  margin: 0 0 8px;
  font-size: 16px;
}

.tag-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.tag-group-card {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  padding: 10px;
}

.tag-group-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}

.tag-group-header h4 {
  margin: 0;
  font-size: 13px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.tag-group-count {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
}

.tag-group-people {
  border-color: #ffd7bf;
  background: #fff7f2;
}

.tag-group-people .tag-group-header h4 {
  color: #8a3f00;
}

.tag-group-people .tag-group-count {
  background: #ffe7d8;
  color: #8a3f00;
}

.tag-group-people .tag-chip {
  border-color: #ffc9a8;
  background: #fff1e7;
  color: #8a3f00;
}

.tag-group-places {
  border-color: #c8dfef;
  background: #f5fafe;
}

.tag-group-places .tag-group-header h4 {
  color: #0f4d73;
}

.tag-group-places .tag-group-count {
  background: #dfedf7;
  color: #0f4d73;
}

.tag-group-places .tag-chip {
  border-color: #bad7ea;
  background: #eaf5fc;
  color: #0f4d73;
}

.tag-group-keywords {
  border-color: #d7d9de;
  background: #f7f8fa;
}

.tag-group-keywords .tag-group-header h4 {
  color: #111827;
}

.tag-group-keywords .tag-group-count {
  background: #e5e7eb;
  color: #374151;
}

.tag-group-keywords .tag-chip {
  border-color: #d1d5db;
  background: #f3f4f6;
  color: #374151;
}

.detail-columns {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.detail-column {
  min-width: 0;
}

.chips-wrap {
  min-height: 28px;
}

.viewer-box {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  padding: 10px;
  min-height: 80px;
  overflow: hidden;
}

.viewer-box-large {
  padding: 0;
  width: min(100%, 595px);
  height: 692px;
  margin: 0 auto;
  overflow: auto;
}

.audio-player {
  width: 100%;
}

.video-player {
  display: block;
  width: 100%;
  height: auto;
  max-height: 62vh;
  margin: 0 auto;
  background: #000;
}

.doc-viewer {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
  overflow: auto;
  pointer-events: auto;
}

.img-viewer {
  display: block;
  width: 100%;
  height: auto;
  max-height: 62vh;
  object-fit: contain;
  margin: 0 auto;
}

@media (max-width: 1024px) {/*
  .detail-nav:not(.detail-nav-bottom) {
    align-items: stretch;
    flex-direction: column;
  }

  .back-to-list-button {
    width: 100%;
  }*/

  .detail-nav-pager {
    width:100%;
    justify-content:flex-end;
    flex-wrap:nowrap;
  }

  /*.nav-position {
    width: 100%;
    min-width: 0;
    order: -1;
  }*/

  .page-size-select {
    margin-left: 0;
  }

  .advanced-search-panel {
    grid-template-columns: 1fr;
  }

  .detail-grid {
    grid-template-columns: 1fr;
  }

  .detail-columns {
    grid-template-columns: 1fr;
  }

  .tag-grid {
    grid-template-columns: 1fr;
  }

  .text-box-large,
  .viewer-box-large {
    width: 100%;
    height: min(75vh, 692px);
  }

  table {
    font-size: 14px;
  }
}


.page-header h2 {color:var(--gray-600);overflow-wrap:anywhere;font-size:18px;line-height:24px;}
p.text-box {font-size:15px;line-height:21px;padding:16px;}
.detail-section h3 {margin:24px 0 12px 0;display:inline-block;width:100%;text-transform:uppercase;font-weight:400;}
.detail-grid.page-detail-grid,.page-header p,.tag-grid article:not(.tag-group-keywords),.detail-section:has(.tag-grid) h3 {display:none;}
.tag-grid {display:inline-block;}
.tag-group-keywords .tag-chip {margin:0 4px 8px 0;}
.viewer-box-large {margin:12px auto;}


main.container {max-width:calc(1180px + 32px);}
main.container table,main.container .filters {border:0 none;outline:2px solid var(--line);}
main.container table {border-radius:0 0 12px 12px;}
main.container .filters {border-radius:12px 12px 0 0;margin-bottom:2px;padding:16px 12px;}
main.container table th {font-size:14px;padding:16px 10px;}
main.container .detail-nav {border:0 none;border-radius:0;background:transparent;}
.detail-nav {padding:16px 0;}
.detail-nav .nav-doc-button {font-size:12px;text-transform:uppercase;font-weight:700;}
.detail-nav-bottom {margin-top:24px;}
.back-to-top-link {flex:0 0 42px;}
.nav-position {min-width:0;padding:0 12px;overflow-wrap:anywhere;}

@media (max-width: 1200px) {
	.detail-columns {display:flex;flex-direction:column;}
	.detail-columns article {width:calc(100% - 4.8rem);}
	.detail-columns article [class*='box-large'] {width:100%;height:auto;aspect-ratio:16/9;}
}

@media (max-width: 1024px) {
	main.container .filters {justify-content:space-between;border-radius:12px;}
	.search-input-wrap {flex:0 1 100%;}
	.detail-nav-bottom .detail-nav-pager {justify-content:flex-end;}
	main.container table {background:transparent;border-radius:0;border:0 none;outline:0 none;}
	main.container table thead {display:none;}
	main.container tbody,main.container table tr {display:flex;}
	main.container tbody {flex-direction:column;}
	main.container table tr {flex-direction:row;flex-wrap:wrap;width:100%;border-radius:12px;background:var(--card);margin:12px 0;border:1px solid var(--line);padding:12px;}
	main.container table tr td {width:100%;border:0 none;padding:8px 0;}
	main.container table tr td:nth-child(4) {border-top:1px solid var(--line);}
	main.container table tr :is(td:nth-child(2),td:nth-child(3)) {width:auto;padding-top:0;}
	main.container table tr td:nth-child(2)::after{content:"\00A0p\00E1gs.";}
	main.container table tr td:nth-child(3)::before{content:"\00A0/\00A0";}
	main.container table tr td:nth-child(3)::after{content:"\00A0Kb";}
	.detail-columns article [class*='box-large'] {aspect-ratio:1;}
}

@media (max-width: 560px) {
	.detail-nav {flex-direction:column;}
	.detail-columns article {width:100%;}
	.detail-columns article [class*='box-large'] {aspect-ratio:3/4;}
}
