/* ============================================================
   MAGEMBED GRID ENGINE — Frontend CSS v2.0.0
   Variables are injected inline per-layout via wp_add_inline_style.
   ============================================================ */

/* ── GOOGLE FONTS PRECONNECT ─────────────────────────────── */
/* Fredoka, Inter, Oswald, Bebas Neue — loaded via PHP enqueue */

/* ── CSS CUSTOM PROPERTY FALLBACKS ──────────────────────── */
.mgb-wrap {
    --mgb-cols-d:    4;
    --mgb-cols-t:    3;
    --mgb-cols-m:    2;
    --mgb-gap:       8px;
    --mgb-radius:    10px;
    --mgb-ratio:     4 / 3;
    --mgb-bw:        0px;
    --mgb-bc:        #2A2A3D;
    --mgb-htc:       #ffffff;
    --mgb-hbg:       rgba(0,0,0,0.70);
    --mgb-hblur:     0px;
    --mgb-hsize:     16px;
    --mgb-hweight:   700;
    --mgb-halign:    left;
    --mgb-hfont:     'Fredoka', sans-serif;
    --mgb-hpos:      bottom;
    --mgb-tvalign:   flex-end;
    --mgb-thalign:   flex-start;
    --mgb-accent:    #C800A1;
    --mgb-cyan:      #00C8C8;
}

/* ── SECTION (homepage category rows) ───────────────────── */
.mgb-section          { margin-bottom: 40px; }
.mgb-section__hd      { display:flex; align-items:baseline; justify-content:space-between;
                         margin-bottom:14px; padding-bottom:10px; border-bottom:1px solid #1E1E2E; }
.mgb-section__title   { font-size:clamp(17px,2.4vw,24px); font-weight:800; color:#fff; margin:0; }
.mgb-section__more    { font-size:13px; color:var(--mgb-accent); text-decoration:none; white-space:nowrap; }
.mgb-section__more:hover { color:var(--mgb-cyan); }

/* ── GRID ────────────────────────────────────────────────── */
.mgb-grid {
    display: grid;
    grid-template-columns: repeat(var(--mgb-cols-d), 1fr);
    gap: var(--mgb-gap);
    list-style: none;
    margin: 0;
    padding: 0;
}
@media (max-width:1024px) {
    .mgb-grid { grid-template-columns: repeat(var(--mgb-cols-t), 1fr); }
}
@media (max-width:640px) {
    .mgb-grid { grid-template-columns: repeat(var(--mgb-cols-m), 1fr); gap: calc(var(--mgb-gap) * 0.75); }
}

/* ── CARD BASE ───────────────────────────────────────────── */
.mgb-card {
    position: relative;
    border-radius: var(--mgb-radius);
    overflow: hidden;
    background: #141420;
    border: var(--mgb-bw) solid var(--mgb-bc);
    display: block;
    transition: transform .22s ease, box-shadow .22s ease;
    cursor: pointer;
}
.mgb-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0,0,0,.45);
}
/* Border effects */
.mgb-wrap[data-layout] .mgb-card[style*="border-effect:neon"],
.mgb-slot--glow { box-shadow: 0 0 0 2px var(--mgb-accent), 0 0 16px rgba(200,0,161,.35); }
.mgb-slot--pulse { animation: mgb-pulse 2.4s ease-in-out infinite; }
@keyframes mgb-pulse {
    0%,100% { box-shadow: 0 0 0 2px var(--mgb-accent); }
    50%      { box-shadow: 0 0 0 3px var(--mgb-accent), 0 0 20px rgba(200,0,161,.5); }
}

.mgb-card__link {
    display: block;
    text-decoration: none;
    color: inherit;
    outline: none;
    height: 100%;
}
.mgb-card__link:focus-visible {
    outline: 2px solid var(--mgb-accent);
    outline-offset: 2px;
}

/* ── CARD MEDIA — ratio controlled by --mgb-ratio per layout */
.mgb-card__media {
    position: relative;
    width: 100%;
    aspect-ratio: var(--mgb-ratio, 4 / 3);
    overflow: hidden;
    background: #0B0B12;
}
.mgb-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .3s ease;
}
.mgb-card__placeholder {
    width: 100%;
    height: 100%;
    display: block;
}

