/* ==========================================================================
   RnI Consultores Independientes — Diseño A (estilos del tema)
   Portado fiel desde el mockup. Un solo archivo para todas las páginas.
   ========================================================================== */

:root{
  --navy:#10254c; --navy2:#0a1832; --celeste:#2aa6e0; --amber:#f4c20d;
  --bg:#f7f9fc; --bg-alt:#eef3f9; --text:#16233f; --muted:#5b6885; --card:#ffffff; --border:#e4ebf5; --hero-text:#fff;
}
html[data-theme="dark"]{--bg:#0c1626;--bg-alt:#0f1d33;--text:#e8eefb;--muted:#9fb0cf;--card:#122440;--border:#20355c}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:"Segoe UI",system-ui,-apple-system,Roboto,Arial,sans-serif;color:var(--text);background:var(--bg);line-height:1.55}
a{color:inherit;text-decoration:none}
img{max-width:100%}
/* Skip-link (accesibilidad): oculto hasta recibir foco con Tab */
.skip-link{position:fixed;left:8px;top:-80px;z-index:100000;background:var(--navy);color:#fff!important;padding:10px 18px;border-radius:0 0 10px 10px;font-weight:700;font-size:14px;text-decoration:none;box-shadow:0 6px 18px rgba(0,0,0,.3);transition:top .15s}
.skip-link:focus{top:0;outline:3px solid var(--celeste);outline-offset:2px}
#rni-contenido{scroll-margin-top:10px}
.wrap{max-width:1200px;margin:0 auto;padding:0 22px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;border-radius:10px;padding:11px 22px;font-size:15px;cursor:pointer;border:2px solid transparent;transition:.18s}
.btn-amber{background:var(--amber);color:#1a1300!important}.btn-amber:hover{transform:translateY(-2px)}
html[data-theme="dark"] .btn-amber{background:#c99c1e}
.btn-ghost{background:transparent;color:var(--hero-text);border-color:rgba(255,255,255,.65)}.btn-ghost:hover{background:rgba(255,255,255,.14)}
.btn-navy{background:var(--navy);color:#fff!important}.btn-navy:hover{background:#1a3e80}
.btn-red{background:#ff0000;color:#fff!important}.btn-red:hover{transform:translateY(-2px)}
.btn-gray{background:#6b7280;color:#fff!important}.btn-gray:hover{background:#565e6b;transform:translateY(-2px)}

/* Barra superior */
.topbar{background:var(--navy2);color:#cfe0f5;font-size:12.5px}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:32px}
.topbar .social{display:flex;gap:14px;align-items:center}
.topbar .social a{display:flex;opacity:.85}.topbar .social a:hover{opacity:1}
.topbar svg{width:15px;height:15px;fill:currentColor}
.toggle{background:rgba(255,255,255,.1);border:0;color:#cfe0f5;cursor:pointer;border-radius:20px;padding:4px 10px;font-size:12px}

/* Header con collage (servicios + publicaciones), adaptable claro/oscuro */
header.rni-header{position:sticky;top:0;z-index:50;background:#0b1830}
html[data-theme="light"] header.rni-header{box-shadow:0 6px 18px rgba(16,37,76,.18)}
html[data-theme="dark"]  header.rni-header{box-shadow:0 8px 22px rgba(0,0,0,.5)}
.hbgclip{position:absolute;inset:0;overflow:hidden;z-index:0}
.hcollage{position:absolute;inset:0;display:flex}
.hcollage .ph{flex:1;background-size:cover;background-position:center;margin-left:-55px;animation:hkb 26s ease-in-out infinite alternate;-webkit-mask-image:linear-gradient(90deg,transparent,#000 16%,#000 84%,transparent);mask-image:linear-gradient(90deg,transparent,#000 16%,#000 84%,transparent)}
.hcollage .ph:first-child{margin-left:0}
@keyframes hkb{from{transform:scale(1.05)}to{transform:scale(1.14)}}
html[data-theme="light"] .hcollage .ph{filter:grayscale(.15) brightness(1.02) saturate(1.05)}
html[data-theme="dark"]  .hcollage .ph{filter:grayscale(.4) brightness(.6) saturate(1.05)}
.hgrad{position:absolute;inset:0}
html[data-theme="light"] .hgrad{background:radial-gradient(95% 130% at 88% 30%,rgba(42,166,224,.16),transparent 60%),linear-gradient(96deg,rgba(255,255,255,.93),rgba(255,255,255,.78) 44%,rgba(228,238,252,.55))}
html[data-theme="dark"]  .hgrad{background:radial-gradient(90% 120% at 88% 30%,rgba(42,166,224,.28),transparent 60%),linear-gradient(96deg,rgba(8,20,42,.93),rgba(8,20,42,.8) 42%,rgba(9,26,56,.64))}
.hgrad::after{content:"";position:absolute;left:0;right:0;bottom:0;height:4px;background:linear-gradient(90deg,var(--celeste),var(--amber))}
header.rni-header .wrap{position:relative;z-index:3;display:flex;align-items:center;justify-content:space-between;height:150px;gap:20px}
.logo{position:relative;display:inline-flex;align-items:center;padding:4px 14px}
.logo::before{content:"";position:absolute;inset:0;z-index:0;border-radius:20px;filter:blur(7px)}
html[data-theme="light"] .logo::before{background:radial-gradient(62% 130% at 50% 50%,rgba(255,255,255,.88),rgba(255,255,255,.58) 45%,rgba(255,255,255,0) 80%)}
html[data-theme="dark"]  .logo::before{background:radial-gradient(62% 130% at 50% 50%,rgba(255,255,255,.95),rgba(255,255,255,.7) 40%,rgba(42,166,224,.22) 66%,rgba(255,255,255,0) 82%)}
.logo img{position:relative;z-index:1;height:135px;width:auto;display:block;filter:drop-shadow(0 3px 8px rgba(0,0,0,.3))}
nav.main{display:flex;gap:22px;align-items:center;margin-left:auto}
nav.main>a{font-weight:700;font-size:16.5px;padding:6px 0;text-transform:uppercase;letter-spacing:.4px}
html[data-theme="light"] nav.main>a{color:var(--navy)}
html[data-theme="dark"]  nav.main>a{color:#fff;text-shadow:0 1px 6px rgba(0,0,0,.55)}
nav.main>a:hover,nav.main>a.active{color:var(--celeste)!important}
.brochure-hdr{margin:0 2px 0 10px}
nav.main>a.brochure-hdr{padding:11px 24px;color:#1a1300!important;text-shadow:none}
/* Hamburguesa (mobile) */
.navtoggle{display:none;background:transparent;border:0;cursor:pointer;width:44px;height:44px;align-items:center;justify-content:center;position:relative;z-index:4}
.navtoggle span{position:relative;display:block;width:26px;height:3px;border-radius:2px;background:currentColor;transition:.25s}
.navtoggle span::before,.navtoggle span::after{content:"";position:absolute;left:0;width:26px;height:3px;border-radius:2px;background:currentColor;transition:.25s}
.navtoggle span::before{top:-8px}.navtoggle span::after{top:8px}
html[data-theme="light"] .navtoggle{color:var(--navy)}
html[data-theme="dark"]  .navtoggle{color:#fff}
.navtoggle.open span{background:transparent}
.navtoggle.open span::before{top:0;transform:rotate(45deg)}
.navtoggle.open span::after{top:0;transform:rotate(-45deg)}

/* Hero (Home) */
.hero{position:relative;min-height:430px;display:flex;align-items:center;background:var(--navy2);overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0;transform:scale(1.03)}
.hero-grad{position:absolute;inset:0;z-index:1;background:linear-gradient(96deg,rgba(8,20,42,.97) 0%,rgba(8,20,42,.9) 32%,rgba(9,26,56,.6) 64%,rgba(9,26,56,.32) 100%)}
.hero .wrap{position:relative;z-index:2;padding:38px 22px;width:100%}
.hero-content{max-width:690px;color:var(--hero-text);text-align:left}
.eyebrow{color:var(--amber);font-weight:700;letter-spacing:2px;font-size:12.5px;text-transform:uppercase;margin-bottom:14px}
.hero h1{font-size:40px;line-height:1.12;font-weight:800;margin-bottom:14px;color:#fff}
.hero p{font-size:17px;color:#dbe6f7;max-width:600px;margin-bottom:24px}
.hero .cta{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.hero .cta .btn-ghost{margin:0 6px}

/* Hero de página (slim) */
.page-hero{position:relative;min-height:185px;display:flex;align-items:flex-end;background:var(--navy2);overflow:hidden}
.page-hero.compact{min-height:170px}
.page-hero .hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0;transform:scale(1.03)}
.page-hero .hero-grad{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(8,20,42,.55) 0%,rgba(8,20,42,.9) 100%)}
.page-hero .wrap{position:relative;z-index:2;padding:24px 22px;width:100%;color:#fff}
.crumb{font-size:13px;color:#bcd0ee;margin-bottom:8px}
.crumb a:hover{color:var(--celeste)}
.page-hero h1{font-size:38px;font-weight:800;line-height:1.1;color:#fff}
.page-hero .lead{color:#dbe6f7;max-width:880px;margin-top:8px;font-size:16px}

/* Secciones */
section.block{padding:26px 0}
#serv,#contacto{scroll-margin-top:165px}
.sec-head{text-align:center;max-width:760px;margin:0 auto 18px}
.sec-head .kicker{color:var(--celeste);font-weight:700;letter-spacing:2px;text-transform:uppercase;font-size:12px}
.sec-head h2{font-size:26px;color:var(--text);margin:5px 0 8px;font-weight:800}
.sec-head p{color:var(--muted);font-size:14.5px}

/* Carrusel servicios (Home) */
.carousel{position:relative;padding:0 56px}
.track-mask{overflow:hidden;padding:6px 2px}
.track{display:flex;gap:20px}
.scard-c{flex:0 0 calc((100% - 4*20px)/5);background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:0 10px 30px rgba(16,37,76,.06);display:flex;flex-direction:column}
.scard-c .ph{height:150px;background:linear-gradient(135deg,#163a73,#2aa6e0);display:flex;align-items:center;justify-content:center}
.scard-c .ph.ph-photo{background-size:cover;background-position:center;background-repeat:no-repeat}
/* Apagar un poquito las fotos con mucho blanco */
.scard-c .ph.ph-photo,.pub .cover.photo,.split .ph{filter:brightness(.95) saturate(1.04)}
.scard-c .ph svg,.scard-c .ph img{width:54px;height:54px;background:#fff;border-radius:50%;padding:12px;box-sizing:border-box;object-fit:contain}
.scard-c .ph svg{fill:none;stroke:#15336b;stroke-width:1.9}
.scard-c .body{padding:12px 14px 15px;text-align:center}
.scard-c h3{font-size:14.5px;color:var(--text);margin-bottom:6px;line-height:1.22}
.scard-c p{font-size:12.5px;color:var(--muted);line-height:1.45}
.arrow{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:50%;background:var(--navy);color:#fff;border:0;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:5;box-shadow:0 6px 18px rgba(0,0,0,.2)}
.arrow:hover{background:var(--celeste)}.arrow.prev{left:2px}.arrow.next{right:2px}
/* Chevron dibujado con CSS puro (sin SVG): ningún tema/plugin lo puede pisar. */
.arrow::before{content:"";display:block;width:9px;height:9px;border-top:2.5px solid #fff;border-right:2.5px solid #fff}
.arrow.next::before{transform:rotate(45deg);margin-left:-3px}
.arrow.prev::before{transform:rotate(-135deg);margin-right:-3px}
.dots{display:flex;gap:8px;justify-content:center;margin-top:16px}
.dots i{width:9px;height:9px;border-radius:50%;background:var(--border);cursor:pointer}.dots i.on{background:var(--amber);width:24px;border-radius:5px}
.center{text-align:center;margin-top:18px}

/* Stats (3 datos, un poco más grandes) */
.stats{background:var(--navy)}
.stats .wrap{display:flex;flex-wrap:wrap;justify-content:center;gap:22px;padding:32px 22px;text-align:center;color:#fff}
.stat{flex:1 1 0;min-width:160px}
.stat b{display:block;font-size:36px;color:var(--amber);font-weight:800;line-height:1.1}
.stat span{color:#cfe0f5;font-size:14.5px}

/* RnI en Imágenes */
.ig-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.ig-grid .tile{aspect-ratio:1/1;border-radius:12px;background:linear-gradient(135deg,#1b3a73,#2aa6e0);display:flex;align-items:center;justify-content:center;overflow:hidden}
.ig-grid .tile span{color:rgba(255,255,255,.55);font-size:12px}
.ig-grid .tile:nth-child(9){display:none}
/* Feed real de Instagram (Smash Balloon): en WEB los 8 más recientes (4x2). El mobile (9 en 3x3) va en el @media de abajo. */
.ig-feed #sb_instagram #sbi_images{display:grid!important;grid-template-columns:repeat(4,1fr)!important;gap:12px!important}
.ig-feed #sb_instagram #sbi_images .sbi_item{width:auto!important;margin:0!important;padding:0!important;aspect-ratio:1;overflow:hidden}
.ig-feed #sb_instagram #sbi_images .sbi_item:nth-child(n+9){display:none!important}
.ig-feed #sb_instagram #sbi_load,.ig-feed #sb_instagram .sbi_load_btn{display:none!important}
.ig-feed #sb_instagram .sb_instagram_header{display:none!important} /* sacamos avatar+bio: la sección ya tiene su título */
/* Feed de YouTube (Smash Balloon): fila de 4 en web, 2x2 en mobile. Solo los 4 más recientes. */
.yt-feed .sb_youtube .sby_items_wrap{display:grid!important;grid-template-columns:repeat(4,1fr)!important;gap:14px!important}
.yt-feed .sb_youtube .sby_item{width:auto!important;margin:0!important;padding:0!important;float:none!important}
.yt-feed .sb_youtube .sby_item:nth-child(n+5){display:none!important}
.yt-feed .sb_youtube .sby_footer,.yt-feed .sb_youtube .sby_load_more_wrap,.yt-feed .sb_youtube .sby_load_btn,.yt-feed .sb_youtube .sby_load_more{display:none!important}
/* Cada celda con alto fijo 16:9 (cargue o no la miniatura de i.ytimg.com) y botón play chico/centrado. Evita el "play gigante" si la imagen no carga. */
.yt-feed .sb_youtube .sby_video_thumbnail_wrap{position:relative!important;aspect-ratio:16/9!important;height:auto!important;padding:0!important;overflow:hidden!important;border-radius:10px;background:#0b1830}
.yt-feed .sb_youtube .sby_video_thumbnail{width:100%!important;height:100%!important;display:block!important;background-size:cover!important;background-position:center!important}
.yt-feed .sb_youtube .sby_video_thumbnail img{width:100%!important;height:100%!important;object-fit:cover!important;display:block}
.yt-feed .sb_youtube .sby_play_btn{position:absolute!important;top:50%!important;left:50%!important;transform:translate(-50%,-50%)!important;width:auto!important;height:auto!important;max-width:none!important;margin:0!important;z-index:2}
.yt-feed .sb_youtube .sby_play_btn svg{width:46px!important;height:46px!important;max-width:46px!important;opacity:.92}
.yt-feed .sb_youtube .sby_thumbnail_hover,.yt-feed .sb_youtube .sby_video_title{display:none!important} /* sin título superpuesto: miniatura limpia */
.feed-cta{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:16px}

/* Videos */
.vid-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.vid{position:relative;aspect-ratio:16/9;border-radius:12px;overflow:hidden;background:linear-gradient(135deg,#11203c,#1d2e4d);display:flex;align-items:center;justify-content:center;cursor:pointer}
.vid .play{width:50px;height:50px;border-radius:50%;background:#ff0000;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 18px rgba(0,0,0,.35);transition:.18s}
.vid:hover .play{transform:scale(1.08)}
.vid .play svg{width:22px;height:22px;fill:#fff;margin-left:3px}
.vid .vlabel{position:absolute;left:0;right:0;bottom:0;padding:20px 12px 9px;background:linear-gradient(transparent,rgba(0,0,0,.78));color:#fff;font-size:12.5px}

/* Contacto / formulario */
.contact{display:grid;grid-template-columns:1fr 1.15fr;gap:32px;align-items:start}
.contact .intro h2{font-size:28px;color:var(--text);font-weight:800;margin-bottom:12px}
.contact .intro p{color:var(--muted);margin-bottom:16px}
.cinfo{display:flex;gap:10px;align-items:center;margin-bottom:10px;color:var(--text);font-weight:600}
.cinfo svg{width:20px;height:20px;fill:none;stroke:var(--celeste);stroke-width:1.8}
.form{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:0 14px 40px rgba(16,37,76,.08)}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{margin-bottom:13px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:5px}
.field input,.field textarea{width:100%;border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:10px;padding:11px 13px;font-size:15px;font-family:inherit}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--celeste)}
.field textarea{min-height:96px;resize:vertical;overflow:hidden}
.form-note{margin-top:10px;font-size:13px;display:none}
.form-note.show{display:block}
.form-note.ok{color:#1a7f37}.form-note.err{color:#c0392b}

/* Empresas que confían */
.clients-sec{background:var(--bg);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
html[data-theme="dark"] .clients-sec{background:var(--bg-alt);border-color:var(--border)}
.clients-sec .sec-head{margin-bottom:18px;max-width:none}
.clients-sec .sec-head h2{color:#16233f}
html[data-theme="dark"] .clients-sec .sec-head h2{color:var(--text)}
.clients-sec .sec-head p{color:#5b6885}
.clients{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.clients-track{display:flex;gap:54px;width:max-content;align-items:center;animation:marq 50s linear infinite}
.clients:hover .clients-track{animation-play-state:paused}
.clients-track img{height:42px;width:auto;object-fit:contain;filter:grayscale(1);opacity:.62;transition:.25s}
.clients-track img:hover{filter:none;opacity:1}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Grilla de servicios (página Servicios) */
.sgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
/* Última fila incompleta: si sobra UNO solo, va centrado (col 2). Si sobran dos,
   quedan naturales en col 1 y 2. Sirve para cualquier cantidad de servicios. */
.sgrid .scard:last-child:nth-child(3n+1){grid-column:2}
.scard{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:20px;box-shadow:0 10px 30px rgba(16,37,76,.06);display:flex;flex-direction:column}
.scard .head{display:flex;gap:13px;align-items:center;margin-bottom:11px}
.scard .ico{width:50px;height:50px;flex:0 0 50px;border-radius:13px;background:linear-gradient(135deg,#163a73,#2aa6e0);display:flex;align-items:center;justify-content:center}
.scard .ico svg{width:27px;height:27px;fill:none;stroke:#fff;stroke-width:1.9}
.scard .ico img{width:28px;height:28px;object-fit:contain;filter:brightness(0) invert(1)}
.scard h3{font-size:16px;color:var(--text);font-weight:800;line-height:1.2}
.scard .desc{font-size:13px;color:var(--text);line-height:1.5;margin-bottom:11px;text-align:justify}
.scard ul{list-style:none;margin:0;padding:0;border-top:1px solid var(--border);padding-top:9px}
.scard li{position:relative;padding:3px 0 3px 18px;font-size:12.5px;color:var(--muted);line-height:1.4}
.scard li::before{content:"";position:absolute;left:0;top:9px;width:6px;height:6px;border-radius:50%;background:var(--celeste)}

/* CTA band */
.cta-band{background:var(--navy);text-align:center}
.cta-band .wrap{padding:34px 22px;color:#fff}
.cta-band h2{font-size:26px;font-weight:800;margin-bottom:8px;color:#fff}
.cta-band p{color:#cfe0f5;margin-bottom:18px}

/* Nosotros — Historia */
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:34px;align-items:center}
.split .kicker{color:var(--celeste);font-weight:700;letter-spacing:2px;text-transform:uppercase;font-size:12px;margin-bottom:5px}
.split h2{font-size:27px;font-weight:800;margin-bottom:8px}
.split p{color:var(--muted);margin-bottom:12px;font-size:14.5px}
.split .ph{border-radius:16px;overflow:hidden;min-height:260px;background-size:cover;background-position:center;box-shadow:0 16px 40px rgba(16,37,76,.16)}
/* Misión / Visión */
.mv{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.mv .c{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:0 10px 30px rgba(16,37,76,.06)}
.mv .c .ico{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#163a73,#2aa6e0);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.mv .c .ico svg{width:26px;height:26px;fill:none;stroke:#fff;stroke-width:1.9}
.mv .c h3{font-size:19px;font-weight:800;margin-bottom:6px}
.mv .c p{color:var(--muted);font-size:14.5px}
/* Cómo trabajamos */
.work{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.work .it{display:flex;gap:11px;align-items:flex-start;background:var(--card);border:1px solid var(--border);border-radius:11px;padding:12px 15px}
.work .it svg{width:21px;height:21px;flex:0 0 21px;fill:none;stroke:var(--celeste);stroke-width:2;margin-top:1px}
.work .it span{font-size:14px;color:var(--text);font-weight:600}
/* Equipo (página local) */
.team{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.member{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:0 10px 30px rgba(16,37,76,.06)}
.member .mtop{display:flex;align-items:center;gap:16px;margin-bottom:8px}
.member .avatar{width:64px;height:64px;flex:0 0 64px;border-radius:50%;background:linear-gradient(135deg,#163a73,#2aa6e0);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:21px;letter-spacing:1px}
.member .who h3{font-size:19px;font-weight:800;color:var(--navy);line-height:1.2}
.member .who .role{display:inline-block;margin-top:5px;font-size:11.5px;font-weight:700;color:var(--celeste);background:rgba(42,166,224,.1);border-radius:20px;padding:3px 12px;text-transform:uppercase;letter-spacing:1px}
.member h4{font-size:12.5px;font-weight:800;color:var(--navy);text-transform:uppercase;letter-spacing:1px;margin:15px 0 6px}
.member p{font-size:13.5px;color:var(--muted);margin-bottom:9px;text-align:justify;line-height:1.6}
.member ul{margin:6px 0 0;padding-left:18px;list-style:disc}
.member ul li{font-size:13.5px;color:var(--muted);margin-bottom:7px;text-align:justify;line-height:1.55}
@media(max-width:760px){.team{grid-template-columns:1fr}}
.work-close{text-align:center;color:var(--muted);max-width:780px;margin:18px auto 0;font-size:14.5px}
/* Valores */
.values{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.val{text-align:center}
.val .ico{width:58px;height:58px;border-radius:50%;background:var(--bg-alt);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;margin:0 auto 10px}
.val .ico svg{width:28px;height:28px;fill:none;stroke:var(--celeste);stroke-width:1.8}
.val h3{font-size:15px;font-weight:800;margin-bottom:5px}
.val p{font-size:12.5px;color:var(--muted);line-height:1.45}

/* Descargas — Tabs */
.tabs{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:24px}
.tabs button{background:var(--card);border:1px solid var(--border);color:var(--text);font-weight:700;font-size:14px;padding:10px 20px;border-radius:30px;cursor:pointer;transition:.18s}
.tabs button:hover{border-color:var(--celeste)}
.tabs button.on{background:var(--navy);color:#fff;border-color:var(--navy)}
html[data-theme="dark"] .tabs button.on{background:var(--celeste);border-color:var(--celeste);color:#06223a}
.panel{display:none}.panel.on{display:block;animation:fade .3s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
/* Lista de normativas / artículos */
.doc-list{display:flex;flex-direction:column;gap:12px;max-width:940px;margin:0 auto}
.doc{display:flex;gap:16px;align-items:center;background:var(--card);border:1px solid var(--border);border-radius:13px;padding:14px 18px;box-shadow:0 8px 24px rgba(16,37,76,.05)}
.doc .dico{width:42px;height:42px;flex:0 0 42px;border-radius:10px;background:var(--bg-alt);display:flex;align-items:center;justify-content:center}
.doc .dico svg{width:22px;height:22px;fill:none;stroke:var(--celeste);stroke-width:1.8}
.doc .info{flex:1}
.doc .info h3{font-size:15px;font-weight:800;line-height:1.3}
.doc .info p{font-size:13px;color:var(--muted);margin-top:2px}
.doc .info .tagx{display:inline-block;margin-top:6px;font-size:11.5px;font-weight:700;color:var(--celeste);background:rgba(42,166,224,.1);border-radius:20px;padding:2px 10px}
/* Paginador (Normativas / Artículos): números de página + Anterior/Siguiente. */
.pager{display:flex;align-items:center;justify-content:center;gap:10px;margin:26px auto 0;max-width:940px;flex-wrap:wrap}
.pager .pg-prev,.pager .pg-next{display:inline-flex;align-items:center;gap:7px;background:var(--navy);color:#fff;border:none;border-radius:9px;padding:10px 16px;font-weight:700;font-size:14px;cursor:pointer;transition:.18s}
.pager .pg-prev:hover,.pager .pg-next:hover{background:var(--celeste)}
.pager .pg-prev svg,.pager .pg-next svg,.pager .pg-prev svg path,.pager .pg-next svg path{width:16px;height:16px;fill:none!important;stroke:#fff!important;stroke-width:2.4!important;stroke-linecap:round;stroke-linejoin:round}
.pager .pg-nums{display:flex;gap:6px;flex-wrap:wrap}
.pager .pg-num{min-width:40px;justify-content:center;display:inline-flex;align-items:center;background:var(--card);color:var(--text);border:1px solid var(--border);border-radius:9px;padding:9px 12px;font-weight:700;font-size:14px;cursor:pointer;transition:.18s}
.pager .pg-num:hover{border-color:var(--celeste)}
.pager .pg-num.on{background:var(--navy);color:#fff;border-color:var(--navy)}
html[data-theme="dark"] .pager .pg-num.on{background:var(--celeste);border-color:var(--celeste);color:#06223a}
/* 404 — con impronta RnI (triángulo + marca) */
.nf{background:linear-gradient(160deg,var(--navy) 0%,var(--navy2) 100%);color:#fff;text-align:center;padding:90px 20px;min-height:62vh;display:flex;align-items:center;justify-content:center}
.nf .wrap{max-width:640px}
.nf-tri{width:92px;height:auto;margin:0 auto 20px;display:block;opacity:.96;filter:drop-shadow(0 10px 26px rgba(0,0,0,.35))}
.nf-code{font-size:84px;font-weight:800;line-height:1;color:var(--celeste);letter-spacing:3px}
.nf h1{font-size:30px;font-weight:800;margin:4px 0 12px;color:#fff}
.nf p{color:#dbe6f7;font-size:16px;margin:0 auto 28px;max-width:520px}
.nf-btns{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
@media(max-width:600px){.nf-code{font-size:64px}.nf h1{font-size:24px}}
.doc .dl{flex:0 0 auto;display:inline-flex;align-items:center;gap:7px;background:var(--navy);color:#fff;font-weight:700;font-size:12.5px;padding:8px 15px;border-radius:9px;white-space:nowrap}
.doc .dl:hover{background:var(--celeste)}
.doc .dl svg{width:15px;height:15px;fill:none;stroke:#fff;stroke-width:2}
.doc .dls{display:flex;gap:8px;flex-wrap:wrap;flex:0 0 auto}
/* Publicaciones */
.pub-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.pub{background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:0 10px 30px rgba(16,37,76,.06);display:flex;flex-direction:column}
.pub .cover{height:235px;background:linear-gradient(135deg,#163a73,#2aa6e0);display:flex;align-items:center;justify-content:center}
.pub .cover.photo{background-size:cover;background-repeat:no-repeat;background-position:center top}
.pub .cover svg{width:34px;height:34px;fill:none;stroke:#fff;stroke-width:1.6}
.pub .pb{padding:14px 16px 16px;display:flex;flex-direction:column;flex:1}
.pub .kind{font-size:10.5px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:#b8860b;margin-bottom:6px}
html[data-theme="dark"] .pub .kind{color:var(--amber)}
.pub h3{font-size:15px;font-weight:800;line-height:1.25;margin-bottom:5px}
.pub p{font-size:12.5px;color:var(--muted);flex:1;text-align:justify}
.pub .dls{margin-top:12px;display:flex;gap:14px;flex-wrap:wrap}
.pub .dl{display:inline-flex;align-items:center;gap:7px;color:var(--celeste);font-weight:700;font-size:12.5px}
.pub .dl svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2}
/* Enlaces */
.links-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:980px;margin:0 auto;align-items:stretch}
.lcard{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:22px;box-shadow:0 10px 30px rgba(16,37,76,.06);display:flex;flex-direction:column;height:100%}
.lcard .lico{width:60px;height:60px;border-radius:11px;background:linear-gradient(135deg,#163a73,#2aa6e0);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.lcard .lico svg{width:24px;height:24px;fill:none;stroke:#fff;stroke-width:1.8}
.lcard .lico.logo{width:auto;height:88px;max-width:100%;align-self:center;background:#fff;border:1px solid var(--border);border-radius:12px;padding:10px 22px;box-shadow:0 2px 8px rgba(16,37,76,.06)}
.lcard .lico.logo img{max-height:65px;max-width:234px;width:auto;height:auto;object-fit:contain;display:block}
.lcard h3{font-size:15.5px;font-weight:800;margin-bottom:5px;min-height:2.5em;display:flex;align-items:center}
.lcard p{font-size:13px;color:var(--muted);margin-bottom:14px;flex:1}
.lcard a.go{display:inline-flex;align-items:center;gap:7px;color:var(--celeste);font-weight:700;font-size:13px;margin-top:auto}
.lcard a.go svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2}

/* Texto legal (privacidad / cookies) */
.legal{max-width:880px;margin:0 auto}
.legal>p.intro{font-size:15.5px;color:var(--text);margin-bottom:8px}
.legal h2{font-size:19px;font-weight:800;margin:24px 0 9px;color:var(--text)}
.legal p{color:var(--muted);margin-bottom:12px;font-size:14.5px}
.legal ul{margin:0 0 12px 0;padding-left:20px;color:var(--muted);font-size:14.5px}
.legal li{margin-bottom:7px}
.legal a{color:var(--celeste);font-weight:600}
.legal mark{background:rgba(244,194,13,.4);color:var(--text);padding:1px 6px;border-radius:4px;font-weight:600}
.legal .updated{color:var(--muted);font-size:13px;margin-top:28px;font-style:italic}
.aaip{background:var(--bg-alt);border:1px solid var(--border);border-left:4px solid var(--celeste);border-radius:10px;padding:16px 18px;margin:8px 0 14px;font-size:13.5px;color:var(--text)}
.ctable{width:100%;border-collapse:collapse;margin:6px 0 14px;font-size:14px}
.ctable th,.ctable td{text-align:left;padding:11px 14px;border:1px solid var(--border);vertical-align:top}
.ctable th{background:var(--bg-alt);color:var(--text);font-weight:800}
.ctable td{color:var(--muted)}

/* Volver arriba */
.totop{position:fixed;right:18px;bottom:18px;z-index:95;display:inline-flex;align-items:center;gap:7px;background:rgba(16,37,76,.5);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fff;border:1px solid rgba(255,255,255,.4);border-radius:30px;padding:11px 17px;font-weight:700;font-size:13.5px;cursor:pointer;opacity:0;visibility:hidden;transform:translateY(12px);transition:.25s;box-shadow:0 8px 24px rgba(0,0,0,.28)}
.totop.show{opacity:1;visibility:visible;transform:none}
.totop:hover{background:rgba(42,166,224,.85)}
.totop svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2.6}

/* Footer */
footer.rni-footer{background:var(--navy2);color:#aebfdd;font-size:13.5px;padding:30px 0 0}
.fcols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:26px}
footer.rni-footer h4{color:#fff;font-size:14.5px;margin-bottom:12px;text-transform:uppercase;letter-spacing:1px}
footer.rni-footer a{display:block;padding:3px 0;color:#aebfdd}footer.rni-footer a:hover{color:var(--celeste)}
footer.rni-footer p{margin-bottom:0}
.ftri{position:relative;display:inline-block;padding:18px 26px;margin-bottom:10px}
.fbrand .ftri{display:block;width:max-content;max-width:100%;margin:0 auto 10px}
.ftri::before{content:"";position:absolute;inset:0;background:radial-gradient(58% 120% at 50% 50%,rgba(255,255,255,.95) 0%,rgba(255,255,255,.7) 46%,rgba(255,255,255,0) 80%);filter:blur(10px);border-radius:26px;z-index:0}
.ftri img{position:relative;z-index:1;height:116px;width:auto;display:block}
.fbar{border-top:1px solid rgba(255,255,255,.12);margin-top:20px;padding:13px 0}
.fbar .wrap{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:12.5px}
footer.rni-footer .fbar a{display:inline;padding:0}
.fbar .wrap>span:last-child{white-space:nowrap}
.fsocial{display:flex;gap:14px;align-items:center;margin-top:10px}
.fsocial a{display:inline-flex;padding:0;color:#aebfdd}.fsocial a:hover{color:var(--celeste)}
.fsocial svg{width:20px;height:20px;fill:currentColor}

/* Cookie */
.cookie{position:fixed;bottom:16px;left:16px;right:16px;max-width:560px;margin:0 auto;background:var(--card);border:1px solid var(--border);border-radius:14px;padding:14px 18px;box-shadow:0 16px 40px rgba(0,0,0,.18);display:flex;gap:14px;align-items:center;z-index:99}
.cookie p{font-size:13px;color:var(--muted)}

/* ===================== Responsive ===================== */
@media(max-width:1100px) and (min-width:981px){
  .pub-grid{grid-template-columns:repeat(2,1fr)}
  .sgrid{grid-template-columns:repeat(2,1fr)}
  .sgrid .scard:last-child:nth-child(3n+1){grid-column:auto}
}
@media(max-width:980px){
  header.rni-header .wrap{height:104px}
  .logo img{height:78px}
  header.rni-header .navtoggle{display:inline-flex;background:transparent!important;border:0!important;box-shadow:none!important;padding:0!important;min-width:0!important;width:44px!important;height:44px!important;margin:0!important;flex:0 0 auto}
  nav.main{position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:var(--navy2);padding:8px 0;display:none;box-shadow:0 16px 30px rgba(0,0,0,.45)}
  nav.main.open{display:flex}
  nav.main>a{color:#fff!important;padding:13px 22px;text-shadow:none}
  nav.main>a.brochure-hdr{margin:10px 22px;justify-content:center}
  .hero h1{font-size:32px}
  .page-hero h1{font-size:30px}
  .scard-c{flex-basis:calc((100% - 20px)/2)}
  .ig-grid{grid-template-columns:repeat(3,1fr)}.ig-grid .tile:nth-child(9){display:flex}
  .ig-feed #sb_instagram #sbi_images{grid-template-columns:repeat(3,1fr)!important}.ig-feed #sb_instagram #sbi_images .sbi_item:nth-child(n+9){display:block!important}.ig-feed #sb_instagram #sbi_images .sbi_item:nth-child(n+10){display:none!important}
  .yt-feed .sb_youtube .sby_items_wrap{grid-template-columns:repeat(2,1fr)!important}
  .vid-row{grid-template-columns:repeat(2,1fr)}
  .contact{grid-template-columns:1fr}
  .sgrid{grid-template-columns:1fr}.sgrid .scard:last-child:nth-child(3n+1){grid-column:auto}
  .split,.mv,.work{grid-template-columns:1fr}
  .values{grid-template-columns:repeat(2,1fr)}
  .pub-grid,.links-grid{grid-template-columns:1fr}
  .doc{flex-wrap:wrap}.doc .dl,.doc .dls{margin-left:58px}
  .fcols{grid-template-columns:1fr 1fr}
  .ctable,.ctable tbody,.ctable tr,.ctable td,.ctable th{display:block}
  .ctable th{margin-top:10px}
}
@media(max-width:560px){
  .scard-c{flex-basis:100%}
  .vid-row{grid-template-columns:1fr}
  .fcols{grid-template-columns:1fr}
  .hero h1{font-size:26px}
  .form .row{grid-template-columns:1fr}
  .values{grid-template-columns:1fr}
}
