/* =========================================================
   OIC - DENUNCIAS (ESTÁTICO / LIMPIO)
   Archivo: public/css/oic.denuncias.css
   Scope: .oic-denuncias
========================================================= */

.oic-denuncias{
  /* Tokens */
  --oic-magenta: #b01271;
  --oic-magenta-2: #d14a9a;

  --oic-text: #4b5563;
  --oic-strong: #111827;
  --oic-muted: #6b7280;

  --oic-border: rgba(255,255,255,.25);
  --oic-card-border: rgba(176,18,113,.18);

  --wrap: 1100px;
  --pad: clamp(16px, 2.6vw, 30px);

  --radius-lg: 28px;
  --radius-md: 18px;
  --radius-sm: 12px;

  --shadow-hero: 0 18px 60px rgba(0,0,0,.22);
  --shadow-card: 0 22px 70px rgba(0,0,0,.18);

  --hero-text: rgba(255,255,255,.92);
  --hero-title: #fff;

  /* Fondo */
  background:
    radial-gradient(1200px 900px at 18% 22%, rgba(255,255,255,.14), transparent 55%),
    radial-gradient(900px 700px at 82% 35%, rgba(255,255,255,.10), transparent 55%),
    linear-gradient(180deg, #b01271 0%, #b01271 35%, #b73a88 70%, #c85aa0 100%);
  background-repeat: no-repeat;
  background-size: cover;

  /* IMPORTANT: más aire al final para que el FORM no choque con footer */
  padding-bottom: clamp(70px, 7vw, 130px);

  overflow-x: hidden;
}

/* evita que borders/paddings “sumen” y desborden en responsive */
.oic-denuncias,
.oic-denuncias *{
  box-sizing: border-box;
}

.oic-denuncias .oic-den-wrap{
  max-width: var(--wrap);
  width: min(100%, var(--wrap));
  margin: 0 auto;
  padding: 0 var(--pad);
}

/* =========================================================
   HERO
========================================================= */

.oic-denuncias .oic-den-hero{
  padding-top: clamp(22px, 3vw, 40px);
  padding-bottom: clamp(18px, 3vw, 34px);
  text-align: center;
  color: var(--hero-text);
}

.oic-denuncias .oic-den-hero h1,
.oic-denuncias .oic-den-hero h2{
  color: var(--hero-title);
  text-shadow: 0 2px 14px rgba(0,0,0,.22);
}

.oic-denuncias .oic-den-brand{
  display:flex;
  justify-content:center;
  margin-bottom: clamp(10px, 2vw, 18px);
}

.oic-denuncias .oic-den-logo{
  height: clamp(42px, 4.2vw, 62px);
  width: auto;
  display:block;
  opacity: .96;
  filter: drop-shadow(0 10px 24px rgba(0,0,0,.20));
}

/* Row icon + divider + title */
.oic-denuncias .oic-den-hero-row{
  display:flex;
  align-items:center;
  justify-content:center;
  gap: clamp(14px, 2.2vw, 24px);
  margin: clamp(8px, 1.6vw, 18px) auto;
}

@media (max-width: 640px){
  .oic-denuncias .oic-den-hero-row{
    flex-direction: column;
    gap: 12px;
  }

  .oic-denuncias .oic-den-divider{
    width: clamp(70px, 40vw, 160px);
    height: 6px;
  }
}

.oic-denuncias .oic-den-hero-icon{
  display:flex;
  align-items:center;
  justify-content:center;
}

.oic-denuncias .oic-den-hero-icon img{
  width: clamp(96px, 7.8vw, 134px);
  height: auto;
  display:block;
  object-fit: contain;
  filter: drop-shadow(0 14px 28px rgba(0,0,0,.22));
}

/* Divider */
.oic-denuncias .oic-den-divider{
  width: 6px;
  height: clamp(74px, 6.2vw, 104px);
  background: rgba(255,255,255,.88);
  border-radius: 6px;
  box-shadow: 0 6px 16px rgba(0,0,0,.18);
}

/* Title + CTA */
.oic-denuncias .oic-den-hero-main{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap: 10px;
}

.oic-denuncias .oic-den-title{
  font-weight: 950;
  letter-spacing: .04em;
  margin: 0;
  font-size: clamp(38px, 5.2vw, 62px);
  line-height: .98;
}

/* CTA — fino, sin vibes de hipervínculo */
.oic-denuncias .oic-den-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;

  padding: 12px 26px;
  border-radius: 999px;

  background: rgba(255,255,255,.96);
  color: var(--oic-magenta);

  font-weight: 900;
  letter-spacing: .02em;

  /* mata subrayados de cualquier CSS global */
  text-decoration: none !important;
  text-decoration-thickness: 0 !important;
  text-underline-offset: 0 !important;

  /* mata "líneas" hechas con background/border de otros estilos */
  border: 1px solid rgba(176,18,113,.18);
  background-image: none !important;
  box-shadow: 0 16px 46px rgba(0,0,0,.18);

  -webkit-tap-highlight-color: transparent;
  user-select: none;

  transition: transform .18s ease, box-shadow .18s ease, filter .18s ease, background-color .18s ease, border-color .18s ease;
  will-change: transform;
}

