.elementor-170 .elementor-element.elementor-element-604eacc{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-170 .elementor-element.elementor-element-da18397{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-widget-image-gallery .gallery-item .gallery-caption{font-family:var( --e-global-typography-accent-font-family ), Sans-serif;font-size:var( --e-global-typography-accent-font-size );font-weight:var( --e-global-typography-accent-font-weight );text-transform:var( --e-global-typography-accent-text-transform );font-style:var( --e-global-typography-accent-font-style );letter-spacing:var( --e-global-typography-accent-letter-spacing );}.elementor-170 .elementor-element.elementor-element-984e4fb .gallery-item .gallery-caption{display:none;}.elementor-170 .elementor-element.elementor-element-a722e1b{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-170 .elementor-element.elementor-element-746f7e0{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-170 .elementor-element.elementor-element-ad3a1d4{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:-35px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;}.elementor-170 .elementor-element.elementor-element-ad3a1d4 > .elementor-shape-top .elementor-shape-fill, .elementor-170 .elementor-element.elementor-element-ad3a1d4 > .e-con-inner > .elementor-shape-top .elementor-shape-fill{fill:#C95C01;}.elementor-170 .elementor-element.elementor-element-ad3a1d4 > .elementor-shape-top svg, .elementor-170 .elementor-element.elementor-element-ad3a1d4 > .e-con-inner > .elementor-shape-top svg{width:calc(161% + 1.3px);}.elementor-170 .elementor-element.elementor-element-204283f{margin:164px 0px calc(var(--kit-widget-spacing, 0px) + 30px) 0px;}:root{--page-title-display:none;}@media(min-width:768px){.elementor-170 .elementor-element.elementor-element-da18397{--content-width:886px;}.elementor-170 .elementor-element.elementor-element-ad3a1d4{--content-width:905px;}}@media(max-width:1024px){.elementor-widget-image-gallery .gallery-item .gallery-caption{font-size:var( --e-global-typography-accent-font-size );letter-spacing:var( --e-global-typography-accent-letter-spacing );}}@media(max-width:767px){.elementor-widget-image-gallery .gallery-item .gallery-caption{font-size:var( --e-global-typography-accent-font-size );letter-spacing:var( --e-global-typography-accent-letter-spacing );}}/* Start custom CSS for html, class: .elementor-element-cc78cfe */@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700&family=Playfair+Display:ital,wght@0,400;0,700;1,400&display=swap');

/* ── HERO ── */
.jpat-hero{padding:6rem 2.5rem 5rem;text-align:center;background:#fff;border-bottom:1px solid #e8e8e8}
.jpat-eyebrow{font-family:'Montserrat',sans-serif;font-size:18px;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:#c96a3a;margin-bottom:1.2rem;display:block;animation:jpat-up .7s ease both}
.jpat-title{font-family:'Playfair Display',serif!important;font-size:clamp(3rem,8vw,6.5rem)!important;font-weight:700!important;color:#111!important;line-height:1!important;margin-bottom:.5rem!important;animation:jpat-up .7s ease .1s both}
.jpat-subtitle{font-family:'Montserrat',sans-serif;font-size:clamp(.7rem,1.5vw,.85rem);font-weight:300;letter-spacing:.5em;text-transform:uppercase;color:#999;margin-bottom:2rem;display:block;animation:jpat-up .7s ease .15s both}
.jpat-divider{width:44px;height:2px;background:#c96a3a;margin:0 auto 2rem;animation:jpat-up .7s ease .2s both}
.jpat-desc{font-family:'Montserrat',sans-serif;font-size:.95rem;font-weight:300;line-height:1.95;color:#666;max-width:560px;margin:0 auto;animation:jpat-up .7s ease .25s both}
@keyframes jpat-up{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}

/* ── BASE ── */
.jpat-wrap{max-width:1160px;margin:0 auto;padding:0 2.5rem}
.jpat-sh{text-align:center;margin-bottom:3.5rem}
.jpat-tag{font-family:'Montserrat',sans-serif;font-size:30px;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:#c96a3a;display:block;margin-bottom:.8rem}
.jpat-stitle{font-family:'Playfair Display',serif!important;font-size:clamp(1.8rem,3.5vw,2.8rem)!important;font-weight:700!important;color:#111!important;line-height:1.2!important;margin-bottom:1rem!important}
.jpat-line{width:40px;height:2px;background:#c96a3a;margin:0 auto 1rem}
.jpat-sub{font-family:'Montserrat',sans-serif;font-size:20px;font-weight:300;color:#666;max-width:420px;margin:0 auto;line-height:1.90rem}

/* ── ESTILOS ── */
.jpat-estilos{padding:6rem 0;background:#f9f9f9;border-top:1px solid #e8e8e8;border-bottom:1px solid #e8e8e8}
.jpat-egrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:#e8e8e8;border:1px solid #e8e8e8}
.jpat-ecard{background:#fff;padding:2.5rem 2rem;text-align:center;transition:background .3s;position:relative;overflow:hidden}
.jpat-ecard::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:#c96a3a;transform:scaleX(0);transition:transform .3s;transform-origin:left}
.jpat-ecard:hover{background:#fdf0ea}
.jpat-ecard:hover::after{transform:scaleX(1)}
.jpat-enum{font-family:'Montserrat',sans-serif;font-size:.62rem;font-weight:700;letter-spacing:.2em;color:#c96a3a;display:block;margin-bottom:.9rem}
.jpat-ename{font-family:'Playfair Display',serif!important;font-size:1.05rem!important;font-weight:700!important;color:#111!important;margin-bottom:.6rem!important;line-height:1.3}
.jpat-edesc{font-family:'Montserrat',sans-serif;font-size:.82rem;font-weight:300;color:#666;line-height:1.7;margin:0!important}


/* ── PORTAFOLIO (header) ── */
.jpat-port{padding:6rem 0;background:#fff;border-bottom:1px solid #e8e8e8}

/* ── REVEAL ── */
.jpat-r{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.jpat-r.jpat-vis{opacity:1;transform:translateY(0)}
.jpat-d1{transition-delay:.1s}.jpat-d2{transition-delay:.2s}.jpat-d3{transition-delay:.3s}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .jpat-egrid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  .jpat-hero{padding:4rem 1.5rem 3.5rem}
  .jpat-wrap{padding:0 1.5rem}
  .jpat-egrid{grid-template-columns:1fr}
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-540c3b0 */@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700&family=Playfair+Display:ital,wght@0,400;0,700;1,400&display=swap');

/* ── BASE ── */
.jpat-wrap{max-width:1160px;margin:0 auto;padding:0 2.5rem}
.jpat-sh{text-align:center;margin-bottom:3.5rem}
.jpat-tag{font-family:'Montserrat',sans-serif;font-size:.68rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:#c96a3a;display:block;margin-bottom:.8rem}
.jpat-stitle{font-family:'Playfair Display',serif!important;font-size:clamp(1.8rem,3.5vw,2.8rem)!important;font-weight:700!important;color:#111!important;line-height:1.2!important;margin-bottom:1rem!important}
.jpat-line{width:40px;height:2px;background:#c96a3a;margin:0 auto 1rem}

/* ── FAQ ── */
.jpat-faq{padding:6rem 0;background:#f9f9f9;border-bottom:1px solid #e8e8e8}
.jpat-flist{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:1px;background:#e8e8e8;border:1px solid #e8e8e8}
.jpat-fi{background:#fff;cursor:pointer}
.jpat-fq{padding:1.4rem 1.8rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;transition:background .2s}
.jpat-fi:hover .jpat-fq,.jpat-fi.jpat-open .jpat-fq{background:#fdf0ea}
.jpat-fqt{font-family:'Montserrat',sans-serif;font-size:.82rem;font-weight:600;color:#111;line-height:1.5}
.jpat-ficon{width:22px;height:22px;border:1.5px solid #ddd;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1rem;color:#c96a3a;transition:all .3s;background:#fff;line-height:1}
.jpat-fi.jpat-open .jpat-ficon{background:#c96a3a;border-color:#c96a3a;color:#fff;transform:rotate(45deg)}
.jpat-fa{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s;padding:0 1.8rem}
.jpat-fi.jpat-open .jpat-fa{max-height:500px;padding:0 1.8rem 1.5rem}
.jpat-fa p{font-family:'Montserrat',sans-serif;font-size:.85rem;font-weight:300;line-height:1.85;color:#666;margin-bottom:.5rem}
.jpat-fa strong{color:#111;font-weight:600}
.jpat-fa ul{list-style:none;margin-top:.4rem}
.jpat-fa ul li{font-family:'Montserrat',sans-serif;font-size:.83rem;font-weight:300;color:#666;padding:.2rem 0 .2rem 1.1rem;position:relative;line-height:1.7}
.jpat-fa ul li::before{content:'–';position:absolute;left:0;color:#c96a3a}

/* ── CTA ── */
.jpat-cta{padding:6rem 2.5rem;background:#fff;text-align:center;border-bottom:1px solid #e8e8e8}
.jpat-ctitle{font-family:'Playfair Display',serif!important;font-size:clamp(1.8rem,4vw,3rem)!important;font-weight:700!important;color:#111!important;margin-bottom:.8rem!important;line-height:1.2!important}
.jpat-ctitle span{color:#c96a3a}
.jpat-csub{font-family:'Montserrat',sans-serif;font-size:.92rem;font-weight:300;color:#666;margin:0 auto 2.5rem;max-width:440px;line-height:1.85}
.jpat-cbadges{display:flex;justify-content:center;gap:2rem;margin-bottom:2.5rem;flex-wrap:wrap}
.jpat-cbadge{display:flex;align-items:center;gap:.5rem;font-family:'Montserrat',sans-serif;font-size:.75rem;font-weight:500;color:#666}
.jpat-dot{width:6px;height:6px;background:#c96a3a;border-radius:50%;flex-shrink:0}
.jpat-btn{background:#c96a3a;color:#fff;font-family:'Montserrat',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;padding:.9rem 2.4rem;text-decoration:none;border:2px solid #c96a3a;transition:all .25s;display:inline-block}
.jpat-btn:hover{background:#e07a45;border-color:#e07a45;color:#fff}

/* ── REVEAL ── */
.jpat-r{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.jpat-r.jpat-vis{opacity:1;transform:translateY(0)}

/* ── RESPONSIVE ── */
@media(max-width:640px){
  .jpat-wrap{padding:0 1.5rem}
  .jpat-cta{padding:4rem 1.5rem}
  .jpat-cbadges{gap:1rem}
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-204283f */<style>
.jp-videos-section {
  width: 100%;
  padding: 0;
}
.jp-videos-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 1.5rem;
}
.jp-videos-heading {
  font-size: 28px;
  font-weight: 600;
  margin: 0;
  color: inherit;
  letter-spacing: -0.02em;
}
.jp-videos-heading span {
  color: #D85A30;
}
.jp-ver-todo {
  font-size: 13px;
  color: #888;
  text-decoration: none;
  transition: color 0.2s;
}
.jp-ver-todo:hover {
  color: #D85A30;
}
 
/* Grid */
.jp-videos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.25rem;
}
 
/* Card */
.jp-v-card {
  border-radius: 12px;
  overflow: hidden;
  background: #1a1a1a;
  border: 1px solid #2a2a2a;
  cursor: pointer;
  transition: transform 0.2s ease, border-color 0.2s ease;
}
.jp-v-card:hover {
  transform: translateY(-3px);
  border-color: #444;
}
 
/* Thumbnail */
.jp-v-thumb {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%; /* 16:9 */
  background: #111;
  overflow: hidden;
}
.jp-v-thumb img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.3s ease;
}
.jp-v-card:hover .jp-v-thumb img {
  transform: scale(1.04);
}
.jp-v-thumb iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
}
 
/* Overlay y botón play */
.jp-v-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.3);
  transition: background 0.2s;
}
.jp-v-card:hover .jp-v-overlay {
  background: rgba(0, 0, 0, 0.5);
}
.jp-v-play-btn {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: rgba(216, 90, 48, 0.92);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.2s, background 0.2s;
  flex-shrink: 0;
}
.jp-v-card:hover .jp-v-play-btn {
  transform: scale(1.1);
  background: #D85A30;
}
.jp-v-play-tri {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 11px 0 11px 20px;
  border-color: transparent transparent transparent #ffffff;
  margin-left: 4px;
}
.jp-v-duration {
  position: absolute;
  bottom: 10px;
  right: 10px;
  background: rgba(0, 0, 0, 0.82);
  color: #fff;
  font-size: 11px;
  font-weight: 500;
  padding: 2px 7px;
  border-radius: 4px;
  letter-spacing: 0.02em;
  font-family: inherit;
}
 
/* Cuerpo de la card */
.jp-v-body {
  padding: 14px 16px 16px;
}
.jp-v-cat {
  font-size: 10px;
  font-weight: 700;
  color: #D85A30;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 5px;
  font-family: inherit;
}
.jp-v-title {
  font-size: 14px;
  font-weight: 500;
  color: #f0f0f0;
  line-height: 1.45;
  margin-bottom: 9px;
  font-family: inherit;
}
.jp-v-channel {
  font-size: 12px;
  color: #777;
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: inherit;
}
.jp-v-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #D85A30;
  flex-shrink: 0;
  display: inline-block;
}
 
/* Estado reproduciendo: oculta imagen y overlay */
.jp-v-card.jp-playing .jp-v-overlay,
.jp-v-card.jp-playing .jp-v-thumb img {
  display: none;
}
 
/* Responsive */
@media (max-width: 640px) {
  .jp-videos-grid {
    grid-template-columns: 1fr;
  }
  .jp-videos-heading {
    font-size: 22px;
  }
}
</style>/* End custom CSS */