.elementor-3591 .elementor-element.elementor-element-e414bfc{--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;--gap:48px 48px;--row-gap:48px;--column-gap:48px;--padding-top:80px;--padding-bottom:80px;--padding-left:48px;--padding-right:48px;}.elementor-widget-button .elementor-button{background-color:var( --e-global-color-accent );font-family:var( --e-global-typography-accent-font-family ), Sans-serif;font-weight:var( --e-global-typography-accent-font-weight );}.elementor-3591 .elementor-element.elementor-element-0bcb0c6 .elementor-button{padding:18px 36px 18px 36px;}body.elementor-page-3591:not(.elementor-motion-effects-element-type-background), body.elementor-page-3591 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#E8E3D9;}@media(min-width:768px){.elementor-3591 .elementor-element.elementor-element-e414bfc{--content-width:1200px;}}@media(max-width:1024px){.elementor-3591 .elementor-element.elementor-element-e414bfc{--gap:30px 30px;--row-gap:30px;--column-gap:30px;--padding-top:40px;--padding-bottom:40px;--padding-left:34px;--padding-right:34px;}}@media(max-width:767px){.elementor-3591 .elementor-element.elementor-element-e414bfc{--gap:20px 20px;--row-gap:20px;--column-gap:20px;--padding-top:30px;--padding-bottom:30px;--padding-left:25px;--padding-right:25px;}}/* Start custom CSS for shortcode, class: .elementor-element-258688b */.cat-inner {
    max-width: 1200px;
    margin: 0 auto;
}

.cat-top {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    margin-bottom: 40px;
    gap: 24px;
    flex-wrap: wrap;
}

.cat-lbl {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: #2d56c8;
    margin-bottom: 8px;
}

.cat-lbl::before {
    content: '';
    width: 14px;
    height: 2px;
    background: #2d56c8;
}

.cat-h {
    font-family: 'Bebas Neue', sans-serif;
    font-size: clamp(32px, 4.5vw, 62px);
    font-weight: 600;
    letter-spacing: .04em;
    color: #0d1f4e;
    line-height: .9;
}

.cat-count {
    font-size: 14px;
    color: #0d1f4e;
    opacity: .45;
    margin-top: 8px;
}

.filter-bar {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    margin-bottom: 32px;
}

.fbtn {
    font-size: 9px;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    border: 1px solid #0d1f4e21;
    background: transparent;
    cursor: pointer;
    color: rgba(13, 31, 78, .5);
    padding: 7px 14px;
    border-radius: 4px;
    transition: all .18s;
    white-space: nowrap;
}

.fbtn:hover {
    border-color: #2d56c8;
    color: #2d56c8;
}

.fbtn.active {
    background: #0d1f4e;
    color: #e8e3d9;
    border-color: #0d1f4e;
}

.meme-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}

.mcard {
    position: relative;
    border-radius: 10px;
    overflow: hidden;
    cursor: pointer;
    background: var(--dark);
    transition: transform .28s cubic-bezier(.34, 1.56, .64, 1);
}

.mcard:hover {
    transform: scale(1.03);
}

.mcard:hover .mc-overlay {
    opacity: 1;
}

.mcard:hover .mc-img-inner {
    transform: scale(1.05);
    filter: brightness(.5);
}

.mcard.tall {
    grid-row: span 2;
}

.mc-img2 {
    position: relative;
    overflow: hidden;
}

.mc-img-inner {
    width: 100%;
    aspect-ratio: 4/3;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
    transition: transform .4s ease, filter .4s ease;
}

.mcard.tall .mc-img-inner {
    aspect-ratio: 4/5;
}

.mc-emoji2 {
    font-size: 32px;
    line-height: 1;
}

.mc-meme-txt {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 11px;
    letter-spacing: .05em;
    color: rgba(232, 227, 217, .5);
    text-align: center;
    padding: 0 10px;
    line-height: 1.3;
}

.mc-grad {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(5, 14, 40, .92) 0%, transparent 55%);
    pointer-events: none;
}

.mc-info {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 9px 12px 11px;
    z-index: 2;
}

.mc-cat2 {
    display: inline-block;
    background: var(--blue);
    color: #fff;
    font-size: 6px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    padding: 2px 6px;
    border-radius: 2px;
    margin-bottom: 5px;
}

.mc-name2 {
    font-family: 'Bebas Neue', sans-serif;
    font-size: clamp(12px, 1vw, 16px);
    letter-spacing: .04em;
    color: var(--cream);
    line-height: 1;
    margin-bottom: 2px;
}

.mc-uses2 {
    font-size: 7px;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: rgba(232, 227, 217, .38);
}

.mc-overlay {
    position: absolute;
    inset: 0;
    z-index: 3;
    background: rgba(45, 86, 200, .15);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    opacity: 0;
    transition: opacity .28s ease;
}