.oic-denuncias .oic-den-cta:hover{
  text-decoration: none !important; /* por si un a:hover global gana */
  transform: translateY(-2px);
  filter: brightness(1.02);
  border-color: rgba(176,18,113,.28);
  box-shadow: 0 20px 58px rgba(0,0,0,.22);
}

/* focus elegante (accesible) */
.oic-denuncias .oic-den-cta:focus,
.oic-denuncias .oic-den-cta:focus-visible{
  outline: none;
  text-decoration: none !important;
  box-shadow:
    0 20px 58px rgba(0,0,0,.20),
    0 0 0 6px rgba(255,255,255,.18),
    0 0 0 10px rgba(176,18,113,.22);
}

/* por si bootstrap le mete underline en :hover a anchors */
.oic-denuncias a.oic-den-cta:hover,
.oic-denuncias a.oic-den-cta:active,
.oic-denuncias a.oic-den-cta:visited{
  text-decoration: none !important;
}

.oic-denuncias .oic-den-h2{
  margin: clamp(18px, 2.8vw, 28px) 0 12px;
  font-weight: 950;
  font-size: clamp(24px, 3.2vw, 34px);
}

.oic-denuncias .oic-den-lead{
  max-width: 960px;
  margin: 0 auto;
  color: var(--hero-text);
  font-size: clamp(14.5px, 1.15vw, 16px);
  line-height: 1.70;
  text-shadow: 0 2px 12px rgba(0,0,0,.18);
}

/* =========================================================
   PANEL BLANCO
========================================================= */

.oic-denuncias .oic-den-panel{
  padding: clamp(14px, 2.4vw, 24px) 0;
}

.oic-denuncias .oic-den-card{
  background: #fff;
  border-radius: var(--radius-lg);
  padding: clamp(18px, 2.8vw, 30px);
  box-shadow: var(--shadow-card);
  border: 1px solid rgba(0,0,0,.04);
}

/* Dos cajas */
.oic-denuncias .oic-den-two{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(12px, 2vw, 20px);
  margin-bottom: clamp(18px, 2.4vw, 28px);
}

@media (max-width: 860px){
  .oic-denuncias .oic-den-two{ grid-template-columns: 1fr; }
}

.oic-denuncias .oic-den-box{
  border: 2px solid rgba(232, 62, 140, .75);
  border-radius: var(--radius-md);
  padding: 18px 18px 16px;
  background: linear-gradient(180deg, rgba(176,18,113,.03), rgba(176,18,113,0));
}

.oic-denuncias .oic-den-box-head{
  display:flex;
  align-items:center;
  gap: 10px;
  margin-bottom: 8px;
}

.oic-denuncias .oic-den-box-badge{
  width: 32px; height: 32px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius: 999px;
  font-weight: 950;
  flex: 0 0 auto;
}

.oic-denuncias .oic-den-box-badge.ok{
  background:#e9f7ef;
  color:#1e7e34;
  border: 1px solid rgba(30,126,52,.25);
}

.oic-denuncias .oic-den-box-badge.no{
  background:#fdecea;
  color:#b02a37;
  border: 1px solid rgba(176,42,55,.25);
}

.oic-denuncias .oic-den-box h3{
  margin: 0;
  font-size: clamp(16px, 1.3vw, 18px);
  font-weight: 950;
  color: var(--oic-magenta);
}

.oic-denuncias .oic-den-box p{
  margin: 0;
  font-size: clamp(13px, 1.05vw, 14.5px);
  line-height: 1.65;
  color: var(--oic-text);
}

/* =========================================================
   REQUISITOS (Animación + tamaño)
========================================================= */

.oic-denuncias .oic-den-h3{
  text-align:center;
  margin: 18px 0 26px;
  font-size: clamp(22px, 2.8vw, 34px);
  font-weight: 950;
  color: var(--oic-magenta);
}

.oic-denuncias .oic-den-reqs{
  display:grid;
  grid-template-columns: repeat(6, 1fr);
  gap: clamp(16px, 2vw, 22px);
  align-items: start;
}

