/* ============================================================
   OLORUN KIT — Línea gráfica unificada (hub · ciberseguridad · site)
   Tokens claro/oscuro · tipografía Fraunces/Hanken/Space Mono
   ============================================================ */
:root{
  --bg:#FBFCFE; --bg-alt:#EFF4F9; --surface:#FFFFFF;
  --text:#11203F; --text-dim:#5C6B82;
  --line:#DCE5EF;
  --accent:#2A8AC6; --accent-2:#1E3C7E; --accent-soft:#9bd0f2;
  --head-bg:rgba(251,252,254,.85);
  --btn:#1E3C7E; --btn-h:#2A8AC6; --btn-tx:#fff;
  --ink:#0E1A30; --ink-2:#0A1426;
  --shadow:rgba(17,32,63,.45);
  --serif:'Fraunces',Georgia,serif; --sans:'Hanken Grotesk',system-ui,sans-serif; --mono:'Space Mono',ui-monospace,monospace;
  --maxw:1180px; --pad:clamp(20px,5vw,68px);
}
[data-theme=dark]{
  --bg:#0A1322; --bg-alt:#0E1A2E; --surface:#13213B;
  --text:#E6EDF7; --text-dim:#9DAEC8;
  --line:#23344F;
  --accent:#3F9BDC; --accent-2:#7FB9E6; --accent-soft:#9bd0f2;
  --head-bg:rgba(10,19,34,.82);
  --btn:#2A6FA8; --btn-h:#3F9BDC; --btn-tx:#fff;
  --ink:#070E1B; --ink-2:#050B16;
  --shadow:rgba(0,0,0,.6);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{background:var(--bg);color:var(--text);font-family:var(--sans);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;transition:background .35s,color .35s}
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--accent-soft);color:#11203F}

.mono{font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--text-dim);text-transform:uppercase}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--accent);flex:none}
.brace{font-family:var(--serif);color:var(--accent);font-weight:400;font-style:italic}

