/* ===========================================================
   IPSE · cursos.css  ·  Grilla de cursos + modal de malla (#ipseCursos)
   =========================================================== */
#ipseCursos,#ipseCursos *{box-sizing:border-box}
#ipseCursos img{max-width:100%;display:block}
#ipseCursos a{text-decoration:none}
#ipseCursos button{font-family:inherit;cursor:pointer}
#ipseCursos{--red:#FF2C2C;--redD:#B40017;--redDp:#6B0010;--ink:#0f172a;--sub:#475569;--ease:cubic-bezier(.2,.9,.2,1)}
#ipseCursos .cs-shell{width:100%;padding:clamp(52px,6vw,88px) 0 clamp(60px,7vw,100px);background:#f8fafc;position:relative;isolation:isolate;overflow:hidden}
#ipseCursos .cs-shell::before{content:"";position:absolute;inset:-200px;pointer-events:none;z-index:0;background:radial-gradient(ellipse 60% 50% at 15% 20%,rgb(255 44 44 / .07),transparent 65%),radial-gradient(ellipse 50% 45% at 85% 80%,rgb(255 44 44 / .05),transparent 60%)}
#ipseCursos .cs-inner{position:relative;z-index:1;width:100%;max-width:1380px;margin:0 auto;padding:0 clamp(16px,3.5vw,48px)}
#ipseCursos .cs-head{text-align:center;margin-bottom:clamp(32px,4vw,52px)}
#ipseCursos .cs-kicker{display:inline-flex;align-items:center;gap:8px;padding:7px 16px;border-radius:999px;background:rgb(255 44 44 / .07);border:1px solid rgb(255 44 44 / .18);font:900 11px/1 system-ui,Arial;letter-spacing:.18em;text-transform:uppercase;color:rgb(180 0 23 / .88);margin-bottom:14px}
#ipseCursos .cs-kicker-dot{width:7px;height:7px;border-radius:99px;background:var(--red);box-shadow:0 0 0 3px rgb(255 44 44 / .20)}
#ipseCursos .cs-title{font:900 clamp(26px,3vw,42px)/1.1 system-ui,Arial;letter-spacing:-.025em;color:var(--ink);margin:0 0 10px}
#ipseCursos .cs-title span{color:var(--redD)}
#ipseCursos .cs-title::after{content:"";display:block;width:72px;height:5px;border-radius:999px;background:linear-gradient(90deg,var(--redDp),var(--red));margin:14px auto 0;box-shadow:0 8px 22px rgb(255 44 44 / .22)}
#ipseCursos .cs-sub{font:500 clamp(14px,1.2vw,16.5px)/1.6 system-ui,Arial;color:var(--sub);max-width:640px;margin:14px auto 0}
/* ----- Buscador + filtros ----- */
#ipseCursos .cs-filter{display:flex;flex-direction:column;gap:16px;margin-bottom:30px}
#ipseCursos .cs-search{position:relative;width:100%;max-width:480px;margin:0 auto}
#ipseCursos .cs-search .cs-search-ico{position:absolute;left:18px;top:50%;transform:translateY(-50%);font-size:16px;opacity:.5;pointer-events:none}
#ipseCursos .cs-search input{width:100%;padding:14px 44px 14px 46px;border-radius:999px;border:1.5px solid rgb(15 23 42 / .12);font:600 15px/1.2 system-ui,Arial;color:var(--ink);background:#fff;box-shadow:0 4px 16px rgb(15 23 42 / .06);transition:border-color .15s ease,box-shadow .15s ease}
#ipseCursos .cs-search input::placeholder{color:#94a3b8;font-weight:500}
#ipseCursos .cs-search input:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 4px rgb(255 44 44 / .12)}
#ipseCursos .cs-search .cs-search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:28px;height:28px;border:none;border-radius:999px;background:rgb(15 23 42 / .06);color:#475569;font:900 14px/1 system-ui,Arial;cursor:pointer;display:none;place-items:center}
#ipseCursos .cs-search .cs-search-clear.show{display:grid}
#ipseCursos .cs-cats{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
#ipseCursos .cs-cat{padding:9px 18px;border-radius:999px;border:1.5px solid rgb(255 44 44 / .18);background:#fff;font:800 13px/1 system-ui,Arial;color:var(--sub);cursor:pointer;transition:background .16s ease,color .16s ease,border-color .16s ease,transform .12s var(--ease)}
#ipseCursos .cs-cat:hover{transform:translateY(-1px);color:var(--ink)}
#ipseCursos .cs-cat.active{background:#C00;color:#fff;border-color:#C00;box-shadow:0 6px 18px rgb(180 0 0 / .24)}
#ipseCursos .cs-cat .cs-cat-n{opacity:.7;font-weight:700}
#ipseCursos .cs-empty{display:none;text-align:center;padding:46px 20px;color:#94a3b8;font:600 15px/1.6 system-ui,Arial}
#ipseCursos .cs-empty.show{display:block}
#ipseCursos .cs-empty b{color:var(--ink)}
@media(max-width:700px){#ipseCursos .cs-cats{justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;padding:0 clamp(16px,4vw,24px) 4px;scrollbar-width:none}#ipseCursos .cs-cats::-webkit-scrollbar{display:none}#ipseCursos .cs-cat{flex:0 0 auto}}
#ipseCursos .cs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
@media(max-width:700px){#ipseCursos .cs-grid{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-padding-left:clamp(16px,4vw,24px);-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;padding-left:clamp(16px,4vw,24px);padding-right:clamp(16px,4vw,24px);padding-bottom:12px;scrollbar-width:none;-ms-overflow-style:none}#ipseCursos .cs-grid::-webkit-scrollbar{display:none}#ipseCursos .cs-card{flex:0 0 82vw;max-width:320px;scroll-snap-align:start}#ipseCursos .cs-swipe-hint{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:16px;font:700 12px/1 system-ui,Arial;letter-spacing:.10em;text-transform:uppercase;color:rgb(15 23 42 / .45)}#ipseCursos .cs-swipe-hint svg{opacity:.5}}
@media(min-width:701px){#ipseCursos .cs-swipe-hint{display:none}}
#ipseCursos .cs-card{border-radius:22px;overflow:hidden;background:#fff;border:1px solid rgb(15 23 42 / .07);box-shadow:0 8px 32px rgb(15 23 42 / .09);display:flex;flex-direction:column;transition:transform .22s var(--ease),box-shadow .22s var(--ease);cursor:pointer;position:relative}
#ipseCursos .cs-card:hover{transform:translateY(-6px);box-shadow:0 24px 64px rgb(15 23 42 / .16)}
#ipseCursos .cs-img-wrap{position:relative;height:210px;overflow:hidden;background:#0a0a14}
#ipseCursos .cs-img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease),filter .5s ease;filter:saturate(1.05)}
#ipseCursos .cs-card:hover .cs-img{transform:scale(1.07);filter:saturate(1.12) brightness(1.04)}
#ipseCursos .cs-img-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgb(10 10 20 / .72) 100%);pointer-events:none}
#ipseCursos .cs-area{position:absolute;top:14px;left:14px;z-index:2;display:inline-flex;align-items:center;gap:7px;padding:6px 12px;border-radius:999px;font:900 10.5px/1 system-ui,Arial;letter-spacing:.10em;text-transform:uppercase;color:#fff;white-space:nowrap;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgb(255 255 255 / .22)}
#ipseCursos .cs-area-dot{width:7px;height:7px;border-radius:99px;background:#fff;opacity:.9}
#ipseCursos .cs-img-title{position:absolute;bottom:14px;left:14px;right:14px;z-index:2;font:900 clamp(16px,1.4vw,19px)/1.15 system-ui,Arial;color:#fff;letter-spacing:-.01em;text-shadow:0 2px 12px rgb(0 0 0 / .35)}
#ipseCursos .cs-body{padding:18px 18px 20px;display:flex;flex-direction:column;gap:14px;flex:1}
#ipseCursos .cs-desc{font:500 13.5px/1.55 system-ui,Arial;color:var(--sub);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
#ipseCursos .cs-chips{display:flex;gap:7px;flex-wrap:wrap}
#ipseCursos .cs-chip{font:800 10.5px/1 system-ui,Arial;letter-spacing:.08em;text-transform:uppercase;padding:5px 10px;border-radius:999px;border:1px solid;white-space:nowrap}
#ipseCursos .cs-foot{display:flex;gap:8px;align-items:center;padding:14px 18px;border-top:1px solid rgb(15 23 42 / .06);margin-top:auto}
#ipseCursos .cs-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:10px 14px;border-radius:999px;font:900 13px/1 system-ui,Arial;border:none;transition:transform .15s var(--ease),box-shadow .15s var(--ease);white-space:nowrap}
#ipseCursos .cs-btn:hover{transform:translateY(-1px)}
#ipseCursos .cs-btn.wsp{background:#16a34a;color:#fff;box-shadow:0 6px 18px rgb(22 163 74 / .22)}
#ipseCursos .cs-btn.wsp:hover{background:#15803d;box-shadow:0 10px 24px rgb(22 163 74 / .32)}
#ipseCursos .cs-btn.info{background:#fff;color:var(--ink);border:1px solid rgb(15 23 42 / .12);box-shadow:0 4px 14px rgb(15 23 42 / .07);flex:0 0 auto}
#ipseCursosModal{display:none;position:fixed;inset:0;z-index:99999;align-items:center;justify-content:center;padding:clamp(10px,2vw,20px);background:rgb(10 10 20 / .60);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);overscroll-behavior:contain;touch-action:none}
#ipseCursosModal.is-open{display:flex}
#ipseCursosModal .cm-dialog{width:min(960px,100%);max-height:calc(100dvh - 24px);border-radius:24px;overflow:hidden;background:#fff;box-shadow:0 40px 100px rgb(0 0 0 / .35);border:1px solid rgb(255 44 44 / .12);display:flex;flex-direction:column;animation:cmIn .2s var(--ease) both}
@keyframes cmIn{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}
#ipseCursosModal .cm-top{display:flex;gap:16px;align-items:flex-start;padding:20px 20px 16px;border-bottom:1px solid rgb(15 23 42 / .07);background:linear-gradient(180deg,#fff0f0,#fff);flex-shrink:0}
#ipseCursosModal .cm-thumb{width:110px;height:110px;border-radius:16px;overflow:hidden;flex-shrink:0;border:1px solid rgb(255 44 44 / .16);box-shadow:0 10px 26px rgb(0 0 0 / .08)}
#ipseCursosModal .cm-thumb img{width:100%;height:100%;object-fit:cover}
#ipseCursosModal .cm-head{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}
#ipseCursosModal .cm-area-tag{font:900 10.5px/1 system-ui,Arial;letter-spacing:.14em;text-transform:uppercase;color:var(--redD)}
#ipseCursosModal .cm-title{font:900 clamp(18px,2vw,24px)/1.12 system-ui,Arial;color:var(--ink);letter-spacing:-.015em}
#ipseCursosModal .cm-sub{font:500 14px/1.5 system-ui,Arial;color:var(--sub);overflow-wrap:anywhere}
#ipseCursosModal .cm-pills{display:flex;flex-wrap:wrap;gap:7px;margin-top:4px}
#ipseCursosModal .cm-pill{font:800 10.5px/1 system-ui,Arial;letter-spacing:.10em;text-transform:uppercase;padding:6px 11px;border-radius:999px;background:rgb(255 44 44 / .07);border:1px solid rgb(255 44 44 / .18);color:var(--redD)}
#ipseCursosModal .cm-close{width:40px;height:40px;border-radius:12px;flex-shrink:0;border:1px solid rgb(15 23 42 / .10);background:#fff;display:grid;place-items:center;font-size:18px;font-weight:900;color:var(--redD);transition:transform .14s var(--ease);margin-left:auto}
#ipseCursosModal .cm-close:hover{transform:scale(.96)}
#ipseCursosModal .cm-scroll{overflow:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;touch-action:pan-y;flex:1}
#ipseCursosModal .cm-body{padding:20px;display:grid;grid-template-columns:1.4fr .9fr;gap:16px}
#ipseCursosModal .cm-card{border:1px solid rgb(15 23 42 / .08);border-radius:18px;background:#fff;box-shadow:0 8px 24px rgb(15 23 42 / .06);overflow:hidden}
#ipseCursosModal .cm-card-h{padding:12px 16px;border-bottom:1px solid rgb(15 23 42 / .06);font:900 13.5px/1 system-ui,Arial;color:var(--ink);background:linear-gradient(180deg,#fafafa,#fff)}
#ipseCursosModal .cm-card-b{padding:14px 16px;font:500 14px/1.6 system-ui,Arial;color:#334155;overflow-wrap:anywhere}
#ipseCursosModal .cm-malla{margin:0;padding-left:18px}
#ipseCursosModal .cm-malla li{margin:8px 0}
#ipseCursosModal .cm-cta-col{display:flex;flex-direction:column;gap:10px}
#ipseCursosModal .cm-action{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 16px;border-radius:999px;border:none;font:900 14px/1 system-ui,Arial;text-decoration:none;transition:transform .15s var(--ease),box-shadow .15s var(--ease);white-space:nowrap}
#ipseCursosModal .cm-action:hover{transform:translateY(-1px)}
#ipseCursosModal .cm-action.wsp{background:#16a34a;color:#fff;box-shadow:0 8px 22px rgb(22 163 74 / .26)}
#ipseCursosModal .cm-action.wsp:hover{background:#15803d;box-shadow:0 12px 28px rgb(22 163 74 / .36)}
#ipseCursosModal .cm-action.copy{background:#C00;color:#fff;box-shadow:0 8px 22px rgb(180 0 0 / .22)}
#ipseCursosModal .cm-note{font:500 12px/1.5 system-ui,Arial;color:#94a3b8}
@media(max-width:860px){#ipseCursosModal .cm-body{grid-template-columns:1fr}#ipseCursosModal .cm-thumb{width:80px;height:80px;border-radius:12px}}
@media(max-width:520px){#ipseCursosModal .cm-top{flex-wrap:wrap}#ipseCursosModal .cm-close{position:absolute;top:12px;right:12px}#ipseCursosModal .cm-title{font-size:18px;padding-right:48px}}
html.ipse-lock,html.ipse-lock body{overflow:hidden!important;touch-action:none}
