/**
 * @author João Batista <joao.cardoso@unitri.edu.br>
 * @copyright Copyright (c) 2026, ASOEC. (http://asoec.com.br)
 * @version   1.1.0
 * not-found.css — Página 404
 * @package CApDHC
 */

/* ── Wrapper ──────────────────────────────────────── */
.capdhc-not-found {
  display: flex;
  flex-direction: column;
  min-height: calc(100dvh - var(--header-h, 112px));
  background-color: var(--color-bg-light);
}

/* ── Hero com o grande "404" ───────────────────────── */
.capdhc-not-found__hero {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: linear-gradient(
    150deg,
    var(--color-navy-dark) 0%,
    var(--color-navy) 60%,
    var(--color-navy-light) 100%
  );
  padding: 4rem 1rem 5rem;
}

/* Linhas decorativas de fundo */
.capdhc-not-found__lines {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
}

.capdhc-not-found__lines span {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) rotate(-25deg);
  width: 140%;
  height: 1px;
  background: var(--overlay-white-08);
}

.capdhc-not-found__lines span:nth-child(1) {
  margin-top: -60px;
}
.capdhc-not-found__lines span:nth-child(2) {
  margin-top: 0px;
}
.capdhc-not-found__lines span:nth-child(3) {
  margin-top: 60px;
}

/* Número 404 */
.capdhc-not-found__code {
  position: relative;
  z-index: 1;
  font-family: var(--font-heading);
  font-size: clamp(7rem, 22vw, 14rem);
  font-weight: 900;
  letter-spacing: -0.04em;
  line-height: 1;
  color: transparent;
  -webkit-text-stroke: 2px var(--overlay-gold-35);
  text-shadow:
    0 0 80px var(--overlay-gold-15),
    0 4px 40px rgba(0, 0, 0, 0.4);
  user-select: none;
}

/* ── Corpo ──────────────────────────────────────────── */
.capdhc-not-found__body {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding-block: 3.5rem 4rem;
  flex: 1;
}

/* Badge */
.capdhc-not-found__badge {
  display: inline-block;
  padding: 0.25rem 0.875rem;
  border-radius: var(--radius-full);
  background-color: var(--color-red);
  color: var(--color-white);
  font-family: var(--font-heading);
  font-size: var(--font-size-xs);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 1.25rem;
}

/* Título */
.capdhc-not-found__title {
  font-family: var(--font-heading);
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 800;
  color: var(--color-navy);
  margin-bottom: 1rem;
  line-height: 1.2;
}

/* Descrição */
.capdhc-not-found__desc {
  font-family: var(--font-body);
  font-size: var(--font-size-lg);
  color: var(--color-text-muted);
  line-height: 1.7;
  max-width: 480px;
  margin-bottom: 2.5rem;
}

/* ── Botões de ação ─────────────────────────────────── */
.capdhc-not-found__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
  margin-bottom: 3rem;
}

.capdhc-not-found__btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.75rem;
  border-radius: var(--radius-full);
  font-family: var(--font-heading);
  font-size: var(--font-size-sm);
  font-weight: 700;
  letter-spacing: 0.03em;
  text-decoration: none;
  transition: all var(--transition-base);
  cursor: pointer;
}

.capdhc-not-found__btn--primary {
  background-color: var(--color-navy);
  color: var(--color-white);
  box-shadow: var(--shadow-card);
}

.capdhc-not-found__btn--primary:hover,
.capdhc-not-found__btn--primary:focus-visible {
  background-color: var(--color-navy-light);
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-2px);
}

.capdhc-not-found__btn--outline {
  background-color: transparent;
  color: var(--color-navy);
  border: 2px solid var(--color-navy);
}

.capdhc-not-found__btn--outline:hover,
.capdhc-not-found__btn--outline:focus-visible {
  background-color: var(--color-navy);
  color: var(--color-white);
  transform: translateY(-2px);
}

/* ── Navegação de links úteis ───────────────────────── */
.capdhc-not-found__nav {
  border-top: 1px solid var(--color-border);
  padding-top: 2rem;
  width: 100%;
  max-width: 560px;
}

.capdhc-not-found__nav-label {
  font-family: var(--font-body);
  font-size: var(--font-size-sm);
  color: var(--color-text-light);
  margin-bottom: 1rem;
}

.capdhc-not-found__nav-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1rem;
  justify-content: center;
  list-style: none;
  margin: 0;
  padding: 0;
}

.capdhc-not-found__nav-list a {
  font-family: var(--font-body);
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-navy);
  text-decoration: none;
  padding: 0.35rem 0.875rem;
  border-radius: var(--radius-sm);
  background-color: var(--color-bg-white);
  border: 1px solid var(--color-border);
  transition: all var(--transition-fast);
}

.capdhc-not-found__nav-list a:hover,
.capdhc-not-found__nav-list a:focus-visible {
  background-color: var(--color-navy);
  color: var(--color-white);
  border-color: var(--color-navy);
}

/* ── Responsivo ─────────────────────────────────────── */
@media (max-width: 639px) {
  .capdhc-not-found__hero {
    padding: 3rem 1rem 4rem;
  }

  .capdhc-not-found__desc br {
    display: none;
  }

  .capdhc-not-found__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .capdhc-not-found__btn {
    justify-content: center;
  }
}