.btn{font-family:var(--sans);font-size:15px;font-weight:500;cursor:pointer;border:none;transition:all .2s;display:inline-flex;align-items:center;gap:8px;border-radius:2px;white-space:nowrap}
.btn--sky{background:var(--btn);color:var(--btn-tx);padding:13px 26px}
.btn--sky:hover{background:var(--btn-h)}
.btn--line{padding:13px 6px;color:var(--text);position:relative;background:none}
.btn--line::after{content:"";position:absolute;left:6px;right:6px;bottom:6px;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.btn--line:hover::after{transform:scaleX(1)}
.btn--ghost-d{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.3);padding:13px 26px}
.btn--ghost-d:hover{border-color:#fff}
.btn--white{background:#fff;color:#11203F;padding:13px 26px}
.btn--white:hover{background:var(--accent-soft)}

/* header */
.head{position:fixed;inset:0 0 auto 0;z-index:60;transition:background .3s,box-shadow .3s}
.head.scrolled{background:var(--head-bg);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--line)}
.head__in{display:flex;align-items:center;justify-content:space-between;height:78px;gap:18px}
.head__logo{height:38px;width:auto}
[data-theme=light] .logo-dark{display:none}
[data-theme=dark] .logo-light{display:none}
.nav{display:flex;align-items:center;gap:28px}
.nav a{font-size:14.5px;color:var(--text);opacity:.78;transition:opacity .2s}
.nav a:hover{opacity:1}
.tools{display:flex;align-items:center;gap:14px}
.lang{display:inline-flex;border:1px solid var(--line);border-radius:3px;overflow:hidden}
.lang button{font-family:var(--mono);font-size:11px;letter-spacing:.04em;padding:5px 8px;background:none;border:none;color:var(--text-dim);cursor:pointer;transition:all .2s}
.lang button[aria-pressed=true]{background:var(--accent);color:#fff}
.themetoggle{width:34px;height:34px;border:1px solid var(--line);border-radius:50%;background:none;color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .2s}
.themetoggle:hover{border-color:var(--accent)}
.themetoggle svg{width:17px;height:17px}
[data-theme=light] .ic-moon{display:none}
[data-theme=dark] .ic-sun{display:none}
.navtoggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.navtoggle span{width:24px;height:1.5px;background:var(--text);display:block}
.mnav{position:fixed;inset:78px 0 auto 0;z-index:55;background:var(--bg);border-bottom:1px solid var(--line);padding:14px var(--pad) 22px;display:none;flex-direction:column;gap:4px}
.mnav.open{display:flex}
.mnav a{padding:11px 0;color:var(--text);border-bottom:1px solid var(--line);font-size:15px}

/* hero */
.hero{padding-top:clamp(124px,16vh,182px);padding-bottom:clamp(50px,8vh,96px);position:relative}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);align-items:center}
.hero h1{font-family:var(--serif);font-weight:300;font-size:clamp(38px,5.4vw,68px);line-height:1.05;letter-spacing:-.02em;margin:26px 0 0}
.hero h1 em{font-style:italic;font-weight:400}
.hero__lead{margin-top:26px;max-width:52ch;font-size:clamp(16px,1.7vw,18.5px);color:var(--text-dim)}
.hero__act{margin-top:34px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.hero__stats{margin-top:48px;border-top:1px solid var(--line);padding-top:22px;display:grid;grid-template-columns:repeat(4,auto);gap:10px 36px;justify-content:start}
.hero__stats div{display:flex;flex-direction:column;gap:2px}
.hero__stats b{font-family:var(--serif);font-weight:400;font-size:23px;color:var(--accent-2);line-height:1}
.hero__stats span{font-family:var(--mono);font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.03em}
.hero__media{position:relative}
.hero__frame{position:relative;border-radius:4px;overflow:hidden;box-shadow:0 30px 70px -30px var(--shadow);will-change:transform}
.hero__frame img{width:100%;height:clamp(360px,52vh,520px);object-fit:cover;object-position:center}
.chip{position:absolute;background:var(--surface);border:1px solid var(--line);border-radius:6px;padding:11px 15px;box-shadow:0 14px 36px -14px var(--shadow);will-change:transform}
.chip__k{font-family:var(--mono);font-size:10px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em}
.chip__v{font-family:var(--serif);font-size:21px;color:var(--accent-2);line-height:1.1}
.chip--score{top:24px;left:-26px}
.chip--prod{bottom:26px;right:-22px;display:flex;align-items:center;gap:9px}
.dot{width:7px;height:7px;border-radius:50%;background:var(--accent);position:relative;flex:none}
.dot::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:1px solid var(--accent);opacity:0;animation:ping 2.6s ease-out infinite}
@keyframes ping{0%{transform:scale(.6);opacity:.7}80%,100%{transform:scale(2.1);opacity:0}}
.hero__deco{position:absolute;right:-8%;top:8%;font-family:var(--serif);font-style:italic;font-size:clamp(180px,26vw,340px);color:var(--accent);opacity:.05;z-index:-1;line-height:1;user-select:none;pointer-events:none}

