/* ===================================================================
   Mis solicitudes — Studio independiente
   Alcance exclusivo: .requests-studio
   =================================================================== */

.requests-studio {
  --req-navy: #0b2138;
  --req-blue: var(--primary, #377cc0);
  --req-blue-soft: var(--primary-light, #cce5f8);
  --req-surface: #f4f8fc;
  --req-card: #ffffff;
  --req-edge: rgba(55, 124, 192, 0.14);
  --req-edge-strong: rgba(55, 124, 192, 0.22);
  --req-shadow: 0 16px 48px rgba(11, 33, 56, 0.07);
  --req-shadow-sm: 0 6px 20px rgba(11, 33, 56, 0.06);
  --req-shadow-nav: 0 2px 8px rgba(15, 23, 42, 0.06);
  --req-radius: 18px;
  --req-radius-sm: 12px;
  --req-accent: #2563eb;
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
  padding-bottom: 0.5rem;
}

.requests-studio .req-studio-head,
.requests-studio .requests-studio-head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem 1.5rem;
  padding: 1.15rem 1.35rem;
  border-radius: var(--req-radius);
  border: 1px solid var(--req-edge-strong);
  background: linear-gradient(135deg, color-mix(in srgb, var(--req-accent) 8%, transparent), transparent 55%), var(--req-card);
  box-shadow: var(--req-shadow-sm);
  position: relative;
  overflow: hidden;
}

/* ── Workspace header (Registrar | Consultar) ── */
.requests-studio > .hr-workspace-header--payroll {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  flex: 0 0 auto;
  gap: 0.65rem;
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}

.requests-studio > .hr-workspace-header--payroll .requests-studio-head,
.requests-studio > .hr-workspace-header--payroll .payroll-module-head--compact {
  flex: 0 0 auto;
  width: 100%;
}

.requests-studio .hr-workspace-header__switch {
  flex: 0 0 auto;
  flex-grow: 0;
  flex-shrink: 0;
  align-self: flex-end;
  width: auto;
  max-width: 100%;
  min-height: 0;
}

.requests-studio .hr-workspace-tabs--switch {
  padding: 0.28rem;
  border-radius: 999px;
  border: 1px solid var(--req-edge-strong);
  background: var(--req-surface);
  gap: 0.2rem;
  box-shadow: inset 0 1px 2px rgba(11, 33, 56, 0.04);
}

.requests-studio .hr-workspace-tab--switch {
  min-height: 2.45rem;
  padding: 0 1.1rem;
  border-radius: 999px;
  font-weight: 700;
  font-size: 0.88rem;
  color: var(--text-soft);
  transition: background 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}

.requests-studio .hr-workspace-tab--switch.is-active {
  background: linear-gradient(135deg, var(--req-blue), var(--primary-dark, #2a6399));
  color: #fff;
  box-shadow: 0 6px 18px rgba(var(--primary-rgb), 0.28);
}

.requests-studio .hr-workspace-tab--switch .hr-workspace-tab-hint {
  display: none;
}

.requests-studio .hr-workspace-panels {
  gap: 1rem;
}

.requests-studio .requests-form-card.admin-users-data-card {
  border-radius: var(--req-radius);
  border: 1px solid var(--req-edge-strong);
  background: var(--req-card);
  box-shadow: var(--req-shadow);
  overflow: hidden;
}

.requests-studio .req-operate {
  display: grid;
  grid-template-columns: minmax(12rem, 16rem) minmax(0, 1fr);
  gap: 1.25rem;
  align-items: start;
}

.requests-studio .req-operate__main .hr-action-card {
  margin: 0;
  border-radius: var(--req-radius);
  border: 1px solid var(--req-edge);
  background: var(--req-card);
  box-shadow: var(--req-shadow);
  overflow: visible;
  transform: none;
}

.requests-studio .req-operate__main .hr-action-card:hover {
  transform: none;
  box-shadow: var(--req-shadow);
}

.requests-studio .req-operate__main .hr-action-card--open,
.requests-studio .req-operate__main .hr-action-card.p-card--expanded {
  border-color: #cbd5e1;
  box-shadow:
    0 1px 3px rgba(15, 23, 42, 0.05),
    0 10px 28px rgba(15, 23, 42, 0.09);
}

.requests-studio .req-operate__main .hr-action-card__head {
  padding: 1.2rem 1.45rem 1rem;
  border-bottom: 1px solid var(--req-edge);
  background: var(--req-card);
}

.requests-studio .req-operate__main .hr-action-card__head .hr-card-icon {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 11px;
  background: linear-gradient(145deg, #2563eb, #1d4ed8);
  box-shadow: 0 6px 16px rgba(37, 99, 235, 0.28);
}

.requests-studio .req-operate__main .hr-action-card__panel {
  padding: 0 1.45rem 1.35rem;
}

.requests-studio .requests-operate-nav {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin: 0;
  padding: 0;
}

.requests-studio .requests-operate-nav-tab {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  width: 100%;
  padding: 0.72rem 0.8rem;
  border-radius: var(--req-radius-sm);
  border: 1px solid var(--req-edge);
  background: var(--req-card);
  text-align: left;
  color: #475569;
  box-shadow: var(--req-shadow-nav);
  cursor: default;
}

.requests-studio .requests-operate-nav-tab.is-active {
  background: linear-gradient(135deg, #eff6ff 0%, #f8fafc 100%);
  border-color: rgba(59, 130, 246, 0.32);
  color: #1e40af;
  box-shadow: 0 4px 16px rgba(37, 99, 235, 0.14);
}

.requests-studio .requests-operate-nav-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 1.65rem;
  height: 1.65rem;
  margin-top: 0.05rem;
  border-radius: 8px;
  background: rgba(var(--primary-rgb), 0.18);
  color: var(--primary-dark);
}

.requests-studio .requests-operate-nav-ico svg {
  width: 0.95rem;
  height: 0.95rem;
}

.requests-studio .requests-operate-nav-copy {
  display: flex;
  flex-direction: column;
  gap: 0.12rem;
  min-width: 0;
}

.requests-studio .requests-operate-nav-label {
  font-size: 0.82rem;
  font-weight: 750;
  line-height: 1.25;
  color: inherit;
}

.requests-studio .requests-operate-nav-hint {
  font-size: 0.68rem;
  line-height: 1.35;
  color: var(--text-soft);
}

.requests-studio .requests-operate-nav-tab.is-active .requests-operate-nav-hint {
  color: color-mix(in srgb, var(--primary-dark) 72%, var(--text-soft));
}

.requests-studio .requests-operate-nav-norm {
  display: inline-block;
  margin-top: 0.15rem;
  padding: 0.1rem 0.45rem;
  border-radius: 999px;
  font-size: 0.56rem;
  font-weight: 800;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  width: fit-content;
  background: rgba(37, 99, 235, 0.1);
  color: #1d4ed8;
}

.requests-studio .req-operate__rail {
  position: sticky;
  top: 0.75rem;
  padding: 0.85rem 0.75rem;
  border-radius: var(--req-radius);
  border: none;
  background: var(--req-surface);
  box-shadow: none;
}

.requests-studio .req-operate__rail-label {
  display: block;
  margin: 0 0 0.55rem 0.55rem;
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-soft);
}

.requests-studio .req-operate__main {
  min-width: 0;
}

.requests-studio .req-data-panel {
  padding: 1rem 1.1rem 1.15rem;
  border-radius: var(--req-radius);
  border: 1px solid var(--req-edge);
  background: var(--req-card);
  box-shadow: var(--req-shadow-sm);
}

.requests-studio .req-form-card.admin-users-data-card {
  border-radius: var(--req-radius);
  border: 1px solid var(--req-edge-strong);
  background: var(--req-card);
  box-shadow: var(--req-shadow);
  overflow: hidden;
}

@media (max-width: 900px) {
  .requests-studio .req-operate {
    grid-template-columns: 1fr;
  }

  .requests-studio .req-operate__rail {
    position: static;
  }

  .requests-studio .requests-operate-nav-hint,
  .requests-studio .requests-operate-nav-norm {
    display: none;
  }
}

body[data-theme="dark"] .requests-studio .requests-operate-nav-tab {
  background: rgba(15, 28, 46, 0.92);
  border-color: rgba(148, 196, 255, 0.14);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

body[data-theme="dark"] .requests-studio .requests-operate-nav-tab.is-active {
  background: linear-gradient(135deg, rgba(30, 58, 138, 0.45), rgba(15, 28, 46, 0.9));
  border-color: rgba(96, 165, 250, 0.35);
}

body[data-theme="dark"] .requests-studio .req-operate__main .hr-action-card {
  background: rgba(12, 26, 44, 0.92);
  border-color: rgba(148, 196, 255, 0.14);
}

/* ── Solicitudes · Consultar ── */
.requests-studio .requests-data-panel {
  padding: 1.05rem 1.15rem 1.2rem;
  gap: 0;
}

.requests-studio .requests-data-layout--admin {
  display: grid;
  grid-template-columns: minmax(250px, 290px) minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
}

.requests-studio .requests-data-sidebar {
  padding: 0.9rem 0.95rem;
  border-radius: var(--req-radius-sm);
  border: 1px solid var(--req-edge);
  background:
    linear-gradient(180deg, rgba(55, 124, 192, 0.05) 0%, transparent 42%),
    var(--req-surface);
  box-shadow: var(--req-shadow-sm);
  position: sticky;
  top: 0.65rem;
  max-height: calc(100dvh - 7.5rem);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.requests-studio .requests-data-sidebar__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.65rem;
  margin-bottom: 0.45rem;
}

.requests-studio .requests-data-sidebar__eyebrow {
  display: block;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--primary-dark) 72%, #64748b);
  margin-bottom: 0.2rem;
}

.requests-studio .requests-data-sidebar__title {
  margin: 0;
  font-size: 1rem;
  font-weight: 800;
  color: var(--primary-dark);
  line-height: 1.2;
}

.requests-studio .requests-data-sidebar__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  height: 2rem;
  padding: 0 0.55rem;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 800;
  color: var(--primary-dark);
  background: var(--req-card);
  border: 1px solid var(--req-edge-strong);
  box-shadow: var(--req-shadow-sm);
}

.requests-studio .requests-data-sidebar__hint {
  margin: 0 0 0.75rem;
  font-size: 0.78rem;
  line-height: 1.45;
}

.requests-studio .requests-data-sidebar__hub {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

.requests-studio .requests-company-directory {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}

.requests-studio .requests-company-directory__tools {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.requests-studio .requests-company-directory__search input[type="search"] {
  width: 100%;
  min-height: 2.2rem;
  padding: 0.45rem 0.72rem 0.45rem 2rem;
  border-radius: 10px;
  border: 1px solid var(--req-edge-strong);
  background:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='15' height='15' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E")
    no-repeat 0.62rem center,
    var(--req-card);
  font-size: 0.8rem;
}

.requests-studio .requests-company-directory__sort {
  display: flex;
  flex-wrap: wrap;
  gap: 0.32rem;
}

.requests-studio .requests-company-directory__sort-btn {
  flex: 1 1 auto;
  min-width: 0;
  padding: 0.32rem 0.5rem;
  border-radius: 999px;
  border: 1px solid var(--req-edge);
  background: var(--req-card);
  color: var(--primary-dark);
  font-size: 0.72rem;
  font-weight: 650;
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.requests-studio .requests-company-directory__sort-btn.is-active {
  background: linear-gradient(135deg, var(--req-blue), var(--primary-dark));
  border-color: transparent;
  color: #fff;
  box-shadow: 0 4px 12px rgba(var(--primary-rgb), 0.18);
}

.requests-studio .requests-company-directory__pending-only {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  font-size: 0.76rem;
  color: #64748b;
  cursor: pointer;
  user-select: none;
}

.requests-studio .requests-company-directory__pending-only strong {
  color: var(--primary-dark);
  font-weight: 800;
}

.requests-studio .requests-company-directory__meta {
  margin: 0;
  font-size: 0.74rem;
  line-height: 1.35;
}

.requests-studio .requests-company-directory__meta strong {
  color: var(--primary-dark);
}

.requests-studio .requests-company-directory__list {
  flex: 1;
  min-height: 8.5rem;
  max-height: min(52vh, 34rem);
  overflow-y: auto;
  overflow-x: hidden;
  display: flex;
  flex-direction: column;
  gap: 0.32rem;
  padding: 0.2rem 0.15rem 0.2rem 0;
  margin: 0;
  scrollbar-gutter: stable;
}

.requests-studio .requests-company-directory__empty {
  margin: 0.35rem 0;
  font-size: 0.78rem;
  line-height: 1.45;
}

.requests-studio .requests-company-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.55rem;
  width: 100%;
  padding: 0.48rem 0.55rem;
  border-radius: 11px;
  border: 1px solid transparent;
  background: var(--req-card);
  text-align: left;
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}

.requests-studio .requests-company-row:hover {
  border-color: var(--req-edge-strong);
  background: color-mix(in srgb, var(--req-card) 88%, var(--req-blue-soft) 12%);
}

.requests-studio .requests-company-row.is-active {
  border-color: color-mix(in srgb, var(--req-blue) 45%, var(--req-edge));
  background: color-mix(in srgb, var(--req-card) 78%, var(--req-blue-soft) 22%);
  box-shadow: 0 4px 14px rgba(var(--primary-rgb), 0.1);
}

.requests-studio .requests-company-row--all {
  border-color: var(--req-edge);
  background: color-mix(in srgb, var(--req-surface) 70%, var(--req-card) 30%);
}

.requests-studio .requests-company-row--all.is-active {
  border-color: color-mix(in srgb, var(--req-blue) 50%, var(--req-edge));
  background: linear-gradient(135deg, rgba(55, 124, 192, 0.12), rgba(55, 124, 192, 0.04));
}

.requests-studio .requests-company-row__logo {
  width: 2rem;
  height: 2rem;
  min-width: 2rem;
  border-radius: 999px;
  border: 1px solid var(--req-edge);
  background: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.requests-studio .requests-company-row__logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.requests-studio .requests-company-row__logo--fallback,
.requests-studio .requests-company-row__logo--all {
  font-size: 0.78rem;
  font-weight: 800;
  color: var(--primary-dark);
  background: color-mix(in srgb, var(--req-blue-soft) 55%, #fff 45%);
}

.requests-studio .requests-company-row__logo--all svg {
  width: 1rem;
  height: 1rem;
}

.requests-studio .requests-company-row__body {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.12rem;
}

.requests-studio .requests-company-row__name {
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--primary-dark);
  line-height: 1.25;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.requests-studio .requests-company-row__meta {
  font-size: 0.68rem;
  color: #64748b;
  line-height: 1.3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.requests-studio .requests-company-row__pending {
  min-width: 1.35rem;
  height: 1.35rem;
  padding: 0 0.35rem;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.68rem;
  font-weight: 800;
  color: #fff;
  background: linear-gradient(135deg, #f59e0b, #d97706);
  box-shadow: 0 2px 8px rgba(217, 119, 6, 0.28);
}

.requests-studio .requests-data-main {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

.requests-studio .requests-data-head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem 1rem;
  padding: 0.15rem 0.05rem 0;
}

.requests-studio .requests-data-head__eyebrow {
  display: block;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--primary-dark) 72%, #64748b);
  margin-bottom: 0.25rem;
}

.requests-studio .requests-data-head__title {
  margin: 0;
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--primary-dark);
  line-height: 1.2;
}

.requests-studio .requests-data-head__meta {
  margin: 0.35rem 0 0;
  font-size: 0.84rem;
  line-height: 1.45;
  max-width: 42rem;
}

.requests-studio .requests-data-head__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.5rem;
}

.requests-studio .requests-data-scope-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.42rem 0.72rem;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 650;
  color: var(--primary-dark);
  background: var(--req-surface);
  border: 1px solid var(--req-edge);
}

.requests-studio .requests-data-scope-badge--active {
  color: #fff;
  background: linear-gradient(135deg, var(--req-blue), var(--primary-dark));
  border-color: transparent;
  box-shadow: 0 6px 16px rgba(var(--primary-rgb), 0.22);
}

.requests-studio .requests-data-toolbar {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  padding: 0.85rem 0.95rem;
  border-radius: var(--req-radius-sm);
  border: 1px solid var(--req-edge);
  background: var(--req-surface);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65);
}

.requests-studio .requests-data-toolbar__filters {
  min-width: 0;
}

.requests-studio .requests-data-filters.ops-filters-bar {
  margin: 0;
  padding: 0;
  gap: 0.42rem;
}

.requests-studio .requests-data-filters .ops-filter-pill {
  border-radius: 999px;
  padding: 0.38rem 0.72rem;
  font-size: 0.78rem;
  border: 1px solid var(--req-edge);
  background: var(--req-card);
  box-shadow: none;
}

.requests-studio .requests-data-filters .ops-filter-pill.is-active {
  background: linear-gradient(135deg, var(--req-blue), var(--primary-dark));
  border-color: transparent;
  color: #fff;
  box-shadow: 0 6px 14px rgba(var(--primary-rgb), 0.2);
}

.requests-studio .requests-data-filters .ops-filter-pill.is-active strong {
  background: rgba(255, 255, 255, 0.22);
  color: #fff;
}

.requests-studio .requests-data-toolbar__tools {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.65rem;
  align-items: end;
}

.requests-studio .requests-data-search {
  display: flex;
  flex-direction: column;
  gap: 0.28rem;
  min-width: 0;
}

.requests-studio .requests-data-search__icon {
  display: none;
}

.requests-studio .requests-data-search input[type="search"] {
  width: 100%;
  min-height: 2.35rem;
  padding: 0.5rem 0.8rem 0.5rem 2.15rem;
  border-radius: 12px;
  border: 1px solid var(--req-edge-strong);
  background:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E")
    no-repeat 0.72rem center,
    var(--req-card);
  font-size: 0.84rem;
}

.requests-studio .requests-data-layout.transport-ops-layout {
  display: inline-flex;
  gap: 0.35rem;
  padding: 0.28rem;
  border-radius: 12px;
  border: 1px solid var(--req-edge);
  background: var(--req-card);
}

.requests-studio .requests-data-layout .btn-sm {
  min-width: 5.5rem;
  border-radius: 9px;
}

.requests-studio .requests-data-result-meta {
  margin: 0;
  font-size: 0.8rem;
  color: #64748b;
}

.requests-studio .requests-data-result-meta strong {
  color: var(--primary-dark);
  font-weight: 800;
}

.requests-studio .requests-data-results {
  min-width: 0;
}

.requests-studio .requests-data-results .request-ops-cards,
.requests-studio .requests-data-results .trip-ops-cards {
  display: flex;
  flex-wrap: wrap;
  align-content: flex-start;
  align-items: stretch;
  gap: var(--ops-cards-gap, 0.75rem);
}

.requests-studio .requests-data-results .vehicle-fleet-list-wrap,
.requests-studio .requests-data-results .table-wrap {
  border-radius: var(--req-radius-sm);
  border: 1px solid var(--req-edge);
  box-shadow: var(--req-shadow-sm);
  overflow: hidden;
}

body[data-theme="dark"] .requests-studio .requests-data-sidebar {
  background: linear-gradient(180deg, rgba(55, 124, 192, 0.08) 0%, transparent 42%), rgba(10, 22, 38, 0.72);
}

body[data-theme="dark"] .requests-studio .requests-data-toolbar {
  background: rgba(10, 22, 38, 0.55);
  box-shadow: inset 0 1px 0 rgba(148, 196, 255, 0.06);
}

body[data-theme="dark"] .requests-studio .requests-data-search input[type="search"] {
  background-color: rgba(10, 22, 38, 0.9);
  border-color: rgba(148, 196, 255, 0.16);
  color: #e8f2fc;
}

body[data-theme="dark"] .requests-studio .requests-data-filters .ops-filter-pill {
  background: rgba(10, 22, 38, 0.72);
  border-color: rgba(148, 196, 255, 0.14);
  color: #d7e8fb;
}

body[data-theme="dark"] .requests-studio .requests-data-scope-badge {
  background: rgba(10, 22, 38, 0.72);
  border-color: rgba(148, 196, 255, 0.14);
  color: #d7e8fb;
}

body[data-theme="dark"] .requests-studio .requests-company-directory__search input[type="search"] {
  background-color: rgba(10, 22, 38, 0.9);
  border-color: rgba(148, 196, 255, 0.16);
  color: #e8f2fc;
}

body[data-theme="dark"] .requests-studio .requests-company-directory__sort-btn {
  background: rgba(10, 22, 38, 0.72);
  border-color: rgba(148, 196, 255, 0.14);
  color: #d7e8fb;
}

body[data-theme="dark"] .requests-studio .requests-company-row {
  background: rgba(10, 22, 38, 0.55);
}

body[data-theme="dark"] .requests-studio .requests-company-row__name {
  color: #e8f2fc;
}

body[data-theme="dark"] .requests-studio .requests-company-row__meta {
  color: #9eb8d8;
}

@media (max-width: 1080px) {
  .requests-studio .requests-data-layout--admin {
    grid-template-columns: 1fr;
  }

  .requests-studio .requests-data-sidebar {
    position: static;
    max-height: none;
  }

  .requests-studio .requests-company-directory__list {
    max-height: min(42vh, 22rem);
  }
}

@media (max-width: 720px) {
  .requests-studio .requests-data-toolbar__tools {
    grid-template-columns: 1fr;
  }

  .requests-studio .requests-data-layout.transport-ops-layout {
    width: 100%;
    justify-content: stretch;
  }

  .requests-studio .requests-data-layout .btn-sm {
    flex: 1 1 0;
  }

  .requests-studio .requests-data-head__actions {
    width: 100%;
    justify-content: flex-start;
  }
}

/* ===================================================================
   Tarjetas de solicitud — vista Consultar
   Correcciones: cabecera (display:contents), anchos, responsive, estados
   =================================================================== */

.requests-studio,
.transport-studio .transport-data-pane__body {
  --req-card-min: 18.5rem;
  --req-card-max: 24rem;
}

.requests-studio .requests-data-results .request-ops-cards,
.requests-studio .requests-data-results .trip-ops-cards.request-ops-cards,
.transport-studio .transport-data-pane__body .request-ops-cards {
  --ops-cards-min: var(--req-card-min);
  --ops-cards-max: var(--req-card-max);
}

/* Ancho controlado: no estirar tarjetas en pantallas grandes */
.request-ops-card.portal-ops-card {
  flex: 1 1 var(--req-card-min, 18.5rem);
  max-width: var(--req-card-max, 24rem);
  width: 100%;
  gap: 0.55rem;
  padding: 0.75rem 0.88rem 0.7rem 1rem;
  border-radius: 14px;
  box-shadow:
    0 1px 2px rgba(15, 35, 70, 0.04),
    0 8px 28px rgba(15, 35, 70, 0.08);
}

/* Especificidad correcta para tintes por estado (antes no aplicaban) */
.request-ops-card.portal-ops-card {
  background: linear-gradient(165deg, #ffffff 0%, #fafcff 52%, #f4f8fc 100%);
}

.request-ops-card.portal-ops-card.request-ops-card--pendiente {
  background: linear-gradient(165deg, #fffdf8 0%, #fffaf0 48%, #ffffff 100%);
}

.request-ops-card.portal-ops-card.request-ops-card--aprobada_pendiente_asignacion {
  background: linear-gradient(165deg, #f8fbff 0%, #eff6ff 48%, #ffffff 100%);
}

.request-ops-card.portal-ops-card.request-ops-card--viaje_asignado,
.request-ops-card.portal-ops-card.request-ops-card--has-trip {
  background: linear-gradient(165deg, #f6fdf9 0%, #ecfdf5 42%, #ffffff 100%);
}

.request-ops-card.portal-ops-card.request-ops-card--cancelada,
.request-ops-card.portal-ops-card.request-ops-card--rechazada {
  background: linear-gradient(165deg, #fffafa 0%, #fef2f2 42%, #ffffff 100%);
}

.request-ops-card.portal-ops-card::before {
  width: 4px;
  border-radius: 14px 0 0 14px;
}

.request-ops-card.portal-ops-card:hover {
  transform: translateY(-2px);
  box-shadow:
    0 2px 6px rgba(15, 35, 70, 0.06),
    0 12px 32px rgba(15, 35, 70, 0.1);
}

/* ── Cabecera: anula display:contents del sistema portal-ops-card ── */
.request-ops-card .trip-ops-card-head {
  grid-template-columns: minmax(0, 1fr) auto;
  column-gap: 0.55rem;
  row-gap: 0.35rem;
  align-items: start;
}

.request-ops-card .trip-ops-card-head-main {
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
  grid-column: 1;
  grid-row: 1;
  min-width: 0;
}

.request-ops-card .trip-ops-card-head-info {
  grid-column: unset;
  grid-row: unset;
  flex: 1 1 auto;
  min-width: 0;
}

.request-ops-card .request-ops-card-company-logo,
.request-ops-card .request-ops-card-company-logo img {
  grid-column: unset;
  grid-row: unset;
  flex-shrink: 0;
  width: 2.5rem;
  height: 2.5rem;
  min-width: 2.5rem;
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, var(--req-blue, #377cc0) 22%, #e2e8f0);
  background: #fff;
  box-shadow: 0 3px 10px rgba(var(--primary-rgb, 55, 124, 192), 0.1);
  object-fit: contain;
}

.request-ops-card .request-company-logo--fallback {
  font-size: 0.88rem;
  border-radius: 10px;
}

.request-ops-card .portal-ops-card-badges {
  grid-column: 2;
  grid-row: 1;
  max-width: none;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: flex-end;
  gap: 0.28rem;
}

.request-ops-card .portal-ops-card-status-pill {
  max-width: 100%;
}

.request-ops-card .portal-ops-card-status-pill__text {
  max-width: 10.5rem;
  white-space: normal;
  text-align: left;
  line-height: 1.15;
}

.request-ops-card-kicker {
  margin: 0 0 0.12rem;
  font-size: 0.64rem;
  font-weight: 800;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--primary-dark, #2a6399) 68%, #64748b);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.request-ops-card .trip-ops-card-title {
  font-size: 0.92rem;
  line-height: 1.25;
  margin: 0 0 0.18rem;
  -webkit-line-clamp: 2;
}

/* Meta chips */
.request-ops-card-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.28rem;
}

.request-ops-card-chip {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  padding: 0.14rem 0.46rem;
  border-radius: 999px;
  font-size: 0.62rem;
  font-weight: 700;
  line-height: 1.25;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  border: 1px solid transparent;
}

.request-ops-card-chip--ok {
  color: #047857;
  background: rgba(16, 185, 129, 0.12);
  border-color: rgba(16, 185, 129, 0.24);
}

.request-ops-card-chip--user {
  color: #475569;
  background: #f1f5f9;
  border-color: #e2e8f0;
  max-width: 100%;
}

/* ── Ruta ── */
.request-ops-card-route {
  padding: 0.55rem 0.62rem;
  border-radius: 11px;
  background: linear-gradient(135deg, #f8fafc 0%, #f1f5f9 100%);
  border: 1px solid #e2e8f0;
  gap: 0.35rem;
  min-width: 0;
}

.request-ops-card-route .trip-ops-card-route-node {
  min-width: 0;
}

.request-ops-card-route .trip-ops-card-route-node strong {
  font-size: 0.78rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: block;
  max-width: 100%;
}

.request-ops-card-route .trip-ops-card-route-city {
  max-width: 100%;
}

.request-ops-card-route .trip-ops-card-route-pin--origin svg {
  color: #16a34a;
}

.request-ops-card-route .trip-ops-card-route-pin--dest svg {
  color: #2563eb;
}

.request-ops-card-route .trip-ops-card-route-connector {
  display: inline-flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: center;
  gap: 0.15rem;
  min-width: 1.75rem;
  max-width: 4.25rem;
  align-self: center;
}

.request-ops-card-route .trip-ops-card-route-line {
  flex: 1 1 auto;
  min-width: 0.35rem;
  border-top: 2px solid color-mix(in srgb, var(--req-blue, #377cc0) 28%, #cbd5e1);
}

.trip-ops-card-route-distance {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  padding: 0.1rem 0.32rem;
  border-radius: 999px;
  font-size: 0.56rem;
  font-weight: 800;
  color: #1e40af;
  background: rgba(59, 130, 246, 0.12);
  border: 1px solid rgba(59, 130, 246, 0.2);
  white-space: nowrap;
  line-height: 1.2;
}

.request-ops-card-route .trip-ops-card-route-arrow svg {
  width: 0.85rem;
  height: 0.85rem;
}

/* Cuadrícula de datos */
.request-ops-card-spec-grid {
  gap: 0.32rem;
}

.request-ops-card-spec-grid .trip-ops-card-item {
  min-width: 0;
}

.request-ops-card-spec-grid .trip-ops-card-item:first-child,
.request-ops-card-spec-grid .trip-ops-card-item:nth-child(2) {
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
}

.request-ops-card-spec-grid .trip-ops-card-item-body,
.request-ops-card-spec-grid .trip-ops-card-item-value {
  min-width: 0;
}

.request-ops-card-spec-grid .trip-ops-card-item:nth-child(2) .trip-ops-card-item-value {
  color: #0d2f5c;
  font-weight: 800;
}

/* Bloque viaje asignado */
.request-ops-card-trip-bar {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.48rem 0.58rem;
  border-radius: 10px;
  margin: 0;
  min-width: 0;
}

.request-ops-card-trip-copy {
  display: grid;
  gap: 0.06rem;
  min-width: 0;
  flex: 1 1 auto;
}

.request-ops-card-trip-no {
  font-size: 0.76rem;
  font-weight: 800;
  color: #065f46;
  line-height: 1.2;
}

.request-ops-card-trip-meta {
  font-size: 0.68rem;
  line-height: 1.3;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.request-ops-card-trip-sep {
  margin: 0 0.22rem;
  opacity: 0.55;
}

.request-ops-card .request-ops-card-trip-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.85rem;
  height: 1.85rem;
  border-radius: 9px;
  background: rgba(5, 150, 105, 0.14);
  color: #047857;
  flex-shrink: 0;
}

.request-ops-card .request-ops-card-trip-ico svg {
  width: 0.95rem;
  height: 0.95rem;
}

/* Pendiente de asignación */
.request-ops-card-await {
  display: flex;
  align-items: flex-start;
  gap: 0.45rem;
  margin: 0;
  padding: 0.42rem 0.55rem;
  border-radius: 10px;
  font-size: 0.72rem;
  font-weight: 650;
  color: #1e40af;
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.12), rgba(59, 130, 246, 0.05));
  border: 1px dashed rgba(59, 130, 246, 0.32);
  min-width: 0;
}

.request-ops-card-await-text {
  flex: 1 1 auto;
  min-width: 0;
  line-height: 1.35;
}

.request-ops-card-await-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.55rem;
  height: 1.55rem;
  border-radius: 8px;
  background: rgba(59, 130, 246, 0.14);
  flex-shrink: 0;
  margin-top: 0.05rem;
}

.request-ops-card-await-ico svg {
  width: 0.85rem;
  height: 0.85rem;
}

/* Acciones: botones peligro ocupan celda completa, no 50% suelto */
.request-ops-card .portal-ops-card-actions-grid {
  gap: 0.28rem;
}

.request-ops-card .portal-ops-card-actions-grid .trip-ops-card-btn--danger:last-child {
  grid-column: 1 / -1;
  max-width: none;
  justify-self: stretch;
}

.request-ops-card .trip-ops-card-btn {
  min-height: 1.95rem;
  font-size: 0.68rem;
}

.request-ops-card .portal-ops-card-foot {
  padding-top: 0.4rem;
  font-size: 0.68rem;
}

/* ── Container queries (tarjeta estrecha) ── */
@container ops-card (max-width: 17.5rem) {
  .request-ops-card .trip-ops-card-head {
    grid-template-columns: 1fr;
  }

  .request-ops-card .trip-ops-card-head-main {
    grid-column: 1;
    grid-row: 1;
  }

  .request-ops-card .portal-ops-card-badges {
    grid-column: 1;
    grid-row: 2;
    justify-content: flex-start;
  }

  .request-ops-card .portal-ops-card-status-pill__text {
    max-width: none;
  }

  .request-ops-card-route {
    grid-template-columns: 1fr;
    gap: 0.28rem;
  }

  .request-ops-card-route .trip-ops-card-route-node--dest {
    text-align: left;
    justify-items: start;
  }

  .request-ops-card-route .trip-ops-card-route-connector {
    display: none;
  }

  .request-ops-card-spec-grid {
    grid-template-columns: 1fr;
  }

  .request-ops-card .portal-ops-card-actions-grid {
    grid-template-columns: 1fr;
  }
}

@container ops-card (max-width: 20rem) {
  .trip-ops-card-route-distance {
    display: none;
  }
}

/* ── Viewport: móvil y panel estrecho (admin sidebar) ── */
@media (max-width: 720px) {
  .requests-studio,
  .transport-studio .transport-data-pane__body {
    --req-card-min: 100%;
    --req-card-max: 100%;
  }

  .requests-studio .requests-data-results .request-ops-cards > .request-ops-card,
  .transport-studio .transport-data-pane__body .request-ops-cards > .request-ops-card {
    flex: 1 1 100%;
    max-width: 100%;
  }
}

@media (max-width: 520px) {
  .request-ops-card .trip-ops-card-btn {
    white-space: normal;
    line-height: 1.2;
    padding: 0.35rem 0.4rem;
  }

  .request-ops-card-route .trip-ops-card-route-node strong {
    font-size: 0.82rem;
  }
}

/* Dark mode */
body[data-theme="dark"] .request-ops-card.portal-ops-card {
  background: linear-gradient(165deg, rgba(18, 32, 50, 0.98) 0%, rgba(12, 24, 38, 0.96) 100%);
  border-color: rgba(148, 196, 255, 0.16);
}

body[data-theme="dark"] .request-ops-card.portal-ops-card.request-ops-card--pendiente,
body[data-theme="dark"] .request-ops-card.portal-ops-card.request-ops-card--aprobada_pendiente_asignacion,
body[data-theme="dark"] .request-ops-card.portal-ops-card.request-ops-card--has-trip,
body[data-theme="dark"] .request-ops-card.portal-ops-card.request-ops-card--cancelada,
body[data-theme="dark"] .request-ops-card.portal-ops-card.request-ops-card--rechazada {
  background: linear-gradient(165deg, rgba(18, 32, 50, 0.98) 0%, rgba(12, 24, 38, 0.96) 100%);
}

body[data-theme="dark"] .request-ops-card-kicker {
  color: #94a8c0;
}

body[data-theme="dark"] .request-ops-card-route {
  background: rgba(15, 28, 46, 0.72);
  border-color: rgba(148, 196, 255, 0.14);
}

body[data-theme="dark"] .request-ops-card-spec-grid .trip-ops-card-item:first-child,
body[data-theme="dark"] .request-ops-card-spec-grid .trip-ops-card-item:nth-child(2) {
  background: rgba(15, 28, 46, 0.55);
}

body[data-theme="dark"] .request-ops-card-chip--user {
  color: #cbd5e1;
  background: rgba(15, 28, 46, 0.72);
  border-color: rgba(148, 196, 255, 0.14);
}

body[data-theme="dark"] .request-ops-card-trip-no {
  color: #6ee7b7;
}

body[data-theme="dark"] .request-ops-card-await {
  color: #93c5fd;
  background: rgba(30, 58, 138, 0.28);
  border-color: rgba(96, 165, 250, 0.28);
}