/* ── OVERLAY (always rendered, visibility controlled by hover effect) */
.mgb-card__overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: var(--mgb-tvalign, flex-end);
    justify-content: var(--mgb-thalign, flex-start);
    padding: 10px 12px;
    background: var(--mgb-hbg);
    backdrop-filter: blur(var(--mgb-hblur));
    -webkit-backdrop-filter: blur(var(--mgb-hblur));
    opacity: 0;
    transition: opacity .22s ease, transform .22s ease;
    pointer-events: none;
}
/* Hover positions (overlay entrance direction) */
.mgb-hpos--bottom .mgb-card__overlay { transform:translateY(6px); }
.mgb-hpos--center .mgb-card__overlay { transform:scale(.96); }
.mgb-hpos--top    .mgb-card__overlay { transform:translateY(-6px); }

.mgb-card__title {
    font-family:   var(--mgb-hfont) !important;
    font-size:     var(--mgb-hsize);
    font-weight:   var(--mgb-hweight);
    color:         var(--mgb-htc);
    text-align:    var(--mgb-halign);
    line-height:   1.25;
    display:       block;
    max-width:     100%;
    word-break:    break-word;
}

/* ── HOVER EFFECTS ───────────────────────────────────────── */

/* title_slide — Magbei Classic:
 * A riposo: overlay e titolo completamente nascosti, solo thumb visibile.
 * Hover: overlay sale dal basso fino al 45% dell'altezza, opaco, clip-path obliquo.
 */