/* breakpoints */
@media (max-width: 1100px){
  .oic-denuncias .oic-den-reqs{ grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 620px){
  .oic-denuncias .oic-den-reqs{ grid-template-columns: repeat(2, 1fr); }
}

.oic-denuncias .oic-den-req{
  text-align: center;
  color: var(--oic-text);
  font-size: clamp(13.5px, 1.1vw, 15.5px);
  line-height: 1.35;
  padding: 10px 8px;
  border-radius: 16px;

  transition: transform .18s ease;
  will-change: transform;

  opacity: 0;
  animation: oicDenPop .45s ease forwards;
}

.oic-denuncias .oic-den-req:nth-child(1){ animation-delay: .02s; }
.oic-denuncias .oic-den-req:nth-child(2){ animation-delay: .06s; }
.oic-denuncias .oic-den-req:nth-child(3){ animation-delay: .10s; }
.oic-denuncias .oic-den-req:nth-child(4){ animation-delay: .14s; }
.oic-denuncias .oic-den-req:nth-child(5){ animation-delay: .18s; }
.oic-denuncias .oic-den-req:nth-child(6){ animation-delay: .22s; }

.oic-denuncias .oic-den-req:hover,
.oic-denuncias .oic-den-req:focus-within{
  transform: translateY(-6px);
}

.oic-denuncias .oic-den-req-ico{
  width: clamp(86px, 6.6vw, 108px);
  height: clamp(86px, 6.6vw, 108px);
  margin: 0 auto 12px;
  border-radius: 999px;

  background: rgba(255,255,255,.98);
  display:flex;
  align-items:center;
  justify-content:center;

  border: 3px solid rgba(232, 62, 140, .82);

  box-shadow:
    0 18px 40px rgba(0,0,0,.10),
    inset 0 0 0 10px rgba(176,18,113,.06);

  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  will-change: transform;
}

.oic-denuncias .oic-den-req-ico img{
  width: clamp(46px, 3.6vw, 60px);
  height: auto;
  display:block;
  object-fit: contain;

  transition: transform .18s ease, filter .18s ease;
  will-change: transform;
}

.oic-denuncias .oic-den-req-txt{
  max-width: 210px;
  margin: 0 auto;
}

.oic-denuncias .oic-den-req:hover .oic-den-req-ico,
.oic-denuncias .oic-den-req:focus-within .oic-den-req-ico{
  transform: translateY(-2px) scale(1.05);
  border-color: rgba(255,255,255,.92);
  box-shadow:
    0 22px 52px rgba(0,0,0,.14),
    0 0 0 8px rgba(255,255,255,.12),
    inset 0 0 0 10px rgba(176,18,113,.08);
}

.oic-denuncias .oic-den-req:hover .oic-den-req-ico img,
.oic-denuncias .oic-den-req:focus-within .oic-den-req-ico img{
  transform: rotate(-3deg) scale(1.06);
  filter: drop-shadow(0 12px 18px rgba(0,0,0,.20));
}

@keyframes oicDenPop {
  0%   { transform: translateY(10px) scale(.96); opacity: 0; }
  60%  { transform: translateY(-2px) scale(1.03); opacity: 1; }
  100% { transform: translateY(0) scale(1); opacity: 1; }
}

@media (prefers-reduced-motion: reduce){
  .oic-denuncias .oic-den-req,
  .oic-denuncias .oic-den-req-ico,
  .oic-denuncias .oic-den-req-ico img{
    animation: none !important;
    transition: none !important;
    opacity: 1 !important;
  }
}

/* =========================================================
   IFRAME (si luego embebes formulario)
========================================================= */

.oic-denuncias .oic-den-embed{
  margin-top: 18px;
  border-top: 1px solid #e5e7eb;
  padding-top: 18px;
}

.oic-denuncias .oic-den-embed iframe{
  width: 100%;
  height: min(75vh, 900px);
  border: 0;
  border-radius: 12px;
  background: #fff;
}

/* =========================================================
   FORM PLACEHOLDER — (ESTE ES EL ÚNICO FORM QUE QUEDA)
   Fix: padding-bottom + margin-bottom para no pegar con footer
========================================================= */

.oic-denuncias .oic-den-form{
  padding: clamp(26px, 3.2vw, 54px) 0 clamp(42px, 6vw, 110px);
}

.oic-denuncias .oic-den-form-placeholder{
  max-width: 980px;
  margin: 0 auto;
  border-radius: 18px;
  padding: clamp(18px, 2.6vw, 30px);

  /* NO se “corta” con footer */
  margin-bottom: clamp(18px, 3vw, 50px);

  border: 2px dashed rgba(255,255,255,.75);
  background: rgba(255,255,255,.10);
  box-shadow: 0 18px 55px rgba(0,0,0,.16);

  text-align: center;
  color: rgba(255,255,255,.92);
}

/* blur solo si hay soporte (evita glitches) */
@supports ((-webkit-backdrop-filter: blur(2px)) or (backdrop-filter: blur(2px))){
  .oic-denuncias .oic-den-form-placeholder{
    -webkit-backdrop-filter: blur(2px);
    backdrop-filter: blur(2px);
  }
}

.oic-denuncias .oic-den-form-ph-badge{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 12px;
  border-radius: 999px;
  font-weight: 900;
  letter-spacing: .08em;
  font-size: 11px;

  background: rgba(255,255,255,.95);
  color: var(--oic-magenta);
}

.oic-denuncias .oic-den-form-ph-title{
  margin: 12px 0 8px;
  font-weight: 950;
  font-size: clamp(18px, 2.1vw, 24px);
  color: #fff;
  text-shadow: 0 2px 14px rgba(0,0,0,.22);
}

.oic-denuncias .oic-den-form-ph-text{
  margin: 0 auto;
  max-width: 760px;
  font-size: clamp(13.5px, 1.1vw, 15px);
  line-height: 1.6;
  color: rgba(255,255,255,.90);
}

.oic-denuncias .oic-den-form-ph-actions{
  display: flex;
  justify-content: center;
  margin-top: 14px;
}

/* =========================================================
   DENUNCIAS — FULL BLEED QUIRÚRGICO (gana aunque otros CSS carguen después)
========================================================= */

@supports selector(body:has(.oic-denuncias)){

  body.oic-skin#top:has(.oic-denuncias){
    overflow-x: hidden !important;
    background: transparent !important;
  }

  body.oic-skin#top:has(.oic-denuncias) .oic-shell.oic-shell{
    background: transparent !important;
  }

  body.oic-skin#top:has(.oic-denuncias) .oic-shell > main.main-content,
  body.oic-skin#top:has(.oic-denuncias) .oic-shell > .main-content,
  body.oic-skin#top:has(.oic-denuncias) .oic-shell > main.main-content.main-content{
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    background: transparent !important;
  }

  body.oic-skin#top:has(.oic-denuncias) main.main-content .row:has(.oic-denuncias){
    --bs-gutter-x: 0 !important;
    --bs-gutter-y: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  body.oic-skin#top:has(.oic-denuncias) main.main-content [class*="col-"]:has(.oic-denuncias),
  body.oic-skin#top:has(.oic-denuncias) main.main-content .col-12:has(.oic-denuncias){
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  body.oic-skin#top:has(.oic-denuncias) main.main-content article:has(.oic-denuncias),
  body.oic-skin#top:has(.oic-denuncias) main.main-content .cms-content:has(.oic-denuncias){
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
  }

  body.oic-skin#top:has(.oic-denuncias) main.main-content .oic-denuncias{
    min-height: 100vh !important;
    min-height: 100svh !important;
    width: 100% !important;
    margin: 0 !important;
    display: flow-root !important;
    isolation: isolate !important;

    padding-top: max(env(safe-area-inset-top), 0px);
    padding-bottom: max(env(safe-area-inset-bottom), 0px);
  }

  body.oic-skin#top:has(.oic-denuncias) footer.oic-footer.mt-5{
    margin-top: 0 !important;
  }

  body.oic-skin#top:has(.oic-denuncias) main.main-content .oic-denuncias > section:first-child{
    margin-top: 0 !important;
  }
}