/* split feature (vEmergency style, reusable) */
.vemg{background:var(--bg-alt);position:relative;overflow:hidden}
.vemg__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,68px);align-items:center;padding-block:clamp(60px,9vh,110px)}
.vemg h2{font-family:var(--serif);font-weight:300;font-size:clamp(28px,4vw,46px);line-height:1.1;letter-spacing:-.02em;margin-top:16px}
.vemg h2 em{font-style:italic;font-weight:400}
.vemg__desc{margin-top:20px;color:var(--text-dim);max-width:48ch}
.vemg__chips{display:flex;flex-wrap:wrap;gap:8px;margin:24px 0 30px;list-style:none}
.vemg__chips li{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-dim);border:1px solid var(--line);border-radius:3px;padding:5px 11px;background:var(--surface)}
.vemg__act{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.vemg__note{margin-top:18px;font-size:13px;color:var(--text-dim);display:flex;gap:8px;align-items:flex-start;max-width:46ch}
.vemg__media{position:relative;display:flex;justify-content:center}
.vemg__frame{position:relative;border-radius:6px;overflow:hidden;box-shadow:0 30px 70px -30px var(--shadow);max-width:380px;will-change:transform}
.vemg__frame img{width:100%;height:clamp(340px,48vh,460px);object-fit:cover}
.qrcard{position:absolute;bottom:-18px;right:-18px;background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:16px;box-shadow:0 20px 50px -18px var(--shadow);text-align:center;will-change:transform}
.qrcard__logo{height:14px;width:auto;margin:0 auto 9px}
.qrcard svg{width:80px;height:80px;display:block;margin:0 auto 8px}
.qrcard__l{font-family:var(--mono);font-size:10px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em}
.qrcard__d{font-family:var(--mono);font-size:11px;color:var(--accent)}

/* marquee */
.clients{padding:46px 0 52px;background:var(--bg);overflow:hidden}
.clients__h{text-align:center;margin-bottom:28px}
.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee+.marquee{margin-top:16px}
.track{display:flex;gap:16px;width:max-content;animation:scroll 42s linear infinite}
.track--rev{animation-direction:reverse;animation-duration:52s}
.marquee:hover .track{animation-play-state:paused}
@keyframes scroll{to{transform:translateX(-50%)}}
.logo-chip{flex:none;width:178px;height:84px;background:#fff;border:1px solid var(--line);border-radius:10px;display:flex;align-items:center;justify-content:center;padding:18px}
/* logos claros (texto blanco / pensados para fondo oscuro) van en chip oscuro para que se lean en color */
.logo-chip:has(img[alt="Coopnectados"]),.logo-chip:has(img[alt="Gysem"]){background:var(--ink);border-color:var(--ink)}
.logo-chip img{max-height:100%;max-width:100%;width:auto;object-fit:contain;filter:grayscale(1);opacity:.62;transition:filter .3s,opacity .3s}
.logo-chip:hover img{filter:none;opacity:1}

/* section */
.sec{padding-block:clamp(64px,9vh,116px)}
.sec--alt{background:var(--bg-alt)}
.sec__head{max-width:60ch;margin-bottom:50px}
.sec__head--center{margin-inline:auto;text-align:center}
.sec h2{font-family:var(--serif);font-weight:300;font-size:clamp(28px,4vw,46px);line-height:1.1;letter-spacing:-.02em;margin-top:16px}
.sec h2 em{font-style:italic;font-weight:400}
.sec__desc{margin-top:18px;color:var(--text-dim);max-width:60ch}
.sec__head--center .eyebrow{justify-content:center}
.sec__head--center .sec__desc{margin-inline:auto}

/* 3-up pillars */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:6px;overflow:hidden}
.pillar{background:var(--bg);padding:34px 30px;display:flex;flex-direction:column;min-height:300px;transition:background .25s}
.pillar:hover{background:var(--surface)}
.pillar__route{font-family:var(--mono);font-size:12px;color:var(--accent)}
.pillar h3{font-family:var(--serif);font-weight:400;font-size:27px;margin:14px 0 12px;letter-spacing:-.01em;color:var(--text)}
.pillar p{color:var(--text-dim);font-size:15.5px;flex:1}
.pillar__tags{display:flex;flex-wrap:wrap;gap:6px;margin:16px 0 18px}
.pillar__tags span{font-family:var(--mono);font-size:10.5px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;border:1px solid var(--line);border-radius:3px;padding:3px 8px}
.pillar__link{font-size:14.5px;color:var(--accent-2);font-weight:500;display:inline-flex;align-items:center;gap:6px}
.pillar__link:hover{color:var(--accent)}

/* service cards grid (reusable) */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.cards--2{grid-template-columns:repeat(2,1fr)}
.scard{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:30px 28px;display:flex;flex-direction:column;transition:border-color .25s,transform .25s}
.scard:hover{border-color:var(--accent);transform:translateY(-3px)}
.scard__tag{font-family:var(--mono);font-size:11px;color:var(--accent);text-transform:uppercase;letter-spacing:.05em;margin-bottom:14px}
.scard h3{font-family:var(--serif);font-weight:400;font-size:24px;color:var(--text);margin-bottom:10px;letter-spacing:-.01em}
.scard p{color:var(--text-dim);font-size:15px;flex:1}
.scard__meta{margin-top:16px;font-family:var(--mono);font-size:12px;color:var(--text);letter-spacing:.02em}
.scard ul{list-style:none;margin-top:14px;display:flex;flex-direction:column;gap:7px}
.scard ul li{font-size:14px;color:var(--text-dim);padding-left:18px;position:relative}
.scard ul li::before{content:"›";position:absolute;left:0;color:var(--accent);font-family:var(--mono)}

/* pricing */
.prices{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:start}
.price{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:32px 28px;display:flex;flex-direction:column}
.price--feat{border:2px solid var(--accent)}
.price__badge{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:#fff;background:var(--accent);border-radius:3px;padding:3px 9px;align-self:flex-start;margin-bottom:14px}
.price__name{font-family:var(--serif);font-size:24px;color:var(--text);margin-bottom:6px}
.price__amt{font-family:var(--serif);font-weight:400;font-size:34px;color:var(--accent-2);line-height:1.1}
.price__amt small{font-family:var(--mono);font-size:12px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em}
.price__sub{font-size:13.5px;color:var(--text-dim);margin:6px 0 18px}
.price ul{list-style:none;display:flex;flex-direction:column;gap:9px;flex:1;margin-bottom:22px}
.price ul li{font-size:14px;color:var(--text);padding-left:20px;position:relative}
.price ul li::before{content:"✓";position:absolute;left:0;color:var(--accent);font-weight:700}
.price .btn{justify-content:center}

/* numbered process steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:6px;overflow:hidden}
.step{background:var(--bg);padding:28px 26px}
.step__n{font-family:var(--mono);font-size:13px;color:var(--accent)}
.step h3{font-family:var(--serif);font-weight:400;font-size:21px;color:var(--text);margin:10px 0 8px}
.step p{font-size:14.5px;color:var(--text-dim)}

/* dark parallax band */
.band{position:relative;overflow:hidden;background:var(--ink);color:#fff}
.band__bg{position:absolute;inset:-18% 0;width:100%;height:136%;object-fit:cover;opacity:.34;will-change:transform}
.band__veil{position:absolute;inset:0;background:linear-gradient(105deg,rgba(10,16,30,.92) 30%,rgba(10,16,30,.6) 70%,rgba(30,60,126,.5))}
.band__in{position:relative;padding-block:clamp(72px,12vh,140px)}
.band h2{font-family:var(--serif);font-weight:300;font-size:clamp(30px,4.6vw,56px);line-height:1.12;letter-spacing:-.02em;max-width:18ch;color:#fff}
.band h2 em{font-style:italic;font-weight:400;color:var(--accent-soft)}
.band__sub{margin-top:22px;max-width:50ch;color:#b9c6da;font-size:18px}
.band__stats{margin-top:48px;display:flex;flex-wrap:wrap;gap:14px 56px}
.band__stats div{display:flex;flex-direction:column;gap:3px}
.band__stats b{font-family:var(--serif);font-weight:400;font-size:38px;color:#fff;line-height:1}
.band__stats span{font-family:var(--mono);font-size:11px;color:var(--accent-soft);text-transform:uppercase;letter-spacing:.05em}

/* ledger */
.ledger{border-top:1px solid var(--line)}
.row{display:grid;grid-template-columns:minmax(0,230px) 1fr auto;align-items:baseline;gap:14px 30px;padding:24px 0;border-bottom:1px solid var(--line);transition:background .25s}
.row:hover{background:rgba(42,138,198,.06)}
.row__dom{font-family:var(--mono);font-size:13px;color:var(--accent)}
.row__name{font-family:var(--serif);font-size:23px;font-weight:400;color:var(--text)}
.row__name small{display:block;font-family:var(--sans);font-size:14.5px;color:var(--text-dim);margin-top:3px}
.row__state{font-family:var(--mono);font-size:12px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;display:inline-flex;align-items:center;gap:9px;white-space:nowrap}

/* testimonials */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.quote{border:1px solid var(--line);border-radius:8px;padding:26px 24px;background:var(--surface);display:flex;flex-direction:column}
.quote__stars{color:var(--accent);letter-spacing:2px;font-size:13px;margin-bottom:14px}
.quote p{font-size:15.5px;flex:1;color:var(--text)}
.quote__who{display:flex;align-items:center;gap:12px;margin-top:20px}
.quote__who img{width:42px;height:42px;border-radius:50%;object-fit:cover;flex:none}
.quote__n{font-size:14.5px;font-weight:500;color:var(--text)}
.quote__r{font-family:var(--mono);font-size:11px;color:var(--text-dim)}

/* contact */
.contact{position:relative;overflow:hidden;background:var(--ink);color:#fff}
.contact__bg{position:absolute;inset:-18% 0;width:100%;height:136%;object-fit:cover;opacity:.22;will-change:transform}
.contact__veil{position:absolute;inset:0;background:linear-gradient(120deg,rgba(10,16,30,.95) 40%,rgba(14,26,48,.78))}
.contact__in{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,64px);align-items:center;padding-block:clamp(56px,9vh,104px)}
.contact__logo{height:40px;width:auto;margin-bottom:22px}
.contact h2{font-family:var(--serif);font-weight:300;font-size:clamp(28px,4.4vw,48px);line-height:1.1;letter-spacing:-.02em;color:#fff;max-width:16ch}
.contact h2 em{font-style:italic;font-weight:400;color:var(--accent-soft)}
.contact__lead{margin-top:18px;color:#b9c6da;max-width:42ch}
.contact__direct{margin-top:26px;display:flex;gap:12px;flex-wrap:wrap}
.contact__meta{margin-top:22px;font-family:var(--mono);font-size:12px;color:#7d8ca6;text-transform:uppercase;letter-spacing:.04em}
.formcard{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:clamp(24px,3vw,34px)}
.formcard h3{font-family:var(--serif);font-weight:400;font-size:23px;color:var(--text);margin-bottom:6px}
.formcard p.sub{font-size:14px;color:var(--text-dim);margin-bottom:22px}
.field{margin-bottom:16px}
.field label{display:block;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;font-family:var(--sans);font-size:15px;color:var(--text);background:var(--bg);border:1px solid var(--line);border-radius:4px;padding:11px 13px;transition:border-color .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent)}
.field textarea{resize:vertical;min-height:84px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.formcard .btn{width:100%;justify-content:center;padding:14px;margin-top:4px}
.form-status{margin-top:12px;font-size:13.5px;min-height:18px}
.form-status.ok{color:#1e9e75}.form-status.err{color:#d8593a}
.form-legal{margin-top:14px;font-size:11.5px;color:var(--text-dim);line-height:1.5}
.form-legal a{color:var(--accent);text-decoration:underline}

/* footer */
.foot{background:var(--ink-2);color:#9fb0c8;padding:64px 0 36px}
.foot__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:32px}
.foot__logo{height:34px;width:auto;margin-bottom:18px}
.foot__tag{font-size:14px;color:#7d8ca6;max-width:30ch}
.foot h4{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:#fff;margin-bottom:14px;font-weight:400}
.foot__col a{display:block;font-size:14px;color:#9fb0c8;padding:5px 0;transition:color .2s}
.foot__col a:hover{color:var(--accent-soft)}
.foot__social{display:flex;gap:12px;margin-top:18px}
.foot__social a{width:34px;height:34px;border:1px solid rgba(255,255,255,.16);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:12px;color:#9fb0c8;transition:all .2s}
.foot__social a:hover{border-color:var(--accent);color:#fff}
.foot__bottom{margin-top:48px;padding-top:22px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-family:var(--mono);font-size:11px;color:#6f7e96;text-transform:uppercase;letter-spacing:.04em}

.rv{opacity:0;transform:translateY(20px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.rv.in{opacity:1;transform:none}

@media(max-width:900px){
  .hero__grid{grid-template-columns:1fr}.hero__media{margin-top:8px}
  .chip--score{left:8px}.chip--prod{right:8px}
  .vemg__grid{grid-template-columns:1fr}.vemg__media{order:-1}
  .pillars,.cards,.prices,.steps{grid-template-columns:1fr}
  .cards--2{grid-template-columns:1fr}
  .quotes{grid-template-columns:1fr}
  .contact__in{grid-template-columns:1fr}
  .foot__grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .nav,.head .btn--sky{display:none}
  .navtoggle{display:flex}
  .hero__stats{grid-template-columns:repeat(2,auto);gap:18px 28px}
  .row{grid-template-columns:1fr auto;gap:6px 14px}
  .row__dom{grid-column:1/-1;order:-1}
  .row2{grid-template-columns:1fr}
  .foot__grid{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .rv{opacity:1;transform:none}
  [data-parallax]{transform:none!important}
  html{scroll-behavior:auto}
}

/* ============================================================
   Iconos normalizados + grid de módulos (estilo Centro de Ayuda)
   Uso: <svg class="ic"><use href="…/olorun-icons.svg#ic-nomina"></use></svg>
   ============================================================ */
.ic{width:24px;height:24px;display:inline-block;color:var(--accent);flex:none}
.ic--lg{width:30px;height:30px}
.ic use{pointer-events:none}

.modgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.modcard{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:24px 16px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;cursor:pointer;color:var(--text);transition:border-color .2s,background .2s,transform .2s}
.modcard:hover{border-color:var(--accent);background:var(--bg-alt);transform:translateY(-2px)}
.modcard .ic{width:30px;height:30px;color:var(--accent-2)}
.modcard:hover .ic{color:var(--accent)}
.modcard__l{font-size:14px;font-weight:500;font-family:var(--sans);color:var(--text)}
.modcard--active{border-color:var(--accent);background:rgba(42,138,198,.08)}
.modcard--active .ic{color:var(--accent)}
@media(max-width:900px){.modgrid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.modgrid{grid-template-columns:repeat(2,1fr)}}
