
  :root{
    --ink:#0e2a52;
    --navy:#123a73;
    --paper:#ffffff;
    --paper-deep:#eef3fa;
    --accent:#c8102e;
    --accent-deep:#9c0c23;
    --blue:#1d4e9c;
    --muted:#5c6b82;
    --line:rgba(14,42,82,.14);
    --display:"Fraunces",Georgia,serif;
    --body:"Newsreader",Georgia,serif;
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    background:var(--paper);color:var(--ink);font-family:var(--body);
    font-size:18px;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden;
  }
  body::before{
    content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.025;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  }
  .wrap{max-width:1180px;margin:0 auto;padding:0 32px;position:relative;z-index:2}

  /* ---------- top bar ---------- */
  header.topbar{
    border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50;
    background:rgba(255,255,255,.92);backdrop-filter:blur(10px);
  }
  /* institutional flag stripe on top */
  .flagstrip{height:4px;background:linear-gradient(90deg,var(--accent) 0 38%,#fff 38% 62%,var(--blue) 62% 100%)}
  .topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:78px}
  .brand{display:flex;align-items:baseline;gap:10px;font-family:var(--display);font-weight:600;font-size:1.4rem;letter-spacing:-.01em;text-decoration:none;color:var(--ink)}
  .brand .full{color:var(--muted);font-weight:400;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase}

  nav.main > ul{display:flex;gap:4px;list-style:none;align-items:center}
  nav.main > ul > li{position:relative}
  nav.main a{
    display:block;color:var(--ink);text-decoration:none;font-size:.85rem;letter-spacing:.04em;
    text-transform:uppercase;padding:10px 8px;border-radius:4px;transition:color .2s,background .2s;white-space:nowrap;
  }
  nav.main > ul > li > a:hover{color:var(--accent)}
  nav.main > ul > li.active > a{color:var(--accent)}
  .has-sub > a::after{content:"›";display:inline-block;transform:rotate(90deg);margin-left:6px;font-size:.9rem;opacity:.6;transition:transform .25s}
  .has-sub:hover > a::after{transform:rotate(90deg) translateX(2px)}

  /* vertical dropdown submenu */
  .submenu{
    position:absolute;top:calc(100% + 10px);left:0;min-width:280px;
    background:#fff;border:1px solid var(--line);border-radius:8px;
    box-shadow:0 18px 48px -18px rgba(14,42,82,.45);
    padding:8px;list-style:none;
    opacity:0;visibility:hidden;transform:translateY(8px);
    transition:opacity .22s ease,transform .22s ease,visibility .22s;
  }
  .submenu::before{content:"";position:absolute;top:-10px;left:0;right:0;height:10px}
  .has-sub:hover .submenu,.has-sub:focus-within .submenu{opacity:1;visibility:visible;transform:translateY(0)}
  .submenu li{border-radius:6px;overflow:hidden}
  .submenu a{
    display:flex;flex-direction:column;gap:2px;padding:12px 16px;text-transform:none;
    letter-spacing:0;font-size:.95rem;border-left:3px solid transparent;transition:all .18s;
  }
  .submenu a:hover{background:var(--paper-deep);border-left-color:var(--accent);color:var(--ink)}
  .submenu a .sm-label{font-family:var(--display);font-weight:500;font-size:1rem}
  .submenu a .sm-desc{font-size:.78rem;color:var(--muted);letter-spacing:.01em}

  /* mobile menu */
  .burger{display:none;background:none;border:1px solid var(--line);border-radius:6px;width:46px;height:42px;cursor:pointer;flex-direction:column;gap:5px;align-items:center;justify-content:center}
  .burger span{width:20px;height:2px;background:var(--ink);transition:.3s}
  @media(max-width:1080px){
    .burger{display:flex}
    nav.main{
      position:fixed;inset:82px 0 auto 0;background:#fff;border-bottom:1px solid var(--line);
      max-height:0;overflow:hidden;transition:max-height .4s ease;box-shadow:0 20px 40px -20px rgba(14,42,82,.4);
    }
    nav.main.open{max-height:80vh;overflow-y:auto}
    nav.main > ul{flex-direction:column;align-items:stretch;gap:0;padding:12px 24px}
    nav.main > ul > li{border-bottom:1px solid var(--line)}
    nav.main a{padding:15px 6px;font-size:.85rem}
    .submenu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;padding:0 0 10px 14px;min-width:0;max-height:0;overflow:hidden;transition:max-height .3s}
    .has-sub.exp .submenu{max-height:600px}
    .has-sub > a::after{margin-left:auto}
  }

  /* ---------- hero ---------- */
  .hero{padding:96px 0 84px;position:relative;border-bottom:1px solid var(--line);background:
    radial-gradient(120% 90% at 85% -10%,rgba(29,78,156,.08),transparent 55%),
    radial-gradient(80% 70% at 5% 110%,rgba(200,16,46,.06),transparent 60%);}
  .kicker{font-size:1.1rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);font-weight:500;margin-bottom:26px;display:flex;align-items:center;gap:14px}
  .kicker::before{content:"";width:42px;height:3px;background:linear-gradient(90deg,var(--accent) 0 50%,var(--blue) 50% 100%)}
  .hero h1{font-family:var(--display);font-weight:500;font-size:clamp(2.8rem,7.5vw,6rem);line-height:.96;letter-spacing:-.028em;max-width:15ch}
  .hero h1 em{font-style:italic;color:var(--accent)}
  .hero .lede{margin-top:34px;max-width:56ch;font-size:1.3rem;line-height:1.6;color:#2a3b54;font-weight:300}
  .hero .lede strong{font-weight:500;color:var(--ink)}
  .cta{margin-top:42px;display:flex;gap:16px;flex-wrap:wrap}
  .btn{font-family:var(--body);font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;padding:15px 30px;border-radius:6px;transition:transform .2s,box-shadow .2s}
  .btn-primary{background:var(--accent);color:#fff;box-shadow:0 10px 26px -12px rgba(200,16,46,.7)}
  .btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 32px -12px rgba(200,16,46,.8)}
  .btn-ghost{border:1px solid var(--ink);color:var(--ink)}
  .btn-ghost:hover{background:var(--ink);color:#fff}

  .reveal{opacity:0;transform:translateY(22px);animation:rise .9s cubic-bezier(.2,.7,.2,1) forwards}
  @keyframes rise{to{opacity:1;transform:none}}
  .d1{animation-delay:.05s}.d2{animation-delay:.18s}.d3{animation-delay:.32s}.d4{animation-delay:.46s}

  /* ---------- pillars ---------- */
  .sec{padding:84px 0;border-bottom:1px solid var(--line)}
  .sec-head{font-family:var(--display);font-weight:500;font-size:clamp(1.9rem,4vw,2.8rem);letter-spacing:-.02em;margin-bottom:8px}
  .sec-sub{color:var(--muted);font-size:.95rem;margin-bottom:50px;font-style:italic}
  .cards{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line)}
  @media(max-width:880px){.cards{grid-template-columns:1fr}}
  .card{padding:40px 34px 46px;border-bottom:1px solid var(--line);transition:background .35s}
  .card:not(:last-child){border-right:1px solid var(--line)}
  @media(max-width:880px){.card:not(:last-child){border-right:none}}
  .card:hover{background:var(--paper-deep)}
  .card .num{font-family:var(--display);font-size:.9rem;color:var(--accent)}
  .card h3{font-family:var(--display);font-weight:600;font-size:1.34rem;line-height:1.15;margin:18px 0 16px;letter-spacing:-.01em}
  .card p{font-size:1rem;color:#34465e}
  .card .more{display:inline-block;margin-top:18px;color:var(--blue);font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;text-decoration:none}
  .card .more:hover{color:var(--accent)}

  /* ---------- media strip ---------- */
  .media{background:var(--ink);color:#fff;padding:84px 0}
  .media .sec-head{color:#fff}
  .media .sec-sub{color:rgba(255,255,255,.55)}
  .mgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
  @media(max-width:880px){.mgrid{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:480px){.mgrid{grid-template-columns:1fr}}
  .mtile{text-decoration:none;color:inherit;display:block;border:1px solid rgba(255,255,255,.18);border-radius:10px;padding:28px 22px;transition:.3s;background:rgba(255,255,255,.02)}
  .mtile:hover{background:rgba(255,255,255,.06);border-color:var(--accent);transform:translateY(-4px)}
  .mtile .mn{font-family:var(--display);font-size:.85rem;color:var(--accent)}
  .mtile h4{font-family:var(--display);font-weight:500;font-size:1.25rem;margin:12px 0 8px;color:#fff}
  .mtile p{font-size:.9rem;color:rgba(255,255,255,.65);line-height:1.5}

  /* ---------- denuncia banner ---------- */
  .banner{padding:0}
  .banner .wrap{padding-top:80px;padding-bottom:80px;display:flex;gap:40px;align-items:center;justify-content:space-between;flex-wrap:wrap}
  .banner h2{font-family:var(--display);font-weight:500;font-size:clamp(1.8rem,4vw,2.6rem);letter-spacing:-.02em;max-width:18ch}
  .banner h2 em{color:var(--accent);font-style:italic}
  .banner p{color:var(--muted);max-width:48ch;margin-top:14px}

  /* ---------- footer ---------- */
  footer{background:var(--paper-deep);border-top:1px solid var(--line);padding:60px 0 40px}
  .fgrid{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;margin-bottom:40px}
  .fcol h5{font-family:var(--display);font-weight:600;font-size:.95rem;margin-bottom:14px;letter-spacing:.02em}
  .fcol a{display:block;color:var(--muted);text-decoration:none;font-size:.9rem;padding:4px 0;transition:color .2s}
  .fcol a:hover{color:var(--accent)}
  .fbrand{max-width:300px}
  .fbrand .brand{font-size:1.3rem;margin-bottom:10px}
  .fbrand .motto{font-family:var(--display);font-style:italic;color:var(--accent);font-size:1rem;margin-top:8px}
  .fbottom{border-top:1px solid var(--line);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}
  .fbottom small{color:var(--muted);font-size:.8rem;letter-spacing:.03em}

/* Logo override */
.iclep-logo { height: 81px !important; width: auto !important; }

/* Logo override */
header.iclep-topbar div.iclep-wrap a.iclep-logo-link img.iclep-logo { height: 81px !important; width: auto !important; max-width: none !important; }