@supports not selector(body:has(.oic-denuncias)){
  .oic-denuncias{
    min-height: 100vh;
    min-height: 100svh;
    display: flow-root;
  }
}

/* =========================================================
   DENUNCIAS — BACKDROP (líneas + gradiente) detrás del header
   - No toca el nav (sticky) ni su funcionalidad
   - No afecta footer
   - Solo se activa en la página que contiene .oic-denuncias
========================================================= */

@supports selector(body:has(.oic-denuncias)){

  /* Crea el lienzo detrás de todo */
  body.oic-skin#top:has(.oic-denuncias){
    position: relative; /* referencia por si el layout trae cosas raras */
    isolation: isolate; /* evita mezclas de z-index externas */
  }

  body.oic-skin#top:has(.oic-denuncias)::before{
    content:"";
    position: fixed;
    inset: 0;
    z-index: 0;              /* atrás del nav y del contenido */
    pointer-events: none;    /* no bloquea clicks */
    opacity: .9;

    /* “líneas” + glow magenta + degradado */
    /* Fondo sólido (magenta limpio) */
    background: var(--oic-magenta);

    /* suavecito */
    filter: saturate(1.05) contrast(1.02);
  }

  /* Asegura que nav + contenido queden arriba del backdrop */
  body.oic-skin#top:has(.oic-denuncias) .oic-navwrap{
    position: sticky;
    z-index: 50;
  }

  body.oic-skin#top:has(.oic-denuncias) .oic-shell{
    position: relative;
    z-index: 1;
  }
}

/* Fallback sin :has(): no aplicamos backdrop global para no afectar otras páginas */