/* ================================================================
   PORTAL MUNICIPAL CHIQUIMULILLA - Frontend
   ================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@300;400;600;700;800&family=Inter:wght@400;500;600&display=swap');

:root {
    --c1: #1a56db;
    --c2: #059669;
    --txt: #1e293b;
    --muted: #64748b;
    --bg: #f0f4f8;
    --border: #e2e8f0;
    --sh: 0 4px 24px rgba(0,0,0,.07);
    --r: 14px;
    --r2: 20px;
}
*  { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { font-family:'Inter',sans-serif; color:var(--txt); overflow-x:hidden; }

/* ── TOPBAR ── */
.portal-topbar {
    background: var(--c1);
    padding: 7px 0;
    font-size: .78rem;
    color: rgba(255,255,255,.8);
}
.portal-topbar .container { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px; }
.topbar-left, .topbar-right { display:flex; align-items:center; gap:16px; }
.topbar-left i, .topbar-right i { margin-right:4px; }
.topbar-right a { color:rgba(255,255,255,.8); text-decoration:none; transition:.2s; }
.topbar-right a:hover { color:#fff; }
.topbar-admin {
    background:rgba(255,255,255,.15); border:1px solid rgba(255,255,255,.25);
    padding:3px 10px; border-radius:100px; font-weight:600;
}

/* ── NAVBAR ── */
.portal-nav {
    background:#fff;
    box-shadow: 0 2px 12px rgba(0,0,0,.08);
    position: sticky; top:0; z-index:900;
    padding: 10px 0;
    transition: box-shadow .3s;
}
.portal-nav.scrolled { box-shadow: 0 4px 20px rgba(0,0,0,.15); }
.portal-nav .container { display:flex; align-items:center; gap:24px; }
.portal-brand { display:flex; align-items:center; gap:12px; text-decoration:none; flex-shrink:0; }
.brand-logo   { height:48px; }
.brand-icon   { width:48px; height:48px; background:var(--c1); color:#fff; border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:1.4rem; }
.brand-name   { font-family:'Sora',sans-serif; font-weight:800; color:var(--txt); font-size:.95rem; display:block; line-height:1.2; }
.brand-sub    { font-size:.72rem; color:var(--muted); display:block; }
.portal-nav-links { display:flex; align-items:center; gap:4px; margin-left:auto; flex-wrap:wrap; }
.nav-item {
    font-family:'Sora',sans-serif; font-weight:600; font-size:.85rem;
    color:var(--muted); text-decoration:none; padding:7px 12px;
    border-radius:9px; transition:.2s; white-space:nowrap;
}
.nav-item:hover, .nav-item.active { color:var(--c1); background:rgba(26,86,219,.07); }
.nav-cta { background:var(--c1); color:#fff !important; }
.nav-cta:hover { background:var(--c1); opacity:.9; }
.nav-dropdown { position:relative; }
.nav-dropdown-menu {
    position:absolute; top:calc(100%+6px); left:0;
    background:#fff; border-radius:var(--r); border:1px solid var(--border);
    box-shadow:0 8px 32px rgba(0,0,0,.12); min-width:220px;
    padding:8px; z-index:999;
    opacity:0; visibility:hidden; transform:translateY(-8px);
    transition:.2s;
}
.nav-dropdown:hover .nav-dropdown-menu { opacity:1; visibility:visible; transform:translateY(0); }
.nav-dropdown-menu a { display:flex; align-items:center; gap:9px; padding:9px 12px; color:var(--txt); text-decoration:none; border-radius:8px; font-size:.87rem; transition:.15s; }
.nav-dropdown-menu a:hover { background:var(--bg); color:var(--c1); }
.nav-toggler { display:none; background:none; border:1.5px solid var(--border); border-radius:9px; padding:7px 10px; cursor:pointer; font-size:1.2rem; margin-left:auto; }

/* ── HERO SLIDER ── */
.portal-hero { position:relative; }
.hero-slider  { position:relative; height:600px; overflow:hidden; }
.hero-slide   {
    position:absolute; inset:0;
    background:linear-gradient(145deg,#0c2461,#1a56db);
    background-size:cover; background-position:center;
    opacity:0; transition:opacity .7s ease;
    display:flex; flex-direction:column; justify-content:center;
}
.hero-slide.active { opacity:1; z-index:1; }
.hero-slide-default { background:linear-gradient(145deg,#0c2461 0%,#1a56db 60%,#2d8cff 100%); position:relative; min-height:560px; display:flex; flex-direction:column; justify-content:center; }
.hero-overlay { position:absolute; inset:0; background:linear-gradient(to right,rgba(0,0,0,.65) 0%,rgba(0,0,0,.25) 60%,transparent 100%); }
.hero-content { position:relative; z-index:2; padding:60px; max-width:720px; color:#fff; }
.hero-badge { display:inline-flex; align-items:center; gap:6px; background:rgba(255,255,255,.15); border:1px solid rgba(255,255,255,.25); padding:5px 14px; border-radius:100px; font-size:.78rem; font-weight:600; letter-spacing:.05em; text-transform:uppercase; margin-bottom:20px; }
.hero-content h1 { font-family:'Sora',sans-serif; font-size:clamp(2rem,5vw,3.8rem); font-weight:800; line-height:1.1; margin-bottom:16px; letter-spacing:-.02em; text-shadow:0 2px 8px rgba(0,0,0,.3); }
.hero-content p  { font-size:1.05rem; color:rgba(255,255,255,.85); line-height:1.7; margin-bottom:28px; max-width:520px; }
.hero-btns  { display:flex; flex-wrap:wrap; gap:12px; }
.hero-btn-primary { display:inline-flex; align-items:center; gap:8px; background:var(--c1); color:#fff; font-family:'Sora',sans-serif; font-weight:700; padding:14px 28px; border-radius:12px; text-decoration:none; font-size:.95rem; transition:.25s; box-shadow:0 4px 16px rgba(0,0,0,.2); }
.hero-btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,0,0,.3); color:#fff; text-decoration:none; }
.hero-btn-ghost { display:inline-flex; align-items:center; gap:8px; color:#fff; font-family:'Sora',sans-serif; font-weight:600; padding:13px 24px; border-radius:12px; text-decoration:none; font-size:.95rem; border:1.5px solid rgba(255,255,255,.4); transition:.25s; }
.hero-btn-ghost:hover { background:rgba(255,255,255,.15); color:#fff; text-decoration:none; }

/* Slider controls */
.hero-prev, .hero-next { position:absolute; top:50%; transform:translateY(-50%); z-index:5; background:rgba(255,255,255,.15); backdrop-filter:blur(8px); border:1px solid rgba(255,255,255,.3); color:#fff; width:48px; height:48px; border-radius:50%; font-size:1.2rem; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:.2s; }
.hero-prev { left:20px; } .hero-next { right:20px; }
.hero-prev:hover, .hero-next:hover { background:rgba(255,255,255,.3); }
.hero-dots { position:absolute; bottom:20px; left:50%; transform:translateX(-50%); z-index:5; display:flex; gap:8px; }
.hero-dot { width:8px; height:8px; border-radius:50%; background:rgba(255,255,255,.4); border:none; cursor:pointer; transition:.3s; }
.hero-dot.active { background:#fff; width:24px; border-radius:100px; }

/* Quick services */
.hero-quick { background:var(--c1); display:flex; justify-content:center; flex-wrap:wrap; }
.quick-item { display:flex; flex-direction:column; align-items:center; gap:6px; padding:18px 32px; color:rgba(255,255,255,.8); text-decoration:none; font-family:'Sora',sans-serif; font-size:.78rem; font-weight:600; transition:.2s; border-right:1px solid rgba(255,255,255,.1); letter-spacing:.03em; text-transform:uppercase; }
.quick-item:last-child { border-right:none; }
.quick-item i { font-size:1.4rem; }
.quick-item:hover { background:rgba(255,255,255,.12); color:#fff; }

/* ── SECTIONS ── */
.portal-section     { padding:80px 0; background:#fff; }
.portal-section-alt { padding:80px 0; background:var(--bg); }
.section-header { display:flex; align-items:flex-start; justify-content:space-between; margin-bottom:48px; flex-wrap:wrap; gap:16px; }
.section-eyebrow { font-family:'Sora',sans-serif; font-size:.75rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--c1); margin-bottom:6px; }
.section-title { font-family:'Sora',sans-serif; font-size:clamp(1.7rem,3vw,2.4rem); font-weight:800; color:var(--txt); letter-spacing:-.02em; line-height:1.15; }
.section-link { display:inline-flex; align-items:center; gap:6px; color:var(--c1); font-family:'Sora',sans-serif; font-weight:600; font-size:.88rem; text-decoration:none; padding:8px 16px; border:1.5px solid var(--c1); border-radius:9px; transition:.2s; white-space:nowrap; margin-top:8px; }
.section-link:hover { background:var(--c1); color:#fff; text-decoration:none; }

/* ── NOTICIAS ── */
.noticias-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.noticia-featured { grid-column:span 1; }
.noticia-card { background:#fff; border-radius:var(--r2); overflow:hidden; box-shadow:var(--sh); border:1px solid var(--border); transition:.3s; }
.noticia-card:hover { transform:translateY(-5px); box-shadow:0 12px 36px rgba(0,0,0,.1); }
.noticia-img { height:200px; background:linear-gradient(135deg,#0c2461,#1a56db); background-size:cover; background-position:center; position:relative; }
.noticia-img-nophoto { background:linear-gradient(135deg,var(--c1),var(--c2)); }
.noticia-badge-dest { position:absolute; top:12px; left:12px; background:#fbbf24; color:#78350f; padding:3px 10px; border-radius:100px; font-size:.72rem; font-weight:700; }
.noticia-cat { position:absolute; bottom:12px; left:12px; background:rgba(0,0,0,.6); color:#fff; padding:3px 10px; border-radius:100px; font-size:.72rem; font-weight:600; }
.noticia-body { padding:20px; }
.noticia-body h3 { font-family:'Sora',sans-serif; font-size:1rem; font-weight:700; margin-bottom:8px; line-height:1.35; }
.noticia-body h3 a { color:var(--txt); text-decoration:none; }
.noticia-body h3 a:hover { color:var(--c1); }
.noticia-body p { font-size:.84rem; color:var(--muted); line-height:1.6; margin-bottom:14px; }
.noticia-meta { display:flex; gap:16px; font-size:.76rem; color:var(--muted); }
.noticia-meta i { margin-right:4px; }

/* ── PROYECTOS ── */
.proyectos-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.proyecto-card { background:#fff; border-radius:var(--r2); overflow:hidden; box-shadow:var(--sh); border:1px solid var(--border); transition:.3s; }
.proyecto-card:hover { transform:translateY(-4px); box-shadow:0 12px 36px rgba(0,0,0,.1); }
.proyecto-img { height:180px; background:linear-gradient(135deg,#0c2461,#1a56db); background-size:cover; background-position:center; position:relative; }
.proyecto-estado { position:absolute; top:12px; right:12px; padding:4px 12px; border-radius:100px; font-size:.72rem; font-weight:700; }
.estado-en_ejecucion { background:#dcfce7; color:#15803d; }
.estado-completado   { background:#e0f2fe; color:#0369a1; }
.estado-planificado  { background:#fef9c3; color:#854d0e; }
.estado-suspendido   { background:#fef2f2; color:#dc2626; }
.proyecto-body { padding:20px; }
.proyecto-body h3 { font-family:'Sora',sans-serif; font-size:.95rem; font-weight:700; margin-bottom:8px; }
.proyecto-body p  { font-size:.83rem; color:var(--muted); line-height:1.6; }
.proyecto-avance  { margin-top:12px; }
.avance-bar { background:var(--border); border-radius:100px; height:6px; margin-bottom:4px; }
.avance-fill { background:linear-gradient(90deg,var(--c1),var(--c2)); height:6px; border-radius:100px; transition:width .6s; }
.proyecto-avance span { font-size:.75rem; color:var(--muted); }
.proyecto-loc { font-size:.78rem; color:var(--muted); margin-top:8px; }
.proyecto-loc i { margin-right:4px; }

/* ── REDES / FB / EVENTOS ── */
.redes-grid { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start; }
.fb-section h2, .eventos-section h2 { font-family:'Sora',sans-serif; font-size:2rem; font-weight:800; color:var(--txt); margin-bottom:24px; }
.fb-feed { display:flex; flex-direction:column; gap:12px; margin-bottom:16px; }
.fb-post { display:flex; flex-direction:column; gap:8px; background:#fff; border-radius:var(--r); padding:16px; text-decoration:none; color:var(--txt); border:1px solid var(--border); transition:.2s; }
.fb-post:hover { border-color:#1877f2; box-shadow:0 4px 16px rgba(24,119,242,.1); }
.fb-post-img  { width:100%; height:160px; object-fit:cover; border-radius:8px; }
.fb-post-text { font-size:.87rem; color:var(--txt); line-height:1.6; }
.fb-post-date { font-size:.75rem; color:var(--muted); }
.fb-follow { display:inline-flex; align-items:center; gap:8px; background:#1877f2; color:#fff; padding:11px 20px; border-radius:10px; text-decoration:none; font-weight:600; font-size:.88rem; transition:.2s; }
.fb-follow:hover { background:#1558c0; color:#fff; }
.redes-cards { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; margin:24px 0; }
.red-card { display:flex; flex-direction:column; align-items:center; gap:8px; padding:24px; border-radius:var(--r2); text-decoration:none; font-family:'Sora',sans-serif; font-weight:700; font-size:.88rem; transition:.3s; }
.red-card i { font-size:2rem; }
.red-card:hover { transform:translateY(-3px); }
.red-fb { background:#e7f0fd; color:#1877f2; } .red-fb:hover { background:#1877f2; color:#fff; }
.red-ig { background:#fce4ec; color:#e91e63; } .red-ig:hover { background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); color:#fff; }
.red-yt { background:#fce4e4; color:#ff0000; } .red-yt:hover { background:#ff0000; color:#fff; }
.red-wa { background:#e4f7ea; color:#25d366; } .red-wa:hover { background:#25d366; color:#fff; }
.eventos-list { display:flex; flex-direction:column; gap:16px; }
.evento-item { display:flex; gap:16px; align-items:flex-start; background:#fff; border-radius:var(--r); padding:16px; border:1px solid var(--border); transition:.2s; }
.evento-item:hover { border-color:var(--c1); box-shadow:0 4px 16px rgba(26,86,219,.08); }
.evento-fecha { text-align:center; background:var(--c1); color:#fff; border-radius:10px; padding:8px 12px; flex-shrink:0; min-width:52px; }
.ev-dia { font-family:'Sora',sans-serif; font-size:1.4rem; font-weight:800; display:block; line-height:1; }
.ev-mes { font-size:.65rem; font-weight:700; letter-spacing:.05em; }
.evento-info h4 { font-family:'Sora',sans-serif; font-size:.9rem; font-weight:700; margin-bottom:4px; }
.evento-info p  { font-size:.8rem; color:var(--muted); margin:2px 0; }
.evento-info i  { margin-right:4px; }

/* ── DEPENDENCIAS ── */
.dep-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.dep-card { background:#fff; border-radius:var(--r2); padding:24px 18px; text-align:center; border:1.5px solid var(--border); transition:.3s; position:relative; overflow:hidden; }
.dep-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--dep-color,var(--c1)); }
.dep-card:hover { transform:translateY(-4px); box-shadow:0 8px 24px rgba(0,0,0,.08); border-color:var(--dep-color,var(--c1)); }
.dep-icon { width:52px; height:52px; border-radius:14px; background:var(--dep-color,var(--c1)); color:#fff; display:flex; align-items:center; justify-content:center; font-size:1.4rem; margin:0 auto 12px; }
.dep-card h4 { font-family:'Sora',sans-serif; font-size:.87rem; font-weight:700; margin-bottom:8px; line-height:1.3; }
.dep-card p  { font-size:.76rem; color:var(--muted); margin:3px 0; }

/* ── MAPA ── */
.mapa-wrap { border-radius:var(--r2); overflow:hidden; box-shadow:var(--sh); }

/* ── FOOTER ── */
.portal-footer { background:#0f172a; padding:64px 0 0; }
.footer-grid { display:grid; grid-template-columns:1.5fr 1fr 1fr 1.5fr; gap:48px; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,.08); }
.footer-brand .footer-logo { height:60px; margin-bottom:16px; }
.footer-brand h3 { font-family:'Sora',sans-serif; font-weight:700; color:#fff; font-size:1rem; margin-bottom:8px; }
.footer-brand p  { color:rgba(255,255,255,.5); font-size:.85rem; line-height:1.6; margin-bottom:16px; }
.footer-social { display:flex; gap:10px; flex-wrap:wrap; }
.footer-social a { width:36px; height:36px; background:rgba(255,255,255,.08); color:rgba(255,255,255,.6); border-radius:9px; display:flex; align-items:center; justify-content:center; font-size:1.05rem; text-decoration:none; transition:.2s; }
.footer-social a:hover { background:var(--c1); color:#fff; }
.footer-links h4, .footer-contacto h4 { font-family:'Sora',sans-serif; font-weight:700; color:#fff; font-size:.88rem; margin-bottom:16px; text-transform:uppercase; letter-spacing:.05em; }
.footer-links a { display:block; color:rgba(255,255,255,.5); text-decoration:none; font-size:.85rem; margin-bottom:10px; transition:.2s; }
.footer-links a:hover { color:#fff; padding-left:4px; }
.footer-contacto p { font-size:.84rem; color:rgba(255,255,255,.5); margin-bottom:8px; }
.footer-contacto i { margin-right:6px; color:var(--c1); }
.footer-cta { display:inline-flex; align-items:center; gap:8px; background:var(--c1); color:#fff; padding:10px 20px; border-radius:10px; text-decoration:none; font-weight:600; font-size:.85rem; margin-top:8px; transition:.2s; }
.footer-cta:hover { opacity:.9; color:#fff; }
.footer-bottom { display:flex; justify-content:space-between; flex-wrap:wrap; gap:8px; padding:20px 0; }
.footer-bottom p { font-size:.78rem; color:rgba(255,255,255,.3); }

/* ── WhatsApp Flotante ── */
.wa-float { position:fixed; bottom:28px; right:28px; width:56px; height:56px; background:#25d366; color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.6rem; text-decoration:none; z-index:999; box-shadow:0 4px 20px rgba(37,211,102,.4); transition:.3s; animation:wa-pulse 2s infinite; }
.wa-float:hover { transform:scale(1.1); color:#fff; box-shadow:0 6px 28px rgba(37,211,102,.5); }
@keyframes wa-pulse { 0%,100%{box-shadow:0 4px 20px rgba(37,211,102,.4)}50%{box-shadow:0 4px 28px rgba(37,211,102,.6),0 0 0 8px rgba(37,211,102,.1)} }

/* ── RESPONSIVE ── */
@media(max-width:1100px){
    .dep-grid { grid-template-columns:repeat(2,1fr); }
    .footer-grid { grid-template-columns:1fr 1fr; }
}
@media(max-width:900px){
    .noticias-grid  { grid-template-columns:repeat(2,1fr); }
    .proyectos-grid { grid-template-columns:repeat(2,1fr); }
    .redes-grid     { grid-template-columns:1fr; }
    .nav-toggler    { display:block; }
    .portal-nav-links { display:none; flex-direction:column; position:absolute; top:100%; left:0; right:0; background:#fff; padding:16px; box-shadow:0 8px 24px rgba(0,0,0,.1); gap:4px; }
    .portal-nav-links.open { display:flex; }
    .portal-nav { position:relative; }
    .nav-dropdown-menu { position:static; box-shadow:none; border:none; padding-left:16px; }
    .hero-slider { height:400px; }
    .hero-content { padding:32px; }
    .quick-item { padding:14px 18px; font-size:.72rem; }
}
@media(max-width:600px){
    .noticias-grid  { grid-template-columns:1fr; }
    .proyectos-grid { grid-template-columns:1fr; }
    .dep-grid       { grid-template-columns:repeat(2,1fr); }
    .footer-grid    { grid-template-columns:1fr; gap:32px; }
    .portal-section, .portal-section-alt { padding:56px 0; }
    .hero-content h1 { font-size:2rem; }
    .hero-quick { display:grid; grid-template-columns:repeat(3,1fr); }
    .quick-item { border-right:none; border-bottom:1px solid rgba(255,255,255,.1); }
}

/* ═══════════════════════════════════════
   PÁGINAS INTERNAS
   ═══════════════════════════════════════ */

/* PAGE HERO */
.page-hero{background:linear-gradient(135deg,#0c2461 0%,var(--c1) 100%);padding:56px 0;color:#fff}
.page-hero-green{background:linear-gradient(135deg,#065f46 0%,var(--c2) 100%)}
.page-hero-eyebrow{font-size:.82rem;color:rgba(255,255,255,.6);margin-bottom:12px}
.page-hero-eyebrow a{color:rgba(255,255,255,.8);text-decoration:none}
.page-hero-eyebrow i{font-size:.7rem;margin:0 6px}
.page-hero h1{font-family:'Sora',sans-serif;font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;margin-bottom:12px}
.page-hero p{color:rgba(255,255,255,.75);font-size:1rem;max-width:520px}

/* NOTICIAS LISTA */
.noticias-lista{display:flex;flex-direction:column;gap:24px}
.noticia-item{display:flex;gap:20px;background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.06);border:1px solid #e2e8f0;transition:.3s}
.noticia-item:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(0,0,0,.1)}
.noticia-item-img{width:200px;min-height:140px;flex-shrink:0;background:linear-gradient(135deg,#0c2461,var(--c1));background-size:cover;background-position:center;position:relative}
.noticia-item-noimg{display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.4);font-size:2rem}
.noticia-item-dest{position:absolute;top:8px;left:8px;background:#fbbf24;color:#78350f;padding:2px 8px;border-radius:100px;font-size:.7rem;font-weight:700}
.noticia-item-body{flex:1;padding:20px 20px 20px 0;display:flex;flex-direction:column;justify-content:center;gap:8px}
.noticia-item-meta{display:flex;flex-wrap:wrap;gap:12px;align-items:center;font-size:.78rem;color:#64748b}
.noticia-item-body h2{font-family:'Sora',sans-serif;font-size:1.1rem;font-weight:700;margin:0;line-height:1.35}
.noticia-item-body h2 a{color:#1e293b;text-decoration:none}
.noticia-item-body h2 a:hover{color:var(--c1)}
.noticia-item-body p{color:#64748b;font-size:.87rem;line-height:1.6;margin:0}
.noticia-item-link{font-family:'Sora',sans-serif;font-size:.83rem;font-weight:600;color:var(--c1);text-decoration:none;display:inline-flex;align-items:center;gap:5px;margin-top:4px;transition:gap .2s}
.noticia-item-link:hover{gap:9px}

/* CATEGORÍAS */
.cat-badge{display:inline-block;background:rgba(26,86,219,.1);color:var(--c1);padding:3px 10px;border-radius:100px;font-size:.76rem;font-weight:600;text-decoration:none;transition:.2s}
.cat-badge:hover,.cat-badge.active{background:var(--c1);color:#fff}

/* SIDEBAR */
.sidebar-widget{background:#fff;border-radius:16px;padding:20px;margin-bottom:20px;box-shadow:0 2px 12px rgba(0,0,0,.06);border:1px solid #e2e8f0}
.sidebar-widget h3{font-family:'Sora',sans-serif;font-size:.95rem;font-weight:700;color:#1e293b;margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid #e2e8f0}
.cat-list{display:flex;flex-wrap:wrap;gap:8px}
.cat-item{display:inline-block;padding:5px 12px;border-radius:100px;font-size:.8rem;font-weight:600;text-decoration:none;color:var(--cat-color,#1a56db);background:rgba(26,86,219,.08);border:1px solid rgba(26,86,219,.15);transition:.2s}
.cat-item:hover,.cat-item.active{background:var(--cat-color,#1a56db);color:#fff}
.sidebar-noticia{display:flex;gap:10px;align-items:flex-start;padding:10px 0;border-bottom:1px solid #e2e8f0;text-decoration:none;color:#1e293b;transition:.2s}
.sidebar-noticia:last-child{border-bottom:none}
.sidebar-noticia:hover{color:var(--c1)}
.sidebar-noticia-img{width:60px;height:48px;border-radius:8px;background:#f0f4f8 center/cover;flex-shrink:0}
.sidebar-noticia p{font-size:.82rem;font-weight:600;line-height:1.4;margin:0 0 4px}
.sidebar-noticia small{font-size:.74rem;color:#64748b}

/* PAGINACIÓN */
.paginacion{display:flex;justify-content:center;gap:6px;margin-top:32px;flex-wrap:wrap}
.pag-btn{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;text-decoration:none;font-size:.88rem;font-weight:600;color:#64748b;background:#fff;border:1.5px solid #e2e8f0;transition:.2s}
.pag-btn:hover,.pag-btn.active{background:var(--c1);color:#fff;border-color:var(--c1);text-decoration:none}

/* NOTICIA INDIVIDUAL */
.noticia-breadcrumb{font-size:.83rem;color:#64748b;margin-bottom:20px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.noticia-breadcrumb a{color:var(--c1);text-decoration:none}
.noticia-single{background:#fff;border-radius:20px;padding:36px;box-shadow:0 2px 16px rgba(0,0,0,.06);border:1px solid #e2e8f0}
.noticia-single-meta{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:16px;font-size:.8rem;color:#64748b}
.noticia-single-title{font-family:'Sora',sans-serif;font-size:clamp(1.6rem,3.5vw,2.2rem);font-weight:800;color:#1e293b;line-height:1.2;margin-bottom:16px}
.noticia-single-resumen{font-size:1.05rem;color:#475569;font-style:italic;border-left:3px solid var(--c1);padding-left:16px;margin-bottom:24px;line-height:1.7}
.noticia-single-img{margin-bottom:28px;border-radius:14px;overflow:hidden}
.noticia-single-img img{width:100%;max-height:480px;object-fit:cover}
.noticia-single-contenido{font-size:.97rem;line-height:1.8;color:#334155}
.noticia-single-contenido h2,.noticia-single-contenido h3{font-family:'Sora',sans-serif;font-weight:700;color:#1e293b;margin:24px 0 12px}
.noticia-single-contenido img{max-width:100%;border-radius:10px;margin:12px 0}
.noticia-single-contenido p{margin-bottom:16px}
.noticia-share{margin-top:28px;padding-top:20px;border-top:1px solid #e2e8f0;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.noticia-share span{font-family:'Sora',sans-serif;font-size:.82rem;font-weight:700;color:#64748b}
.share-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:9px;text-decoration:none;font-size:.82rem;font-weight:600;cursor:pointer;border:none;transition:.2s}
.share-fb{background:#e7f0fd;color:#1877f2}.share-fb:hover{background:#1877f2;color:#fff}
.share-tw{background:#f0f0f0;color:#0f172a}.share-tw:hover{background:#0f172a;color:#fff}
.share-wa{background:#e4f7ea;color:#25d366}.share-wa:hover{background:#25d366;color:#fff}
.share-copy{background:#f1f5f9;color:#475569}.share-copy:hover{background:#475569;color:#fff}

/* PROYECTOS */
.estado-filtros{display:flex;flex-wrap:wrap;gap:10px}
.estado-btn{padding:8px 18px;border-radius:100px;font-size:.85rem;font-weight:600;text-decoration:none;color:#64748b;background:#f1f5f9;border:1.5px solid #e2e8f0;transition:.2s}
.estado-btn:hover{color:var(--c1);border-color:var(--c1)}
.estado-btn.active{background:var(--c1);color:#fff;border-color:var(--c1)}
.proyecto-card-full{background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.07);border:1px solid #e2e8f0;height:100%;transition:.3s}
.proyecto-card-full:hover{transform:translateY(-4px);box-shadow:0 10px 28px rgba(0,0,0,.1)}
.proyecto-full-img{height:200px;background:linear-gradient(135deg,#0c2461,var(--c1));background-size:cover;background-position:center;position:relative}
.proyecto-estado-badge{position:absolute;top:12px;right:12px;padding:4px 12px;border-radius:100px;font-size:.74rem;font-weight:700}
.proyecto-full-body{padding:20px}
.proyecto-full-body h3{font-family:'Sora',sans-serif;font-size:1rem;font-weight:700;margin:8px 0;line-height:1.3}
.proyecto-full-body p{font-size:.84rem;color:#64748b;line-height:1.6;margin-bottom:14px}
.avance-wrap{margin:12px 0}
.avance-info{display:flex;justify-content:space-between;font-size:.78rem;font-weight:600;color:#64748b;margin-bottom:6px}
.avance-bar-full{background:#e2e8f0;border-radius:100px;height:8px}
.proyecto-full-details{display:flex;flex-direction:column;gap:5px;margin-top:12px}
.proyecto-full-details span{font-size:.78rem;color:#64748b}
.proyecto-full-details i{margin-right:5px;color:var(--c1)}

/* DIRECTORIO */
.dir-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.dir-card{background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.07);border:1px solid #e2e8f0;transition:.3s}
.dir-card:hover{transform:translateY(-4px);box-shadow:0 10px 28px rgba(0,0,0,.1)}
.dir-card-header{padding:28px;text-align:center}
.dir-card-header i{font-size:2.5rem;color:#fff}
.dir-card-body{padding:20px}
.dir-card-body h3{font-family:'Sora',sans-serif;font-size:1rem;font-weight:700;color:#1e293b;margin-bottom:12px}
.dir-desc{font-size:.82rem;color:#64748b;line-height:1.6;margin-bottom:12px}
.dir-item{display:flex;align-items:flex-start;gap:8px;margin-bottom:8px;font-size:.83rem}
.dir-item i{color:var(--c1);margin-top:2px;flex-shrink:0}
.dir-item a{color:var(--c1);text-decoration:none}
.dir-item a:hover{text-decoration:underline}

/* CONTACTO */
.contacto-card{background:#fff;border-radius:20px;padding:36px;box-shadow:0 2px 16px rgba(0,0,0,.06);border:1px solid #e2e8f0}
.contacto-card h2{font-family:'Sora',sans-serif;font-size:1.4rem;font-weight:800;margin-bottom:24px}
.contacto-info{background:#fff;border-radius:20px;padding:28px;box-shadow:0 2px 16px rgba(0,0,0,.06);border:1px solid #e2e8f0;margin-bottom:20px}
.contacto-info h3{font-family:'Sora',sans-serif;font-size:1.1rem;font-weight:700;margin-bottom:20px}
.contacto-item{display:flex;gap:14px;align-items:flex-start;margin-bottom:16px}
.contacto-icon{width:40px;height:40px;background:rgba(26,86,219,.1);color:var(--c1);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.contacto-item strong{display:block;font-size:.85rem;font-weight:700;color:#1e293b;margin-bottom:2px}
.contacto-item p{font-size:.83rem;color:#64748b;margin:0}
.btn-whatsapp{display:flex;align-items:center;justify-content:center;gap:8px;background:#25d366;color:#fff;padding:12px;border-radius:12px;text-decoration:none;font-weight:700;font-size:.9rem;transition:.2s;margin-top:16px}
.btn-whatsapp:hover{background:#1da851;color:#fff}
.contacto-mapa{border-radius:12px;overflow:hidden;margin-top:16px}

/* BOTONES Y ALERTAS */
.alert-ok{background:#dcfce7;border:1px solid #bbf7d0;color:#15803d;padding:12px 16px;border-radius:10px;margin-bottom:20px;display:flex;align-items:center;gap:8px;font-size:.9rem}
.alert-err{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:10px;margin-bottom:20px;display:flex;align-items:center;gap:8px;font-size:.9rem}
.btn-portal-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--c1);color:#fff;border:none;border-radius:11px;padding:12px 24px;font-family:'Sora',sans-serif;font-weight:700;font-size:.92rem;text-decoration:none;cursor:pointer;transition:.25s}
.btn-portal-primary:hover{opacity:.9;color:#fff;text-decoration:none}
.btn-portal-outline{display:inline-flex;align-items:center;justify-content:center;gap:8px;color:var(--c1);border:1.5px solid var(--c1);border-radius:11px;padding:10px 20px;font-family:'Sora',sans-serif;font-weight:600;font-size:.88rem;text-decoration:none;transition:.2s}
.btn-portal-outline:hover{background:var(--c1);color:#fff;text-decoration:none}
.empty-state{text-align:center;padding:64px 20px;color:#94a3b8}
.empty-state i{font-size:3rem;display:block;margin-bottom:16px}
.noticias-search .form-control{border-radius:10px 0 0 10px;border:1.5px solid #e2e8f0}

@media(max-width:768px){
    .noticia-item{flex-direction:column}
    .noticia-item-img{width:100%;min-height:180px}
    .noticia-item-body{padding:16px}
    .noticia-single{padding:20px}
    .contacto-card{padding:20px}
}