.mgb-hover--title_slide .mgb-card__overlay {
    inset: unset;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 45%;
    align-items: var(--mgb-tvalign, flex-end);
    justify-content: var(--mgb-thalign, flex-start);
    clip-path: polygon(0 20%, 100% 0%, 100% 100%, 0 100%);
    opacity: 0;
    transform: translateY(100%);
    transition: opacity .12s ease-out, transform .15s ease-out;
    backdrop-filter: blur(var(--mgb-hblur, 0px));
    -webkit-backdrop-filter: blur(var(--mgb-hblur, 0px));
    padding: var(--mgb-hpadv, 10px) var(--mgb-hpadh, 12px);
    pointer-events: none;
}
.mgb-hover--title_slide .mgb-card:hover .mgb-card__overlay,
.mgb-hover--title_slide .mgb-card:focus-within .mgb-card__overlay {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}
.mgb-hover--title_slide .mgb-card__overlay .mgb-card__title {
    color: var(--mgb-htc, #fff);
}

/* overlay — full fade in */
.mgb-hover--overlay .mgb-card__overlay {
    transform: none;
}
.mgb-hover--overlay .mgb-card:hover .mgb-card__overlay,
.mgb-hover--overlay .mgb-card:focus-within .mgb-card__overlay {
    opacity: 1;
}

/* zoom_title — zoom image + show title */
.mgb-hover--zoom_title .mgb-card:hover .mgb-card__img,
.mgb-hover--zoom_title .mgb-card:focus-within .mgb-card__img { transform: scale(1.07); }
.mgb-hover--zoom_title .mgb-card:hover .mgb-card__overlay,
.mgb-hover--zoom_title .mgb-card:focus-within .mgb-card__overlay { opacity:1; transform:none; }

/* zoom — zoom only, no text */
.mgb-hover--zoom .mgb-card__overlay { display:none; }
.mgb-hover--zoom .mgb-card:hover .mgb-card__img,
.mgb-hover--zoom .mgb-card:focus-within .mgb-card__img { transform: scale(1.08); }
.mgb-hover--zoom .mgb-card:hover { transform: none; }

/* none — static */
.mgb-hover--none .mgb-card__overlay { display:none; }
.mgb-hover--none .mgb-card:hover    { transform:none; box-shadow:none; }

/* ── FEATURED SLOT ───────────────────────────────────────── */
.mgb-slot .mgb-card__media {
    height: 100%;
    aspect-ratio: unset;
}
.mgb-slot .mgb-card__img { height:100%; object-fit:cover; }
.mgb-slot__badge {
    position: absolute;
    top: 8px; left: 8px; z-index:10;
    background: var(--mgb-accent); color:#fff;
    font-size:11px; font-weight:700;
    padding:3px 9px; border-radius:3px;
    text-transform:uppercase; letter-spacing:.5px;
    pointer-events:none;
}

/* ── FILTER BAR ──────────────────────────────────────────── */
.mgb-filterbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 14px;
    margin-bottom: 18px;
    padding-bottom: 14px;
    border-bottom: 1px solid #1E1E2E;
}
.mgb-filterbar__group {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}
.mgb-filterbar__lbl {
    font-size: 11px;
    color: #555;
    white-space: nowrap;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
}
.mgb-filterbar__btn {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 14px;
    border: 1px solid #252535;
    border-radius: 20px;
    color: #888;
    text-decoration: none;
    font-size: 13px;
    font-weight: 500;
    transition: all .18s ease;
    white-space: nowrap;
    background: transparent;
    cursor: pointer;
}
.mgb-filterbar__btn:hover { border-color:var(--mgb-accent); color:#fff; }
.mgb-filterbar__btn.is-active {
    background: var(--mgb-accent);
    border-color: var(--mgb-accent);
    color: #fff;
    box-shadow: 0 0 10px rgba(200,0,161,.3);
}
.mgb-filterbar__sel {
    appearance: none;
    background: #14141e url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23666'/%3E%3C/svg%3E") no-repeat right 10px center;
    border: 1px solid #252535;
    border-radius: 4px;
    color: #ccc;
    font-size: 13px;
    padding: 5px 28px 5px 10px;
    cursor: pointer;
    min-width: 130px;
    transition: border-color .18s;
}
.mgb-filterbar__sel:focus { border-color:var(--mgb-accent); outline:none; }
.mgb-filterbar__search {
    background: #14141e;
    border: 1px solid #252535;
    border-radius: 4px;
    color: #ccc;
    font-size: 13px;
    padding: 5px 12px;
    min-width: 160px;
    transition: border-color .18s;
}
.mgb-filterbar__search:focus { border-color:var(--mgb-accent); outline:none; }

/* Mobile filter bar — horizontal scroll */
@media (max-width:640px) {
    .mgb-filterbar { flex-wrap:nowrap; overflow-x:auto; -webkit-overflow-scrolling:touch;
                     scrollbar-width:none; padding-bottom:8px; }
    .mgb-filterbar::-webkit-scrollbar { display:none; }
    .mgb-filterbar__group { flex-wrap:nowrap; }
    .mgb-filterbar__lbl   { display:none; }
}

/* ── LOAD MORE ───────────────────────────────────────────── */
.mgb-lm-wrap  { text-align:center; margin-top:28px; margin-bottom:32px; }
.mgb-lm-btn {
    display: inline-block;
    padding: 12px 40px;
    background: transparent;
    border: 2px solid var(--mgb-accent);
    border-radius: 6px;
    color: var(--mgb-accent);
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: all .2s ease;
    letter-spacing: .2px;
}
.mgb-lm-btn:hover { background:var(--mgb-accent); color:#fff; box-shadow:0 0 18px rgba(200,0,161,.3); }
.mgb-lm-btn.is-loading { opacity:.5; pointer-events:none; }
.mgb-lm-btn.is-done    {
    opacity: .5;
    pointer-events: none;
    cursor: default;
    border-style: dashed;
    font-size: 12px !important;
    letter-spacing: .3px;
}

/* ── EMPTY STATE ─────────────────────────────────────────── */
.mgb-empty {
    text-align:center; color:#555; font-size:15px;
    font-style:italic; padding:36px 20px;
    grid-column:1/-1;
}

/* ── PAGINATION ──────────────────────────────────────────── */
.mgb-pagination { margin-top:28px; }
.mgb-pagination .page-numbers {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 5px;
    list-style: none;
    padding: 0; margin: 0;
    justify-content: center;
}
.mgb-pagination .page-numbers li { display:contents; }
.mgb-pagination .page-numbers a,
.mgb-pagination .page-numbers span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 36px; height:36px;
    padding: 0 9px;
    border: 1px solid #252535;
    border-radius: 4px;
    color: #888;
    text-decoration: none;
    font-size: 14px;
    transition: all .18s;
}
.mgb-pagination .page-numbers a:hover { border-color:var(--mgb-accent); color:#fff; }
.mgb-pagination .page-numbers .current {
    background:var(--mgb-accent); border-color:var(--mgb-accent); color:#fff;
}
.mgb-pagination .page-numbers .dots { border-color:transparent; }

/* ── ARCHIVE HERO ────────────────────────────────────────── */
.mgb-archive-hero  { margin-bottom:20px; }
.mgb-archive-title {
    font-size: clamp(20px, 4vw, var(--mgb-arc-title-size, 38px));
    font-weight: var(--mgb-arc-title-weight, 800);
    color: var(--mgb-arc-title-color, #fff);
    font-family: var(--mgb-arc-title-font, 'Fredoka', sans-serif);
    margin: 0 0 4px;
}
.mgb-archive-count {
    font-size: var(--mgb-arc-count-size, 13px);
    color: var(--mgb-arc-count-color, #555);
    margin: 0;
}

/* ── REDUCED MOTION ──────────────────────────────────────── */
@media (prefers-reduced-motion:reduce) {
    .mgb-card, .mgb-card__img, .mgb-card__overlay,
    .mgb-filterbar__btn, .mgb-lm-btn { transition:none !important; animation:none !important; }
}

/* ============================================================
   v2.2.0 ADDITIONS
   ============================================================ */

/* ── HOVER BG FULL vs TIGHT ──────────────────────────────── */
/* Full = overlay fills entire card (default) */
.mgb-card__overlay {
    padding: var(--mgb-hpadv, 10px) var(--mgb-hpadh, 12px);
}

/* Tight = overlay wraps only around the title text */
.mgb-wrap[style*="--mgb-hbgfull:tight"] .mgb-card__overlay,
.mgb-wrap .mgb-card__overlay.is-tight {
    background: transparent !important;
}
.mgb-wrap[style*="--mgb-hbgfull:tight"] .mgb-card__title {
    background: var(--mgb-hbg);
    backdrop-filter: blur(var(--mgb-hblur));
    -webkit-backdrop-filter: blur(var(--mgb-hblur));
    border-radius: 4px;
    padding: var(--mgb-hpadv, 4px) var(--mgb-hpadh, 8px);
    display: inline-block;
}

/* CSS custom property toggle for hover_bg_full */
.mgb-wrap { --mgb-hbgfull: full; }

/* When tight, make overlay transparent, title gets its own bg */
.mgb-card__overlay[data-bgfull="tight"] {
    background: transparent !important;
    backdrop-filter: none !important;
}
.mgb-card__overlay[data-bgfull="tight"] .mgb-card__title {
    background: var(--mgb-hbg);
    padding: var(--mgb-hpadv, 4px) var(--mgb-hpadh, 8px);
    border-radius: 4px;
    display: inline-block;
}

/* ── LOAD MORE BUTTON — CSS var driven ───────────────────── */
.mgb-lm-btn {
    border-color:   var(--mgb-lm-bc,  #C800A1) !important;
    color:          var(--mgb-lm-tc,  #C800A1) !important;
    border-radius:  var(--mgb-lm-r,   6px)     !important;
    font-size:      var(--mgb-lm-fs,  15px)    !important;
    padding:        var(--mgb-lm-pv,  12px) var(--mgb-lm-ph, 40px) !important;
    background:     transparent;
    border-width:   2px;
    border-style:   solid;
    transition:     all .2s ease;
    font-weight:    600;
    cursor:         pointer;
    letter-spacing: .2px;
}
.mgb-lm-btn:hover {
    background: var(--mgb-lm-hbg,  #C800A1) !important;
    color:      var(--mgb-lm-htc,  #ffffff) !important;
    box-shadow: 0 0 18px rgba(200,0,161,.3);
}

/* Alignment helpers */
.mgb-lm-wrap.mgb-lm--left   { text-align: left; }
.mgb-lm-wrap.mgb-lm--center { text-align: center; }
.mgb-lm-wrap.mgb-lm--right  { text-align: right; }

/* ── PAGINATION — CSS var driven ─────────────────────────── */
.mgb-pagination .page-numbers a,
.mgb-pagination .page-numbers span {
    border-color:  var(--mgb-lm-bc,  #252535);
    color:         var(--mgb-lm-tc,  #888);
    border-radius: var(--mgb-lm-r,   4px);
    font-size:     var(--mgb-lm-fs,  14px);
    padding:       0 var(--mgb-lm-ph, 9px);
    height:        calc(var(--mgb-lm-pv, 12px) * 2 + 1em);
    border-width:  1px;
    border-style:  solid;
}
.mgb-pagination .page-numbers a:hover {
    border-color:  var(--mgb-lm-hbg, #C800A1);
    background:    var(--mgb-lm-hbg, transparent);
    color:         var(--mgb-lm-htc, #fff);
}
.mgb-pagination .page-numbers .current {
    background:    var(--mgb-lm-hbg, #C800A1) !important;
    border-color:  var(--mgb-lm-hbg, #C800A1) !important;
    color:         var(--mgb-lm-htc, #fff)    !important;
}

/* Alignment for pagination */
.mgb-pagination { text-align: center; }
