/* =============================================================
   NCTE 2026 — Legal pages (privacy / terms / code of conduct)
   ----------------------------------------------------------------
   Shared structure: shared sub-header (logo + back), hero with title
   and last-updated meta, and a long-form prose article body with
   numbered headings. Brand-coherent with the rest of the site.
   ============================================================= */

/* Sub-header reuses the pattern from registro-presencial.html */
.nsub-header {
  border-bottom: 1px solid var(--line);
  background: rgba(255,255,255,.95);
  backdrop-filter: saturate(140%) blur(12px);
  position: sticky; top: 0; z-index: 50;
}
.nsub-header .strip-flag { height: 4px; }
.nsub-header__bar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; padding: 14px 0;
}
.nsub-header__logo {
  display: inline-flex; align-items: center; gap: 12px;
  text-decoration: none; color: inherit;
  min-width: 0;
}
.nsub-header__back {
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--cccn-blue-900); font-weight: 600;
  text-decoration: none; font-size: 14px;
  padding: 8px 14px; border-radius: 999px;
  border: 1px solid var(--line); background: #fff;
  transition: background .15s ease, border-color .15s ease;
  flex-shrink: 0; font-family: var(--font-sans);
}
.nsub-header__back:hover {
  background: var(--cream); border-color: var(--cccn-red); color: var(--cccn-red);
}

/* ---- Hero ---- */
.nlegal-hero {
  padding: 56px 0 28px;
  background:
    radial-gradient(ellipse 60% 80% at 100% 0%, rgba(195,15,40,.05), transparent 60%),
    radial-gradient(ellipse 60% 60% at 0% 100%, rgba(4,26,113,.04), transparent 60%);
}
.nlegal-hero__chip {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px 6px 8px; border-radius: 999px;
  background: rgba(195,15,40,.08); color: var(--cccn-red);
  font-size: 12px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
  margin-bottom: 18px;
}
.nlegal-hero__chip .dot {
  width: 8px; height: 8px; border-radius: 50%; background: var(--cccn-red);
  box-shadow: 0 0 0 4px rgba(195,15,40,.18);
}
.nlegal-hero h1 {
  font-family: var(--font-display); font-weight: 600;
  font-size: clamp(34px, 4.4vw, 52px); line-height: 1.04;
  color: var(--cccn-blue-900); letter-spacing: -.02em;
  margin: 0 0 14px;
}
.nlegal-hero h1 em {
  font-style: italic; color: var(--cccn-red); font-weight: 600;
}
.nlegal-hero p.lede {
  font-size: 17px; line-height: 1.55; color: var(--ink-2); margin: 0;
  max-width: 720px;
}
.nlegal-meta {
  display: flex; gap: 22px; margin-top: 22px; flex-wrap: wrap;
  font-size: 13px; color: var(--muted);
}
.nlegal-meta b { color: var(--cccn-blue-900); font-weight: 700; }

/* ---- Article body ---- */
.nlegal-body {
  padding: 36px 0 80px;
}
.nlegal-article {
  max-width: 760px;
  font-size: 15.5px; line-height: 1.7; color: var(--ink);
}
.nlegal-article h2 {
  font-family: var(--font-display); font-weight: 600;
  font-size: 26px; color: var(--cccn-blue-900);
  margin: 36px 0 14px; line-height: 1.2;
  letter-spacing: -.01em;
}
.nlegal-article h2:first-child { margin-top: 0; }
.nlegal-article h2 small {
  display: block; font-family: var(--font-sans); font-size: 11.5px;
  letter-spacing: .14em; text-transform: uppercase; color: var(--cccn-red);
  font-weight: 800; margin-bottom: 6px;
}
.nlegal-article h3 {
  font-family: var(--font-sans); font-weight: 700;
  font-size: 17px; color: var(--cccn-blue-900);
  margin: 24px 0 8px;
}
.nlegal-article p { margin: 0 0 14px; }
.nlegal-article ul, .nlegal-article ol {
  margin: 0 0 14px; padding-left: 24px;
}
.nlegal-article li { margin-bottom: 6px; }
.nlegal-article a {
  color: var(--cccn-red); text-decoration: underline;
  text-decoration-thickness: 1.5px; text-underline-offset: 3px;
}
.nlegal-article a:hover { color: var(--cccn-red-700); }
.nlegal-article strong { color: var(--cccn-blue-900); font-weight: 700; }
.nlegal-article hr {
  border: 0; height: 1px; background: var(--line); margin: 32px 0;
}

/* Placeholder banner — shown while real content is being drafted */
.nlegal-pending {
  display: flex; align-items: flex-start; gap: 14px;
  padding: 18px 20px;
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: 14px;
  margin-bottom: 28px;
}
.nlegal-pending svg {
  flex-shrink: 0; color: var(--cccn-red);
}
.nlegal-pending p {
  margin: 0; font-size: 14px; color: var(--ink-2); line-height: 1.5;
}
.nlegal-pending b { color: var(--cccn-blue-900); }

/* ---- Footer ---- */
.nlegal-foot {
  padding: 28px 0; text-align: center; color: var(--muted);
  font-size: 13px; border-top: 1px solid var(--line);
  background: #fff;
}
.nlegal-foot a { color: var(--cccn-blue-900); font-weight: 600; }

/* ---- Responsive ---- */
@media (max-width: 720px) {
  .nsub-header__bar { padding: 10px 0; gap: 12px; }
  .nsub-header__back { padding: 8px 12px; font-size: 13px; }
  .nlegal-hero { padding: 36px 0 18px; }
  .nlegal-hero h1 { font-size: clamp(26px, 7vw, 34px); }
  .nlegal-hero p.lede { font-size: 15.5px; }
  .nlegal-body { padding: 28px 0 56px; }
  .nlegal-article { font-size: 15px; }
  .nlegal-article h2 { font-size: 22px; margin: 28px 0 10px; }
  .nlegal-article h3 { font-size: 16px; }
}
@media (max-width: 480px) {
  .nsub-header__back-text { display: none; }
  .nsub-header__back { padding: 8px 10px; }
  .nlegal-hero { padding: 28px 0 14px; }
  .nlegal-hero h1 { font-size: 24px; }
  .nlegal-hero p.lede { font-size: 14.5px; }
  .nlegal-meta { gap: 14px; font-size: 12.5px; }
  .nlegal-pending { padding: 14px 16px; }
  .nlegal-article h2 { font-size: 20px; }
}