.mc-overlay-btn {
    font-size: 8px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    background: var(--blue);
    color: #fff;
    border: none;
    cursor: pointer;
    padding: 9px 18px;
    border-radius: 3px;
    transition: background .2s;
}

.mc-overlay-btn:hover {
    background: #3d66d8;
}

.mc-overlay-ghost {
    font-size: 8px;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: rgba(232, 227, 217, .7);
    border: 1px solid rgba(232, 227, 217, .25);
    background: none;
    cursor: pointer;
    padding: 8px 16px;
    border-radius: 3px;
}

.cat-cta {
    text-align: center;
    margin-top: 48px;
}

.cat-cta-btn {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    background: var(--blue);
    color: #fff;
    font-family: 'DM Sans', sans-serif;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    padding: 18px 36px;
    border-radius: 4px;
    border: none;
    cursor: pointer;
    text-decoration: none;
    transition: background .2s, gap .2s;
}

.cat-cta-btn:hover {
    background: #3d66d8;
    gap: 18px;
}


.meme-card {
    position: relative;
    aspect-ratio: 4 / 5;
    border-radius: 16px;
    overflow: hidden;
    cursor: pointer;
    box-shadow: 0 2px 12px rgba(0,0,0,.08);
    transition: transform .3s ease, box-shadow .3s ease;
    background-size: cover;
    background-position: center;
    
}
.meme-card:hover .meme-overlay {
    opacity: 1;
}

.meme-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,.85) 0%, rgba(0,0,0,.3) 50%, transparent 100%);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 24px;
    opacity: 0;
    transition: opacity .3s ease;
}

.meme-overlay .meme-title {
    color: #fff;
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 4px;
}
.meme-overlay .meme-meta {
    color: #ffffffaa;
    font-size: 12px;
    font-weight: 500;
    letter-spacing: .5px;
    margin-bottom: 16px;
}
.meme-overlay .btn-license {
    flex: 1;
    padding: 12px 0;
    background: var( --e-global-color-accent );
    color: #fff;
    border: none;
    border-radius: 10px;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    cursor: pointer;
    transition: background .2s;
    text-align: center;
}
.meme-overlay .btn-row {
    display: flex;
    gap: 10px;
}
.meme-overlay .btn-preview {
    padding: 12px 20px;
    background: rgba(255,255,255,.15);
    backdrop-filter: blur(4px);
    color: #fff;
    border: 2px solid rgba(255,255,255,.3);
    border-radius: 10px;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    cursor: pointer;
    transition: background .2s, border-color .2s;
    text-align: center;
}
.meme-overlay .btn-preview:hover {
    background: rgba(255,255,255,.25);
    border-color: #fff;
}

  
  
  
@media only screen and (max-width: 1024px) {
.meme-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
}
}

@media only screen and (max-width: 767px) {
.meme-grid {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 10px;
}
.cat-top {
    margin-bottom: 20px;
}
.filter-bar {
    margin-bottom: 20px;
}
}/* End custom CSS */
/* Start custom CSS *//* ── LIGHTBOX (Preview) ── */
  .lightbox {
    position: fixed;
    inset: 0;
    z-index: 999;
    background: rgba(0,0,0,.8);
    backdrop-filter: blur(8px);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity .3s ease;
  }
  .lightbox.active {
    opacity: 1;
    pointer-events: auto;
  }
  .lightbox-content {
    background: #fff;
    border-radius: 24px;
    overflow: hidden;
    max-width: 600px;
    width: 90%;
    transform: scale(.9);
    transition: transform .3s ease;
    box-shadow: 0 32px 80px rgba(0,0,0,.3);
  }
  .lightbox.active .lightbox-content {
    transform: scale(1);
  }
  .lightbox-img {
    width: 100%;
    aspect-ratio: 4 / 5;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 140px;
    user-select: none;
  }
  .lightbox-info {
    padding: 28px 32px;
  }
  .lightbox-info h2 {
    font-size: 24px;
    font-weight: 800;
    margin-bottom: 4px;
  }
  .lightbox-info .lb-meta {
    font-size: 13px;
    color: #888;
    margin-bottom: 20px;
  }
  .lightbox-info .btn-license-lg {
    display: block;
    width: 100%;
    padding: 16px;
    background: #2D56C8 ;
    color: #fff;
    border: none;
    border-radius: 12px;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    cursor: pointer;
    transition: background .2s;
    text-align: center;
  }

  .lightbox-close {
    position: absolute;
    top: 20px;
    right: 24px;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: rgba(255,255,255,.15);
    border: none;
    color: #fff;
    font-size: 22px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .2s;
  }
  
  .lightbox-close:hover { background: rgba(255,255,255,.3); 
  }/* End custom CSS */