/* ================================================================
   FEF LOOP WIDGET v3
   ================================================================ */
.fef-lp-grid{display:grid;grid-template-columns:repeat(var(--lp-cols,3),1fr);gap:var(--lp-gap,16px)}
.fef-lp-list{display:flex;flex-direction:column;gap:var(--lp-gap,16px)}
.fef-lp-box{background:#fff;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .25s,transform .25s,background .25s,border-color .25s}
.fef-lp-box:hover{box-shadow:0 2px 12px rgba(0,0,0,.06)}

/* ── Box hover effect presets ──
   The wrapper (.fef-lp-wrap / .fef-lp-slider-wrap) carries the chosen
   fef-lp-hover-{effect} class; --fef-hover-amt is set by the Strength
   control via Elementor's inline {{WRAPPER}}-scoped stylesheet. Grow/
   Shrink use a unitless ratio (e.g. 0.06 for a 6% scale change) — scale()
   requires a unitless number, so the PHP control sends a plain number for
   those two effects specifically, not a px value. Lift/Sink use a px
   length; Tilt uses degrees. */
.fef-lp-hover-grow .fef-lp-box{--fef-hover-amt:6}
.fef-lp-hover-grow .fef-lp-box:hover{transform:scale(calc(1 + var(--fef-hover-amt) / 100))}
.fef-lp-hover-shrink .fef-lp-box{--fef-hover-amt:6}
.fef-lp-hover-shrink .fef-lp-box:hover{transform:scale(calc(1 - var(--fef-hover-amt) / 100))}
.fef-lp-hover-lift .fef-lp-box{--fef-hover-amt:6}
.fef-lp-hover-lift .fef-lp-box:hover{transform:translateY(calc(var(--fef-hover-amt) * -1px))}
.fef-lp-hover-sink .fef-lp-box{--fef-hover-amt:6}
.fef-lp-hover-sink .fef-lp-box:hover{transform:translateY(calc(var(--fef-hover-amt) * 1px))}
.fef-lp-hover-tilt .fef-lp-box{--fef-hover-amt:6}
.fef-lp-hover-tilt .fef-lp-box:hover{transform:rotate(calc(var(--fef-hover-amt) * 1deg))}

/* Force the box's direct content (template output, list-item markup, etc.)
   to fill the box's full width and never shrink below it. Without this,
   a flex child with no explicit width can shrink to its own intrinsic
   content size — this is what was happening with slider items rendering
   smaller than their allotted slot. min-width:0 additionally allows the
   child to be sized down to the parent's width even if its own content
   would otherwise demand more (e.g. unbroken text/wide elements). */
.fef-lp-box>*{width:100%;flex:1 1 auto;min-width:0;box-sizing:border-box}
.fef-lp-header{display:flex;align-items:center;gap:10px;padding:10px 16px;background:#2e7d32;color:#fff;position:relative;overflow:hidden}
.fef-lp-header-link{display:flex;align-items:center;gap:10px;color:inherit;text-decoration:none;width:100%;transition:opacity .15s}
.fef-lp-header-link:hover{opacity:.92}
.fef-lp-header-text{flex:1;font-weight:700;font-size:15px;line-height:1.35}
.fef-lp-header-icon{font-size:18px;opacity:.9;flex-shrink:0}
.fef-lp-header-img{width:22px;height:22px;border-radius:4px;object-fit:cover;flex-shrink:0}
.fef-lp-header-gradient{position:absolute;left:0;top:0;width:5px;height:100%}
.fef-lp-header-arrow{font-size:16px;opacity:.65;flex-shrink:0;transition:opacity .2s,transform .2s}
.fef-lp-header:hover .fef-lp-header-arrow{opacity:1;transform:translateX(2px)}
.fef-lp-header-count{background:rgba(255,255,255,.2);padding:1px 8px;border-radius:10px;font-size:12px;font-weight:600;flex-shrink:0}
.fef-lp-body{flex:1;display:flex;flex-direction:column}
.fef-lp-item{padding:5px 16px;font-size:14px;line-height:1.55;color:#333;display:flex;align-items:center;gap:6px;transition:color .15s,background .15s}
.fef-lp-item:hover{color:#1565c0}
.fef-lp-item a{color:inherit;text-decoration:none;flex:1}
.fef-lp-item a:hover{text-decoration:none}
.fef-lp-item-l2{color:#555}.fef-lp-item-l3{color:#777;font-size:13px}
.fef-lp-term-img{width:28px;height:28px;border-radius:4px;object-fit:cover;flex-shrink:0}
.fef-lp-flat-item{padding:0;flex-direction:column;align-items:stretch;gap:0}
.fef-lp-post-img{width:100%;height:120px;background-size:cover;background-position:center}
.fef-lp-item-content{padding:10px 14px}
.fef-lp-item-title{font-weight:600;font-size:14px;display:block;line-height:1.4}
.fef-lp-item-title-link{color:inherit;text-decoration:none}
.fef-lp-item-title-link:hover{color:#1565c0}
.fef-lp-item-excerpt{font-size:13px;color:#777;margin-top:4px;line-height:1.5}
.fef-lp-item-meta-row{display:flex;gap:12px;margin-top:6px;font-size:12px;color:#999}
.fef-lp-item-meta-row i{margin-right:3px}
.fef-lp-item-metas{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.fef-lp-item-meta{font-size:12px;color:#999;background:#f5f5f5;padding:2px 8px;border-radius:4px}

/* No-image view */
.fef-lp-noimage .fef-lp-post-img{display:none!important}
.fef-lp-wrap.noimage{display:flex;flex-direction:column;gap:var(--lp-gap,16px)}
.fef-lp-wrap.noimage .fef-lp-flat-item{flex-direction:row;align-items:center}
.fef-lp-wrap.noimage .fef-lp-item-content{padding:8px 14px}
.fef-lp-noimage .fef-lp-post-img{display:none}

/* Masonry */
.fef-lp-masonry{display:block;column-count:var(--lp-cols,3);column-gap:var(--lp-gap,16px)}
.fef-lp-masonry>.fef-lp-box,.fef-lp-masonry>.fef-lp-flat-item{break-inside:avoid;margin-bottom:var(--lp-gap,16px)}

/* Equal height */
.fef-lp-equal-h{align-items:stretch}
.fef-lp-equal-h>.fef-lp-box,.fef-lp-equal-h>.fef-lp-flat-item{display:flex;flex-direction:column}
.fef-lp-equal-h .fef-lp-item-content{flex:1}

/* Lazy load */
.fef-lp-lazy .fef-lp-post-img{opacity:0;transition:opacity .4s}
.fef-lp-lazy .fef-lp-post-img.loaded{opacity:1}
.fef-lp-count{font-size:13px;color:#999;font-weight:400;margin-left:4px;flex-shrink:0}
.fef-lp-count-badge{background:#e0e0e0;color:#333;padding:1px 8px;border-radius:10px;font-size:11px;font-weight:600;line-height:1.5}
.fef-lp-hidden{display:none}
.fef-lp-showmore{display:flex;align-items:center;justify-content:center;gap:6px;padding:6px 16px;margin:4px 12px;background:#f5f5f5;border:1px solid #e0e0e0;border-radius:4px;color:#333;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}
.fef-lp-showmore:hover{background:#e8e8e8}
.fef-lp-showmore i{font-size:10px;transition:transform .3s}
.fef-lp-showmore[data-collapsed="0"] i{transform:rotate(180deg)}
.fef-lp-total{font-size:13px;color:#666;margin-bottom:10px;font-weight:500}
.fef-lp-empty{text-align:center;color:#94a3b8;padding:30px;font-size:14px}
.fef-lp-pagination{display:flex;justify-content:center;gap:6px;margin-top:20px;padding:10px 0}
.fef-lp-pg{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:34px;padding:0 10px;background:#f5f5f5;border:1px solid #ddd;border-radius:6px;color:#333;font-size:13px;font-weight:500;text-decoration:none;transition:all .2s}
.fef-lp-pg:hover{background:#e0e0e0}
.fef-lp-pg.active{background:#2e7d32;color:#fff;border-color:#2e7d32}
.fef-lp-injected{position:relative;border:2px solid #ffd54f;background:#fffde7}
.fef-lp-inject-badge{position:absolute;top:6px;right:6px;background:#ff9800;color:#fff;font-size:10px;font-weight:700;padding:2px 8px;border-radius:4px;z-index:2;text-transform:uppercase;letter-spacing:.5px}
/* Slider */
.fef-lp-slider-wrap{position:relative;width:100%;overflow:hidden}
.fef-lp-slider-viewport{overflow:hidden;width:100%}
.fef-lp-slider-track{display:flex;will-change:transform}
.fef-lp-slider-track>.fef-lp-box{flex:0 0 auto;min-width:0;box-sizing:border-box}
.fef-lp-sl-arrow.fef-lp-sl-disabled{opacity:.35;cursor:default;pointer-events:none}
.fef-lp-sl-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:38px;height:38px;border-radius:50%;background:rgba(0,0,0,.06);border:1px solid rgba(0,0,0,.1);color:#333;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}
.fef-lp-sl-arrow:hover{background:rgba(0,0,0,.12)}
.fef-lp-sl-prev{left:8px}.fef-lp-sl-next{right:8px}
.fef-lp-sl-dots{display:flex;justify-content:center;gap:6px;margin-top:14px}
.fef-lp-sl-dot{width:8px;height:8px;border-radius:50px;background:rgba(0,0,0,.15);cursor:pointer;transition:all .3s}
.fef-lp-sl-dot.active{background:#2e7d32;width:20px}

/* ── Arrow placement presets ──
   DOM order is always: [viewport] [prev arrow] [next arrow] [dots].
   For non-default placements, .fef-lp-slider-wrap becomes a wrapping flex
   row. The viewport and dots get flex-basis:100% so they always start
   their own line — this leaves the two arrow buttons (no forced basis)
   sharing a line together, positioned above or below the viewport via
   `order` (top placements: order 1, before the viewport's order 2;
   bottom placements: order 3, after it). justify-content on the wrap
   then aligns that shared arrow-pair line as a whole: left/center/right. */
.fef-lp-slider-wrap[class*="fef-lp-arrows-"]{display:flex;flex-flow:row wrap}
.fef-lp-slider-wrap[class*="fef-lp-arrows-"] .fef-lp-slider-viewport{order:2;flex-basis:100%;width:100%}
.fef-lp-slider-wrap[class*="fef-lp-arrows-"] .fef-lp-sl-dots{order:4;flex-basis:100%}
.fef-lp-slider-wrap[class*="fef-lp-arrows-"] .fef-lp-sl-arrow{position:static;top:auto;left:auto;right:auto;transform:none;margin:0}

/* Top placements: arrows (order:1) before the viewport (order:2). */
.fef-lp-arrows-top-left .fef-lp-sl-prev,.fef-lp-arrows-top-center .fef-lp-sl-prev,.fef-lp-arrows-top-right .fef-lp-sl-prev,
.fef-lp-arrows-top-left .fef-lp-sl-next,.fef-lp-arrows-top-center .fef-lp-sl-next,.fef-lp-arrows-top-right .fef-lp-sl-next{order:1}

/* Bottom placements: arrows (order:3) after the viewport (order:2). */
.fef-lp-arrows-bottom-left .fef-lp-sl-prev,.fef-lp-arrows-bottom-center .fef-lp-sl-prev,.fef-lp-arrows-bottom-right .fef-lp-sl-prev,
.fef-lp-arrows-bottom-left .fef-lp-sl-next,.fef-lp-arrows-bottom-center .fef-lp-sl-next,.fef-lp-arrows-bottom-right .fef-lp-sl-next{order:3}

/* Pair alignment: left / center / right. */
.fef-lp-arrows-top-left,.fef-lp-arrows-bottom-left{justify-content:flex-start}
.fef-lp-arrows-top-center,.fef-lp-arrows-bottom-center{justify-content:center}
.fef-lp-arrows-top-right,.fef-lp-arrows-bottom-right{justify-content:flex-end}
.fef-lp-slider-wrap[class*="fef-lp-arrows-"] .fef-lp-sl-prev{margin-right:8px}

/* Hover animations */
.fef-lp-sl-anim-grow:hover{transform:scale(1.12)}
.fef-lp-slider-wrap[class*="fef-lp-arrows-"] .fef-lp-sl-anim-grow:hover{transform:scale(1.12)}
.fef-lp-sl-anim-move-left:hover{transform:translate(-4px,-50%)}
.fef-lp-slider-wrap[class*="fef-lp-arrows-"] .fef-lp-sl-anim-move-left:hover{transform:translateX(-4px)}
.fef-lp-sl-anim-move-right:hover{transform:translate(4px,-50%)}
.fef-lp-slider-wrap[class*="fef-lp-arrows-"] .fef-lp-sl-anim-move-right:hover{transform:translateX(4px)}
.fef-lp-sl-anim-pulsate:hover{animation:fefLpPulsate .7s ease-in-out infinite}
@keyframes fefLpPulsate{0%,100%{transform:translateY(-50%) scale(1)}50%{transform:translateY(-50%) scale(1.12)}}
.fef-lp-slider-wrap[class*="fef-lp-arrows-"] .fef-lp-sl-anim-pulsate:hover{animation:fefLpPulsateFlat .7s ease-in-out infinite}
@keyframes fefLpPulsateFlat{0%,100%{transform:scale(1)}50%{transform:scale(1.12)}}

@media(max-width:767px){.fef-lp-sl-arrow{width:32px;height:32px;font-size:12px}}