/*
Theme Name: muchocine21
Theme URI: https://muchocine.net
Author: Muchocine Team
Author URI: https://muchocine.net
Description: Social Cine — Red social cinematográfica. Diseño 21.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: muchocine21
*/

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

/* ─── TOKENS ─── */
:root {
    --green:   #00c9a7;
    --green-d: #00a88d;
    --green-l: #e6faf6;
    --accent2: #00a0e0;
    --accent3: #7c3aed;
    --bg:      #f4f6f8;
    --card:    #ffffff;
    --text:    #1a1a2e;
    --text2:   #6b7280;
    --text3:   #9ca3af;
    --border:  #e5e7eb;
    --f: 'Inter', system-ui, sans-serif;
    --shadow: 0 1px 3px rgba(0,0,0,.06), 0 4px 16px rgba(0,0,0,.06);
    --shadow-lg: 0 8px 32px rgba(0,0,0,.1);
    --r: 16px;
    --r-sm: 10px;
    --eout: cubic-bezier(.16,1,.3,1);
}

/* ─── RESET ─── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
a { text-decoration: none; color: inherit; }
img { display: block; }

/* ─── WRAPPER ─── */
.sn {
    background: var(--bg);
    color: var(--text);
    font-family: var(--f);
    -webkit-font-smoothing: antialiased;
    min-height: 100vh;
}

/* ─── TOP BAR ─── */
.sn-bar {
    position: sticky; top: 0; z-index: 200;
    background: rgba(255,255,255,.92);
    backdrop-filter: blur(16px) saturate(180%);
    -webkit-backdrop-filter: blur(16px) saturate(180%);
    border-bottom: 1px solid var(--border);
    padding: 0 24px;
    height: 60px;
    display: flex; align-items: center; justify-content: space-between;
}
.sn-bar__brand {
    display: flex; align-items: center; gap: 10px;
}
.sn-bar__logo {
    font-size: 1.2rem; font-weight: 800; letter-spacing: -.03em; color: var(--text);
    text-decoration: none;
}
.sn-bar__logo b { color: var(--green); }
.sn-bar__tagline {
    font-size: .68rem; font-weight: 500; color: var(--text3);
    font-style: italic; letter-spacing: .01em; line-height: 1.2;
    max-width: 320px;
}
.sn-bar__actions { display: flex; align-items: center; gap: 12px; }
.sn-bar__btn {
    width: 38px; height: 38px; border-radius: 50%;
    background: var(--bg); border: none; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    font-size: 1rem; transition: background .2s;
    color: var(--text2);
}
.sn-bar__btn:hover { background: var(--green-l); color: var(--green); }
.sn-bar__search {
    display: flex; align-items: center; gap: 8px;
    background: var(--bg); border-radius: 100px;
    padding: 8px 16px; font-size: .85rem; color: var(--text3);
    border: 1px solid var(--border); transition: all .2s;
    cursor: pointer; text-decoration: none;
}
.sn-bar__search:hover { border-color: var(--green); color: var(--text); }
.sn-bar__search input[type="text"],
.sn-bar__search input[type="search"] {
    background: none; border: none; outline: none;
    font-family: var(--f); font-size: .85rem; color: var(--text);
    width: 160px;
}
.sn-bar__login {
    font-size: .82rem; color: var(--text2); padding: 7px 16px;
    border: 1px solid var(--border); border-radius: 100px;
    transition: all .2s; display: flex; align-items: center; gap: 6px;
}
.sn-bar__login:hover { color: var(--text); border-color: var(--text2); }

/* Nav menu – toggle + dropdown */
.sn-bar__menu-wrap { position: relative; }
.sn-bar__toggle {
    display: flex; align-items: center; justify-content: center;
    width: 38px; height: 38px; border-radius: 50%;
    background: var(--bg); border: 1px solid var(--border);
    cursor: pointer; color: var(--text2); transition: all .2s;
}
.sn-bar__toggle:hover { border-color: var(--green); color: var(--green); background: var(--green-l); }
.sn-bar__toggle[aria-expanded="true"] { background: var(--green-l); color: var(--green); border-color: var(--green); }
.sn-bar__toggle-close { display: none; }
.sn-bar__toggle[aria-expanded="true"] .sn-bar__toggle-open { display: none; }
.sn-bar__toggle[aria-expanded="true"] .sn-bar__toggle-close { display: block; }
.sn-bar__nav {
    display: none; position: absolute; top: calc(100% + 10px); left: 0;
    background: var(--card); border: 1px solid var(--border); border-radius: var(--r);
    box-shadow: var(--shadow-lg); padding: 8px; margin: 0;
    list-style: none; min-width: 220px; z-index: 300;
}
.sn-bar__menu-wrap.is-open .sn-bar__nav { display: block; }
.sn-bar__nav li a {
    display: block; font-size: .85rem; font-weight: 500; color: var(--text2);
    padding: 10px 16px; border-radius: var(--r-sm); transition: all .15s;
    white-space: nowrap;
}
.sn-bar__nav li a:hover { background: var(--green-l); color: var(--green); }
.sn-bar__nav li.current-menu-item a { background: var(--green-l); color: var(--green); font-weight: 600; }

/* ─── LAYOUT: sidebar + feed ─── */
.sn-layout {
    width: 100%; margin: 0 auto;
    display: grid;
    grid-template-columns: 22% 1fr 20%;
    gap: clamp(12px, 1.5vw, 24px);
    padding: clamp(12px, 1.5vw, 24px);
    align-items: start;
}
/* Prevent grid blowout from images/content */
.sn-layout > * { min-width: 0; }
.sn-sidebar-left, .sn-sidebar-right { overflow: hidden; }

/* ─── LEFT SIDEBAR ─── */
.sn-sidebar-left { position: sticky; top: 84px; }

/* ─── CARD BASE ─── */
.sn-card { background: var(--card); border-radius: var(--r); box-shadow: var(--shadow); overflow: hidden; }
.sn-card + .sn-card { margin-top: 16px; }
.sn-card__head {
    padding: 16px 20px; display: flex; align-items: center; justify-content: space-between;
    border-bottom: 1px solid var(--border);
}
.sn-card__head h3 { font-size: .82rem; font-weight: 700; color: var(--text); }
.sn-card__head a { font-size: .76rem; color: var(--green); font-weight: 600; transition: opacity .2s; }
.sn-card__head a:hover { opacity: .75; }
.sn-card__label {
    font-size: .68rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
    color: var(--text3); margin-bottom: 12px; display: flex; align-items: center; gap: 6px;
}
.sn-card__label::before {
    content: ''; width: 3px; height: 14px; background: var(--green);
    border-radius: 2px; display: inline-block;
}
.sn-card--pad { padding: 20px; }

/* ─── TAGLINE CINEMATOGRÁFICO ─── */
.sn-tagline {
    background: linear-gradient(135deg, #062b2b 0%, #0a1e33 40%, #1a1230 70%, #0d2a2a 100%);
    border: none;
    position: relative; overflow: hidden;
}
.sn-tagline__inner { padding: 0; position: relative; z-index: 1; }

/* Film reel perforations — top & bottom */
.sn-tagline__reel {
    height: 10px;
    background:
        repeating-linear-gradient(90deg,
            transparent 0px, transparent 4px,
            rgba(255,255,255,.08) 4px, rgba(255,255,255,.08) 14px,
            transparent 14px, transparent 18px
        );
    border-bottom: 1px solid rgba(255,255,255,.06);
}

/* Screen area — the "projection surface" */
.sn-tagline__screen {
    position: relative; padding: 28px 22px 24px;
    overflow: hidden;
}

/* Projector light beam — sweeps across on reveal */
.sn-tagline__beam {
    position: absolute; top: -20%; left: -60%; width: 50%; height: 140%;
    background: linear-gradient(
        105deg,
        transparent 0%,
        rgba(255,255,255,.03) 35%,
        rgba(255,255,255,.08) 50%,
        rgba(255,255,255,.03) 65%,
        transparent 100%
    );
    transform: skewX(-15deg);
    opacity: 0;
    pointer-events: none;
}
.sn-tagline.show .sn-tagline__beam {
    animation: projectorSweep 2.5s cubic-bezier(.25,.46,.45,.94) .2s forwards;
}
@keyframes projectorSweep {
    0%   { left: -60%; opacity: 0; }
    10%  { opacity: 1; }
    100% { left: 160%; opacity: 0; }
}

/* Quote text — starts dim, lit up by projector */
.sn-tagline__text {
    font-size: 1.15rem; font-weight: 600; line-height: 1.6;
    color: rgba(255,255,255,.12);
    letter-spacing: -.01em;
    margin: 0; border: none; padding: 0;
    display: block;
    transition: color 1.8s ease .6s;
}
.sn-tagline.show .sn-tagline__text {
    color: rgba(255,255,255,.88);
}
.sn-tagline__text em {
    font-style: italic; font-weight: 700;
    color: rgba(255,255,255,.12);
    transition: color 1.8s ease .8s;
}
.sn-tagline.show .sn-tagline__text em {
    color: var(--green);
}

/* Subtle film grain overlay */
.sn-tagline::after {
    content: ''; position: absolute; inset: 0; z-index: 0;
    opacity: .035; pointer-events: none;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* Vignette — darkened corners like old cinema */
.sn-tagline__screen::before {
    content: ''; position: absolute; inset: 0;
    background: radial-gradient(ellipse at center, transparent 50%, rgba(0,0,0,.4) 100%);
    pointer-events: none; z-index: 1;
}

/* Stats row — fades in after text */
.sn-tagline__stats {
    display: flex; justify-content: space-around;
    padding: 14px 22px 18px;
    border-top: 1px solid rgba(255,255,255,.08);
    opacity: 0; transform: translateY(6px);
    transition: opacity .8s ease 2s, transform .8s ease 2s;
}
.sn-tagline.show .sn-tagline__stats {
    opacity: 1; transform: translateY(0);
}
.sn-tagline__stats > div { text-align: center; }
.sn-tagline__stat-n {
    display: block; font-size: .95rem; font-weight: 800; color: #fff;
}
.sn-tagline__stat-l {
    display: block; font-size: .6rem; color: rgba(255,255,255,.4);
    text-transform: uppercase; letter-spacing: .08em; margin-top: 2px;
}

/* Ranking list */
.sn-rank-item {
    display: flex; align-items: center; gap: 12px;
    padding: 10px 20px; transition: background .15s;
}
.sn-rank-item:hover { background: var(--bg); }
.sn-rank-item__pos {
    font-size: .68rem; font-weight: 800; color: var(--text3);
    width: 16px; text-align: center; flex-shrink: 0;
}
.sn-rank-item__pos--gold   { color: #f59e0b; }
.sn-rank-item__pos--silver { color: #94a3b8; }
.sn-rank-item__pos--bronze { color: #b45309; }
.sn-rank-item__avatar {
    width: 38px; height: 38px; border-radius: 50%; flex-shrink: 0;
    overflow: hidden; border: 2px solid var(--border);
    position: relative;
}
.sn-rank-item__avatar img, .sn-rank-item__avatar .author-avatar {
    width: 100%!important; height: 100%!important;
    object-fit: cover!important; border-radius: 50%!important;
}
.sn-rank-item__info { flex: 1; min-width: 0; }
.sn-rank-item__name {
    font-size: .84rem; font-weight: 600; color: var(--text);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sn-rank-item__count { font-size: .72rem; color: var(--text3); margin-top: 1px; }
.sn-rank-item__badge {
    font-size: .68rem; font-weight: 700; color: var(--green);
    background: var(--green-l); padding: 3px 8px; border-radius: 100px;
    white-space: nowrap;
}

/* Críticos más activos — gradiente animado */
@keyframes gradientShift {
    0%   { background-position: 0% 50%; }
    50%  { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}
@keyframes shimmer {
    0%   { transform: translateX(-100%) skewX(-15deg); }
    100% { transform: translateX(250%) skewX(-15deg); }
}
.sn-card--activos {
    background: linear-gradient(135deg,
        rgba(255,223,80,.18) 0%, rgba(212,175,55,.14) 35%,
        rgba(255,200,50,.2) 65%, rgba(240,185,30,.15) 100%
    );
    background-size: 300% 300%;
    animation: gradientShift 6s ease infinite;
    border: 1px solid rgba(212,175,55,.25);
    backdrop-filter: blur(2px);
    position: relative; overflow: hidden;
}
.sn-card--activos::after {
    content: ''; position: absolute; top: 0; left: 0;
    width: 40%; height: 100%;
    background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,.35) 50%, transparent 100%);
    animation: shimmer 3.5s ease-in-out infinite;
    pointer-events: none;
}
.sn-card--activos .sn-rank-item__badge {
    background: rgba(212,175,55,.2); color: #a07800; backdrop-filter: blur(4px);
}

/* Scrollable rank list — all resolutions */
.sn-rank-scroll {
    max-height: 340px; overflow-y: auto;
    position: relative;
    scrollbar-width: thin; scrollbar-color: var(--border) transparent;
}
.sn-rank-scroll::-webkit-scrollbar { width: 4px; }
.sn-rank-scroll::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }
.sn-rank-scroll-fade {
    position: sticky; bottom: 0; left: 0; right: 0;
    height: 32px; pointer-events: none;
    background: linear-gradient(to top, var(--card), transparent);
}

/* ─── PORTADA DESTACADA — extiende .sn-post ─── */
.sn-post--pinned {
    border: 2px solid transparent;
    background:
        linear-gradient(var(--card), var(--card)) padding-box,
        linear-gradient(135deg, var(--green), var(--accent2), var(--accent3), var(--green)) border-box;
    background-size: 100% 100%, 300% 300%;
    animation: borderShift 6s ease infinite;
}
@keyframes borderShift {
    0%   { background-position: 0% 0%, 0% 50%; }
    50%  { background-position: 0% 0%, 100% 50%; }
    100% { background-position: 0% 0%, 0% 50%; }
}
.sn-post__pin {
    margin-left: auto; font-size: 1rem; line-height: 1;
}
.sn-post__archive-link {
    font-size: .76rem; font-weight: 600; color: var(--green);
    text-decoration: none; transition: opacity .2s;
}
.sn-post__archive-link:hover { opacity: .7; }

/* Sticky mini-bar — appears when portada scrolls out of view */
.sn-portada-sticky {
    position: sticky; top: 60px; z-index: 150;
    opacity: 0; transform: translateY(-10px);
    pointer-events: none;
    transition: opacity .25s, transform .25s;
    margin-bottom: -1px;
}
.sn-portada-sticky.visible {
    opacity: 1; transform: translateY(0);
    pointer-events: auto;
}
.sn-portada-sticky__inner {
    display: flex; align-items: center; gap: 10px;
    background: rgba(255,255,255,.95);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1.5px solid var(--green);
    border-radius: var(--r-sm);
    padding: 6px 12px;
    box-shadow: 0 4px 16px rgba(0,0,0,.1);
    text-decoration: none; color: inherit;
    cursor: pointer;
    transition: box-shadow .2s;
}
.sn-portada-sticky__inner:hover {
    box-shadow: 0 6px 24px rgba(0,0,0,.15);
}
.sn-portada-sticky__img {
    width: 32px; height: 32px; border-radius: 6px;
    object-fit: cover; flex-shrink: 0;
}
.sn-portada-sticky__info {
    flex: 1; min-width: 0; display: flex; align-items: center; gap: 8px;
}
.sn-portada-sticky__label {
    font-size: .6rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: .08em; color: var(--green);
    background: var(--green-l); padding: 2px 7px; border-radius: 100px;
    flex-shrink: 0;
}
.sn-portada-sticky__title {
    font-size: .78rem; font-weight: 600; color: var(--text);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sn-portada-sticky__arrow {
    font-size: .8rem; color: var(--green); font-weight: 700; flex-shrink: 0;
}

/* Related items inside pinned post */
.sn-post__related {
    border-top: 1px solid var(--border);
}
.sn-post__related-label {
    font-size: .68rem; font-weight: 700; color: var(--text3);
    letter-spacing: .06em; text-transform: uppercase;
    padding: 12px 20px 0;
}
.sn-post__related-item {
    display: flex; gap: 12px; align-items: center;
    padding: 10px 20px; transition: background .15s;
    text-decoration: none; color: inherit;
}
.sn-post__related-item:hover { background: var(--bg); }
.sn-post__related-img {
    width: 48px; height: 48px; border-radius: var(--r-sm);
    overflow: hidden; flex-shrink: 0;
}
.sn-post__related-img img { width: 100%; height: 100%; object-fit: cover; }
.sn-post__related-info { flex: 1; min-width: 0; }
.sn-post__related-title {
    font-size: .84rem; font-weight: 600; color: var(--text);
    line-height: 1.3; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sn-post__related-meta {
    font-size: .65rem; font-weight: 600; color: var(--green); margin-top: 2px;
}


/* ─── CENTER FEED ─── */
.sn-feed { display: flex; flex-direction: column; gap: 16px; }

/* Stories row */
.sn-stories {
    background: var(--card); border-radius: var(--r);
    box-shadow: var(--shadow); padding: 16px 0 16px 16px;
}
.sn-stories__title {
    font-size: .76rem; font-weight: 700; color: var(--text2);
    letter-spacing: .06em; text-transform: uppercase;
    padding: 0 0 12px 4px;
}
.sn-stories__track {
    display: flex; gap: 12px; overflow-x: auto;
    padding-right: 16px; scrollbar-width: none;
}
.sn-stories__track::-webkit-scrollbar { display: none; }
.sn-story {
    display: flex; flex-direction: column; align-items: center;
    gap: 6px; flex-shrink: 0; cursor: pointer;
}
.sn-story__ring {
    width: 64px; height: 64px; border-radius: 50%; padding: 2.5px;
    background: linear-gradient(135deg, var(--green), var(--accent2), var(--accent3));
    transition: transform .2s var(--eout), box-shadow .2s;
}
.sn-story__ring:hover { transform: scale(1.06); box-shadow: 0 4px 16px rgba(0,201,167,.3); }
.sn-story__ring--seen { background: var(--border); }
.sn-story__inner {
    width: 100%; height: 100%; border-radius: 50%;
    overflow: hidden; border: 2.5px solid var(--card);
    background: var(--bg);
}
.sn-story__inner img, .sn-story__inner .author-avatar {
    width: 100%!important; height: 100%!important;
    object-fit: cover!important; border-radius: 50%!important;
}
.sn-story__name {
    font-size: .68rem; font-weight: 600; color: var(--text);
    max-width: 64px; text-align: center;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sn-story__count { font-size: .6rem; color: var(--text3); }

/* Opinion post card */
.sn-post {
    background: var(--card); border-radius: var(--r);
    box-shadow: var(--shadow); overflow: hidden;
    transition: box-shadow .25s;
}
.sn-post:hover { box-shadow: var(--shadow-lg); }
.sn-post__head {
    display: flex; align-items: center; gap: 12px; padding: 16px 20px 12px;
}
.sn-post__avatar {
    width: 46px; height: 46px; border-radius: 50%; flex-shrink: 0;
    overflow: hidden; border: 2.5px solid var(--green-l);
    position: relative;
}
.sn-post__avatar img, .sn-post__avatar .author-avatar {
    width: 100%!important; height: 100%!important;
    object-fit: cover!important; border-radius: 50%!important;
}
.sn-post__avatar-ring {
    position: absolute; inset: -2px; border-radius: 50%;
    border: 2px solid var(--green); pointer-events: none;
}
.sn-post__author-name { font-size: .9rem; font-weight: 700; color: var(--text); }
.sn-post__author-meta { font-size: .75rem; color: var(--text3); margin-top: 1px; }
.sn-post__author-meta b { color: var(--green); font-weight: 600; }
.sn-post__more {
    margin-left: auto; width: 32px; height: 32px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    color: var(--text3); font-size: 1rem; transition: background .15s; cursor: pointer;
}
.sn-post__more:hover { background: var(--bg); }
.sn-post__body { padding: 0 20px 14px; }
.sn-post__type {
    display: inline-block; font-size: .65rem; font-weight: 700;
    letter-spacing: .1em; text-transform: uppercase;
    color: var(--green); background: var(--green-l);
    padding: 3px 9px; border-radius: 100px; margin-bottom: 8px;
}
.sn-post__title {
    font-size: 1.05rem; font-weight: 700; color: var(--text);
    line-height: 1.35; margin-bottom: 6px;
}
.sn-post__title a:hover { color: var(--green); }
.sn-post__excerpt {
    font-size: .88rem; color: var(--text2); line-height: 1.6;
    display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
}
.sn-post__img {
    margin: 12px 20px; border-radius: var(--r-sm); overflow: hidden;
    background: var(--bg); text-align: center;
}
.sn-post__img img {
    max-width: 100%; height: auto; display: inline-block;
    transition: transform .4s var(--eout);
}
.sn-post:hover .sn-post__img img { transform: scale(1.02); }
.sn-post__foot {
    display: flex; align-items: center; gap: 4px;
    padding: 12px 20px; border-top: 1px solid var(--border);
}
.sn-post__action {
    display: flex; align-items: center; gap: 6px; padding: 6px 12px;
    border-radius: 100px; font-size: .8rem; font-weight: 500;
    color: var(--text2); cursor: pointer; transition: all .15s; border: none; background: none;
}
.sn-post__action:hover { background: var(--bg); color: var(--text); }
.sn-post__action--like:hover { background: #fef2f2; color: #ef4444; }
.sn-post__action svg { width: 16px; height: 16px; }
.sn-post__read {
    margin-left: auto; font-size: .78rem; font-weight: 700;
    color: var(--green); padding: 6px 14px; border-radius: 100px;
    background: var(--green-l); transition: all .2s;
}
.sn-post__read:hover { background: var(--green); color: #fff; }

/* ─── RIGHT SIDEBAR ─── */
.sn-sidebar-right { position: sticky; top: 84px; }

/* Stats banner */
.sn-stats-banner {
    background: linear-gradient(135deg, var(--green), var(--accent2));
    border-radius: var(--r); padding: 20px; margin-bottom: 16px; color: #fff;
}
.sn-stats-banner h3 { font-size: .95rem; font-weight: 800; margin-bottom: 4px; }
.sn-stats-banner p { font-size: .78rem; opacity: .8; margin-bottom: 16px; }
.sn-stats-banner__grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
}
.sn-stats-banner__item { text-align: center; }
.sn-stats-banner__n { font-size: 1.4rem; font-weight: 800; }
.sn-stats-banner__l { font-size: .68rem; opacity: .8; margin-top: 2px; }

/* Suggested profiles */
.sn-suggest-item {
    display: flex; align-items: center; gap: 12px;
    padding: 10px 20px; transition: background .15s;
}
.sn-suggest-item:hover { background: var(--bg); }
.sn-suggest-avatar {
    width: 46px; height: 46px; border-radius: 50%; flex-shrink: 0;
    overflow: hidden; position: relative; border: 2.5px solid var(--green-l);
}
.sn-suggest-avatar img, .sn-suggest-avatar .author-avatar {
    width: 100%!important; height: 100%!important;
    object-fit: cover!important; border-radius: 50%!important;
}
.sn-suggest-info { flex: 1; min-width: 0; }
.sn-suggest-name {
    font-size: .85rem; font-weight: 700; color: var(--text);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sn-suggest-sub { font-size: .72rem; color: var(--text3); margin-top: 1px; }
.sn-suggest-btn {
    font-size: .72rem; font-weight: 700; color: var(--green);
    border: 1.5px solid var(--green); border-radius: 100px;
    padding: 4px 12px; background: none; cursor: pointer; transition: all .2s;
}
.sn-suggest-btn:hover { background: var(--green); color: #fff; }

/* Genres pills */
.sn-genres-wrap { padding: 12px 16px; display: flex; flex-wrap: wrap; gap: 8px; }
.sn-genre-pill {
    display: flex; align-items: center; gap: 5px;
    font-size: .76rem; font-weight: 500; color: var(--text2);
    background: var(--bg); border: 1px solid var(--border);
    border-radius: 100px; padding: 5px 12px; transition: all .2s;
}
.sn-genre-pill:hover { border-color: var(--green); color: var(--green); background: var(--green-l); }

/* Trend items */
.sn-trend-item {
    display: flex; align-items: center; gap: 12px;
    padding: 10px 20px; transition: background .15s;
}
.sn-trend-item:hover { background: var(--bg); }
.sn-trend-item__icon { font-size: 1.1rem; }
.sn-trend-item__name { font-size: .84rem; font-weight: 600; color: var(--text); }
.sn-trend-item__count { font-size: .72rem; color: var(--text3); margin-top: 1px; }
.sn-trend-item__arrow { margin-left: auto; color: var(--text3); font-size: 1rem; }

/* Series scroll */
.sn-series-scroll {
    display: flex; gap: 10px; overflow-x: auto;
    padding-bottom: 4px; scrollbar-width: none;
}
.sn-series-scroll::-webkit-scrollbar { display: none; }
.sn-series-card {
    flex-shrink: 0; width: 120px; height: 80px;
    border-radius: var(--r-sm); overflow: hidden;
    position: relative; display: block;
}
.sn-series-card img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform .3s var(--eout);
}
.sn-series-card:hover img { transform: scale(1.05); }
.sn-series-card__title {
    position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.7) 0%, transparent 60%);
    display: flex; align-items: flex-end; padding: 6px 8px;
    font-size: .65rem; font-weight: 600; color: #fff; line-height: 1.2;
}

/* ─── BOTTOM NAV (mobile) ─── */
.sn-bottom-nav {
    display: none; position: fixed; bottom: 0; left: 0; right: 0; z-index: 300;
    background: rgba(255,255,255,.95);
    backdrop-filter: blur(12px);
    border-top: 1px solid var(--border);
}
.sn-bottom-nav__inner {
    display: flex; align-items: center; justify-content: space-around;
    padding: 8px 0 max(8px, env(safe-area-inset-bottom));
}
.sn-bnav-item {
    display: flex; flex-direction: column; align-items: center; gap: 3px;
    font-size: .6rem; font-weight: 600; color: var(--text3);
    cursor: pointer; padding: 4px 12px; border-radius: var(--r-sm);
    transition: color .15s;
}
.sn-bnav-item svg { width: 22px; height: 22px; }
.sn-bnav-item.active { color: var(--green); }
.sn-bnav-item:hover { color: var(--green); }
.sn-bnav-plus {
    width: 44px; height: 44px; border-radius: 50%;
    background: var(--green); color: #fff; font-size: 1.4rem; font-weight: 300;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 4px 16px rgba(0,201,167,.4);
}

/* ─── SITE FOOTER ─── */
.sn-footer {
    background: var(--card); border-top: 1px solid var(--border);
    padding: 24px; text-align: center;
}
.sn-footer__links {
    display: flex; flex-wrap: wrap; justify-content: center; gap: 12px 24px;
    margin-bottom: 16px;
}
.sn-footer__links a {
    font-size: .78rem; color: var(--text3); transition: color .2s;
}
.sn-footer__links a:hover { color: var(--green); }
.sn-footer__copy { font-size: .72rem; color: var(--text3); }

/* ─── DETAIL PAGES (single-opinion, single-ficha) ─── */
.sn-detail {
    max-width: 1100px; margin: 0 auto;
    padding: 32px 20px; display: grid;
    grid-template-columns: 1fr 340px; gap: 28px;
}
.sn-hero {
    border-radius: var(--r); overflow: hidden; background: var(--text);
    position: relative; min-height: 280px; display: flex; align-items: flex-end; margin-bottom: 24px;
}
.sn-hero__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: .55; }
.sn-hero__overlay {
    position: absolute; inset: 0;
    background: linear-gradient(to top, rgba(10,10,26,.92) 0%, rgba(10,10,26,.3) 60%, transparent 100%);
}
.sn-hero__body { position: relative; z-index: 2; padding: 28px 28px 24px; width: 100%; }
.sn-hero__pelicula {
    font-size: .72rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase;
    color: var(--green); margin-bottom: 8px; display: flex; align-items: center; gap: 6px;
}
.sn-hero__titulo { font-size: 1.55rem; font-weight: 800; color: #fff; line-height: 1.25; margin-bottom: 12px; }
.sn-hero__meta { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.sn-hero__stars { color: #f59e0b; font-size: 1.1rem; letter-spacing: 1px; }
.sn-hero__val {
    font-size: .8rem; font-weight: 600; color: rgba(255,255,255,.8);
    background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.2);
    border-radius: 100px; padding: 3px 12px;
}
.sn-hero__tax { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 10px; }
.sn-hero__tag {
    font-size: .7rem; font-weight: 500; color: rgba(255,255,255,.7);
    background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.15);
    border-radius: 100px; padding: 3px 10px;
}
.sn-hero__tag:hover { background: var(--green); color: #fff; border-color: var(--green); }

/* Author block */
.sn-autor {
    display: flex; align-items: center; gap: 14px; padding: 20px 24px;
    background: var(--card); border-radius: var(--r); box-shadow: var(--shadow); margin-bottom: 20px;
}
.sn-autor__avatar { width: 52px; height: 52px; border-radius: 50%; object-fit: cover; border: 3px solid var(--green-l); }
.sn-autor__info { flex: 1; }
.sn-autor__nombre { font-size: .95rem; font-weight: 700; color: var(--text); }
.sn-autor__fecha { font-size: .75rem; color: var(--text3); margin-top: 2px; }
.sn-autor__badge { font-size: .7rem; font-weight: 600; padding: 4px 12px; background: var(--green-l); color: var(--green); border-radius: 100px; }

/* Opinion and critique text */
.sn-opinion-text {
    font-size: 1rem; line-height: 1.75; color: var(--text2); font-style: italic;
    border-left: 3px solid var(--green); padding-left: 18px;
}
.sn-critica-text { font-size: .95rem; line-height: 1.8; color: var(--text); }
.sn-critica-text p { margin-bottom: 1em; }
.sn-critica-text p:last-child { margin-bottom: 0; }

/* Pros/cons */
.sn-pros { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.sn-pro, .sn-con { padding: 16px 18px; border-radius: var(--r-sm); }
.sn-pro { background: #f0fdf4; border: 1px solid #bbf7d0; }
.sn-con { background: #fff7ed; border: 1px solid #fed7aa; }
.sn-pro__label, .sn-con__label {
    font-size: .7rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: .08em; margin-bottom: 6px; display: flex; align-items: center; gap: 6px;
}
.sn-pro__label { color: #16a34a; }
.sn-con__label { color: #ea580c; }
.sn-pro__text, .sn-con__text { font-size: .88rem; line-height: 1.5; color: var(--text); }

/* Poster card */
.sn-poster-card { background: var(--card); border-radius: var(--r); box-shadow: var(--shadow); overflow: hidden; margin-bottom: 20px; }
.sn-poster-card__img { width: 100%; aspect-ratio: 2/3; object-fit: cover; }
.sn-poster-card__img-placeholder {
    width: 100%; aspect-ratio: 2/3;
    background: linear-gradient(135deg, #1a1a2e, #2d2d5a);
    display: flex; align-items: center; justify-content: center;
    font-size: 3rem;
}
.sn-poster-card__body { padding: 16px; }
.sn-poster-card__titulo { font-size: 1rem; font-weight: 700; margin-bottom: 4px; }
.sn-poster-card__sub { font-size: .78rem; color: var(--text3); }
.sn-poster-card__btn {
    display: block; margin-top: 14px; text-align: center;
    padding: 10px; background: var(--green); color: #fff;
    border-radius: var(--r-sm); font-size: .82rem; font-weight: 600; transition: background .2s;
}
.sn-poster-card__btn:hover { background: var(--green-d); }

/* Meta list */
.sn-meta-list { list-style: none; padding: 0; margin: 0; }
.sn-meta-list li {
    display: flex; justify-content: space-between; align-items: flex-start;
    padding: 10px 0; border-bottom: 1px solid var(--border); font-size: .82rem; gap: 12px;
}
.sn-meta-list li:last-child { border-bottom: none; }
.sn-meta-list__key { color: var(--text3); font-weight: 500; white-space: nowrap; }
.sn-meta-list__val {
    color: var(--text); font-weight: 500; text-align: right;
    display: flex; flex-wrap: wrap; gap: 4px; justify-content: flex-end;
}
.sn-meta-list__val a { color: var(--green); font-weight: 600; }
.sn-meta-list__val a:hover { text-decoration: underline; }

/* Related opinions */
.sn-rel-grid { display: flex; flex-direction: column; gap: 12px; }
.sn-rel-item {
    display: flex; align-items: flex-start; gap: 12px; padding: 12px;
    border-radius: var(--r-sm); border: 1px solid var(--border); transition: border-color .2s, box-shadow .2s;
}
.sn-rel-item:hover { border-color: var(--green); box-shadow: 0 2px 8px rgba(0,201,167,.1); }
.sn-rel-item__avatar { width: 38px; height: 38px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.sn-rel-item__body { flex: 1; min-width: 0; }
.sn-rel-item__autor { font-size: .75rem; font-weight: 600; color: var(--text2); }
.sn-rel-item__texto {
    font-size: .8rem; color: var(--text); line-height: 1.4; margin-top: 2px;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.sn-rel-item__val { font-size: .7rem; color: #f59e0b; margin-top: 4px; }

/* Comments */
.sn-comments .comment-list { list-style: none; padding: 0; }
.sn-comments .comment { padding: 16px 0; border-bottom: 1px solid var(--border); }
.sn-comments .comment:last-child { border-bottom: none; }
.sn-comments .comment-author { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.sn-comments .comment-author img { border-radius: 50%; }
.sn-comments .comment-author .fn { font-size: .88rem; font-weight: 600; }
.sn-comments .comment-metadata { font-size: .72rem; color: var(--text3); margin-top: 1px; }
.sn-comments .comment-content p { font-size: .88rem; line-height: 1.65; color: var(--text2); }
.sn-comment-form { margin-top: 20px; }
.sn-comment-form input[type=text],
.sn-comment-form input[type=email],
.sn-comment-form textarea {
    width: 100%; padding: 10px 14px; border: 1px solid var(--border);
    border-radius: var(--r-sm); font-family: var(--f); font-size: .88rem;
    color: var(--text); background: #fff; margin-bottom: 12px; transition: border-color .2s;
}
.sn-comment-form input:focus, .sn-comment-form textarea:focus { outline: none; border-color: var(--green); }
.sn-comment-form textarea { min-height: 100px; resize: vertical; }
.sn-comment-form input[type=submit] {
    background: var(--green); color: #fff; border: none; padding: 11px 28px;
    border-radius: var(--r-sm); font-family: var(--f); font-size: .88rem;
    font-weight: 600; cursor: pointer; transition: background .2s;
}
.sn-comment-form input[type=submit]:hover { background: var(--green-d); }

/* ─── TAXONOMY / ARCHIVE / SEARCH PAGES ─── */
.sn-wrap { max-width: 1100px; margin: 0 auto; padding: 32px 20px 80px; }
.sn-page-header { margin-bottom: 28px; }
.sn-page-header__label {
    font-size: .72rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: .1em; color: var(--green); margin-bottom: 8px;
}
.sn-page-header h1 { font-size: 2rem; font-weight: 800; letter-spacing: -.04em; line-height: 1.2; }
.sn-page-header p { font-size: .9rem; color: var(--text3); margin-top: 8px; }

/* Grid cards */
.sn-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 20px; }
.sn-mc-card {
    background: var(--card); border-radius: var(--r); box-shadow: var(--shadow);
    overflow: hidden; transition: box-shadow .2s; display: flex; flex-direction: column;
}
.sn-mc-card:hover { box-shadow: var(--shadow-lg); }
.sn-mc-card__img { height: 260px; overflow: hidden; background: var(--border); flex-shrink: 0; }
.sn-mc-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s; }
.sn-mc-card:hover .sn-mc-card__img img { transform: scale(1.04); }
.sn-mc-card__body { padding: 14px; flex: 1; display: flex; flex-direction: column; }
.sn-mc-card__badge { margin-bottom: 8px; }
.sn-mc-badge { display: inline-block; font-size: .65rem; font-weight: 700; letter-spacing: .08em; padding: 3px 10px; border-radius: 100px; }
.sn-mc-badge--opinion { background: var(--green-l); color: var(--green); }
.sn-mc-badge--critica { background: #fff0f0; color: #e50914; }
.sn-mc-badge--ficha   { background: #eff6ff; color: #2563eb; }
.sn-mc-badge--especial { background: #fef3c7; color: #d97706; }
.sn-mc-card__title { font-size: .95rem; font-weight: 700; color: var(--text); line-height: 1.3; margin-bottom: 6px; }
.sn-mc-card__meta { font-size: .76rem; color: var(--text3); margin-bottom: 6px; }
.sn-mc-card__excerpt {
    font-size: .8rem; color: var(--text2); line-height: 1.5; flex: 1;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.sn-mc-card__author {
    display: flex; align-items: center; gap: 7px; margin-top: 10px;
    padding-top: 10px; border-top: 1px solid var(--border);
}
.sn-mc-card__author img, .sn-mc-card__author .author-avatar {
    width: 22px!important; height: 22px!important; border-radius: 50%!important; object-fit: cover!important;
}
.sn-mc-card__author-name { font-size: .72rem; font-weight: 600; color: var(--text2); }

/* Stars */
.sn-stars { color: #f59e0b; font-size: .95rem; letter-spacing: 1px; }
.sn-val-text { font-size: .8rem; font-weight: 600; color: var(--text2); }

/* Pagination */
.sn-pagination { margin-top: 40px; text-align: center; }
.sn-pagination .page-numbers {
    display: inline-block; padding: 8px 16px; border-radius: 100px;
    border: 1px solid var(--border); margin: 0 3px; font-size: .84rem; font-weight: 600; transition: all .2s;
}
.sn-pagination a.page-numbers:hover { border-color: var(--green); color: var(--green); }
.sn-pagination .current { background: var(--green); color: #fff; border-color: var(--green); }

/* Search box */
.sn-search-form {
    display: flex; align-items: center; gap: 8px;
    background: var(--card); border: 1px solid var(--border);
    border-radius: 100px; padding: 10px 20px; margin-bottom: 28px;
    box-shadow: var(--shadow); max-width: 600px;
}
.sn-search-form input[type="search"],
.sn-search-form input[type="text"] {
    flex: 1; border: none; outline: none; font-family: var(--f);
    font-size: .95rem; color: var(--text); background: transparent;
}
.sn-search-form button {
    background: var(--green); color: #fff; border: none; border-radius: 100px;
    padding: 7px 18px; font-size: .84rem; font-weight: 600; cursor: pointer; transition: background .2s;
}
.sn-search-form button:hover { background: var(--green-d); }

/* Author profile */
.sn-author-hero {
    background: var(--card); border-radius: var(--r); box-shadow: var(--shadow);
    padding: 32px; display: flex; gap: 24px; margin-bottom: 28px; align-items: center;
}
.sn-author-hero__avatar img, .sn-author-hero__avatar .author-avatar {
    width: 88px!important; height: 88px!important;
    border-radius: 50%!important; object-fit: cover!important;
    border: 3px solid var(--green)!important;
}
.sn-author-hero__name { font-size: 1.7rem; font-weight: 800; letter-spacing: -.02em; margin-bottom: 4px; }
.sn-author-hero__bio { font-size: .88rem; color: var(--text2); line-height: 1.6; margin-top: 8px; }
.sn-author-stats {
    display: flex; gap: 24px; margin-top: 16px;
}
.sn-author-stat__n { font-size: 1.3rem; font-weight: 800; color: var(--text); }
.sn-author-stat__l { font-size: .72rem; color: var(--text3); margin-top: 2px; }

/* Ficha hero layout */
.sn-ficha-hero {
    background: var(--card); border-radius: var(--r); box-shadow: var(--shadow);
    padding: 28px; display: grid; grid-template-columns: 200px 1fr;
    gap: 28px; margin-bottom: 24px;
}
.sn-ficha-poster {
    width: 200px; border-radius: var(--r-sm); overflow: hidden;
    background: var(--border); flex-shrink: 0;
}
.sn-ficha-poster img { width: 100%; display: block; }
.sn-ficha-info__title { font-size: 1.7rem; font-weight: 800; line-height: 1.2; letter-spacing: -.02em; margin-bottom: 12px; }
.sn-ficha-info__tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
.sn-ficha-info__tag {
    font-size: .75rem; font-weight: 600; padding: 4px 12px; border-radius: 100px;
    background: var(--bg); border: 1px solid var(--border); color: var(--text2); transition: all .2s;
}
.sn-ficha-info__tag:hover { border-color: var(--green); color: var(--green); }
.sn-ficha-info__synopsis { font-size: .92rem; line-height: 1.75; color: var(--text2); }
.sn-ficha-video { margin-bottom: 24px; border-radius: var(--r); overflow: hidden; background: #000; }
.sn-ficha-video iframe { width: 100%; height: 380px; border: 0; display: block; }
.sn-ficha-stats {
    display: flex; gap: 16px; background: var(--green-l); border-radius: var(--r-sm);
    padding: 14px 18px; margin-bottom: 20px; flex-wrap: wrap;
}
.sn-ficha-stat { text-align: center; }
.sn-ficha-stat__n { font-size: 1.2rem; font-weight: 800; color: var(--green); }
.sn-ficha-stat__l { font-size: .68rem; color: var(--text3); margin-top: 2px; }

/* 404 / page / generic */
.sn-generic-wrap {
    max-width: 720px; margin: 80px auto; padding: 0 20px 80px; text-align: center;
}
.sn-generic-wrap h1 { font-size: 2rem; font-weight: 800; margin-bottom: 12px; }
.sn-generic-wrap p { font-size: .95rem; color: var(--text2); line-height: 1.65; margin-bottom: 24px; }
.sn-generic-wrap .sn-btn-home {
    display: inline-block; background: var(--green); color: #fff; padding: 12px 28px;
    border-radius: 100px; font-weight: 700; font-size: .9rem; transition: background .2s;
}
.sn-generic-wrap .sn-btn-home:hover { background: var(--green-d); }
.sn-404-number { font-size: 6rem; font-weight: 900; color: var(--green-l); line-height: 1; }

/* Page content */
.sn-page-content { background: var(--card); border-radius: var(--r); box-shadow: var(--shadow); padding: 32px; max-width: 800px; margin: 0 auto; }
.sn-page-content h1, .sn-page-content h2 { font-weight: 800; letter-spacing: -.02em; margin-bottom: 12px; }
.sn-page-content p { font-size: .95rem; line-height: 1.75; color: var(--text2); margin-bottom: 1em; }
.sn-page-content a { color: var(--green); }
.sn-page-content a:hover { text-decoration: underline; }

/* ─── REVEAL ANIMATION ─── */
[data-rv] { transition: opacity .6s ease, transform .6s ease; }
[data-rv].rv-init { opacity: 0; transform: translateY(20px); }
[data-rv].show { opacity: 1; transform: translateY(0); }

/* ─── LIKE BUTTON (LikeBtn plugin) ─── */

/* Wrapper en single-opinion: botón integrado al final del bloque autor */
.sn-likebtn-opinion-wrap {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    padding: 8px 0 16px;
}

/* Ficha hero: título + like en la misma fila */
.sn-ficha-info__title-row {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    flex-wrap: wrap;
    margin-bottom: 12px;
}
.sn-ficha-info__title-row .sn-ficha-info__title {
    margin-bottom: 0;
    flex: 1 1 auto;
}
.sn-ficha-info__likebtn {
    flex-shrink: 0;
    padding-top: 4px;
}

/* En el card footer de la homepage: inline con "Leer →" */
.sn-post__action--like {
    display: inline-flex;
    align-items: center;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    gap: 0;
}

/* Overrides globales del widget LikeBtn */
.likebtn-wrapper {
    display: inline-flex !important;
    align-items: center;
}
.likebtn-wrapper * {
    font-size: .82rem !important;
    font-weight: 600 !important;
    font-family: inherit !important;
}
/* Iconos de corazón: mismo tamaño que producción */
img.likebtn-icon.lb-like-icon,
img.likebtn-icon.lb-like-icon.lb-icon-v,
img.likebtn-icon.lb-dislike-icon,
img.likebtn-icon.lb-dislike-icon.lb-icon-v {
    width: 22px !important;
    height: auto !important;
    margin-right: 6px !important;
}
/* En fichas (hero, botón más grande) */
.mc-lb-ficha img.likebtn-icon {
    width: 28px !important;
}
/* Sin padding entre like y dislike en el footer de cards */
span.likebtn-button.lb-like.lb-ef-bounce { padding-right: 6px !important; }

/* ─── SKELETON LOADING ─── */
@keyframes skeletonPulse {
    0%, 100% { opacity: .06; }
    50%      { opacity: .12; }
}
.sn-skeleton { display: flex; flex-direction: column; gap: 16px; }
.sn-skeleton__card {
    background: var(--card); border-radius: var(--r);
    box-shadow: var(--shadow); overflow: hidden;
}
.sn-skeleton__head {
    height: 60px; margin: 16px 20px 12px;
    background: var(--border); border-radius: 8px;
    animation: skeletonPulse 1.5s ease infinite;
}
.sn-skeleton__body {
    height: 48px; margin: 0 20px 14px;
    background: var(--border); border-radius: 6px;
    animation: skeletonPulse 1.5s ease infinite .2s;
}
.sn-skeleton__img {
    height: 180px; margin: 0 20px 20px;
    background: var(--border); border-radius: var(--r-sm);
    animation: skeletonPulse 1.5s ease infinite .4s;
}

/* ─── RESPONSIVE ─── */
@media(max-width:1024px){
    .sn-layout { grid-template-columns: 30% 1fr; }
    .sn-sidebar-right { display: none; }
    .sn-detail { grid-template-columns: 1fr; }
    .sn-ficha-hero { grid-template-columns: 160px 1fr; }
}
@media(max-width:768px){
    .sn-layout { grid-template-columns: 1fr; padding: 12px; gap: 12px; padding-bottom: 80px; }
    .sn-sidebar-left { position: relative; top: auto; }
    .sn-bottom-nav { display: block; }
    .sn-bar { padding: 0 16px; }
    .sn-bar__search { display: none; }
    .sn-detail { padding: 20px 16px; }
    .sn-ficha-hero { grid-template-columns: 1fr; }
    .sn-ficha-poster { width: 100%; max-width: 200px; }
    .sn-pros { grid-template-columns: 1fr; }
    .sn-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); }
    .sn-author-hero { flex-direction: column; align-items: flex-start; }
    .sn-mv-item { grid-template-columns: 44px 70px 1fr; gap: 10px; }
    .sn-mv-votes { flex-direction: row; align-items: center; gap: 12px; }
}

/* ─── LO MÁS VOTADO ─── */
.sn-mv-hero {
    display: flex;
    align-items: center;
    gap: 20px;
    background: linear-gradient(135deg, var(--green-d) 0%, var(--green) 100%);
    border-radius: var(--r);
    padding: 28px 32px;
    margin-bottom: 24px;
    color: #fff;
}
.sn-mv-hero__icon { font-size: 2.4rem; line-height: 1; }
.sn-mv-hero__title {
    font-size: 1.6rem;
    font-weight: 900;
    letter-spacing: -.03em;
    color: #fff;
    margin: 0 0 4px;
}
.sn-mv-hero__sub { font-size: .85rem; color: rgba(255,255,255,.8); margin: 0; }

.sn-mv-list { display: flex; flex-direction: column; gap: 10px; margin-bottom: 24px; }

.sn-mv-item {
    display: grid;
    grid-template-columns: 52px 80px 1fr auto;
    align-items: center;
    gap: 16px;
    background: var(--card);
    border-radius: var(--r);
    box-shadow: var(--shadow);
    padding: 12px 16px;
    transition: box-shadow .2s;
}
.sn-mv-item:hover { box-shadow: var(--shadow-lg); }
.sn-mv-item--top3 { border-left: 4px solid var(--green); }

.sn-mv-rank { text-align: center; }
.sn-mv-medal { font-size: 1.6rem; line-height: 1; }
.sn-mv-num {
    font-size: 1.1rem;
    font-weight: 800;
    color: var(--text3);
    font-variant-numeric: tabular-nums;
}

.sn-mv-poster {
    display: block;
    width: 68px;
    height: 100px;
    border-radius: 8px;
    overflow: hidden;
    flex-shrink: 0;
    box-shadow: 0 4px 12px rgba(0,0,0,.25);
}
.sn-mv-poster img { width: 100%; height: 100%; object-fit: cover; }
.sn-mv-poster__placeholder {
    width: 68px; height: 100px;
    background: var(--bg);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.6rem; border-radius: 8px;
}

.sn-mv-info { min-width: 0; }
.sn-mv-info__title {
    display: block;
    font-size: .95rem;
    font-weight: 700;
    color: var(--text);
    text-decoration: none;
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-bottom: 4px;
}
.sn-mv-info__title:hover { color: var(--green); }
.sn-mv-info__genre { font-size: .72rem; color: var(--text3); text-transform: uppercase; letter-spacing: .05em; }

.sn-mv-votes {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
    min-width: 80px;
}
.sn-mv-votes__bar { display: flex; gap: 8px; align-items: center; font-size: .82rem; }
.sn-mv-votes__like { color: var(--green); font-weight: 700; }
.sn-mv-votes__dislike { color: var(--text3); }
.sn-mv-votes__widget .likebtn-wrapper { transform: scale(.85); transform-origin: right center; }
/* En la página lo-más-votado, los contadores del LikeBtn van en verde oscuro */
.sn-mv-votes__widget .mc-lb-ficha { --lb-counter-c: var(--green-d); }

/* Items con opiniones: alinear al inicio verticalmente */
.sn-mv-item--has-ops { align-items: start; }
.sn-mv-item--has-ops .sn-mv-rank { padding-top: 4px; }
.sn-mv-item--has-ops .sn-mv-poster { margin-top: 2px; }
.sn-mv-item--has-ops .sn-mv-votes { margin-top: 4px; }

/* Título de ficha sin truncar cuando hay opiniones debajo */
.sn-mv-item--has-ops .sn-mv-info__title {
    white-space: normal;
    overflow: visible;
    text-overflow: unset;
}

/* Lista de opiniones dentro de cada ficha */
.sn-mv-opinions {
    list-style: none;
    margin: 10px 0 0;
    padding: 8px 0 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
    border-top: 1px solid var(--border);
}
.sn-mv-opinion__link {
    display: flex;
    align-items: center;
    gap: 8px;
    text-decoration: none;
    transition: opacity .15s;
}
.sn-mv-opinion__link:hover { opacity: .8; }

/* Avatar con anillo de gradiente — igual que los stories de portada */
.sn-mv-opinion__ava-ring {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    padding: 2px;
    background: linear-gradient(135deg, var(--green), var(--accent2));
    flex-shrink: 0;
    transition: transform .2s var(--eout);
}
.sn-mv-opinion__link:hover .sn-mv-opinion__ava-ring { transform: scale(1.08); }
.sn-mv-opinion__ava-inner {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    overflow: hidden;
    border: 1.5px solid var(--card);
    background: var(--bg);
}
.sn-mv-opinion__ava-inner img,
.sn-mv-opinion__ava-inner .author-avatar {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: 50% !important;
    display: block;
}

.sn-mv-opinion__title {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: .78rem;
    font-weight: 600;
    color: var(--text2);
    line-height: 1.3;
}
.sn-mv-opinion__link:hover .sn-mv-opinion__title { color: var(--green); }

/* Paginación */
.sn-mv-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin: 24px 0 12px;
    flex-wrap: wrap;
}
.sn-mv-page-numbers {
    display: flex;
    align-items: center;
    gap: 4px;
}
.sn-mv-page-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    height: 36px;
    padding: 0 12px;
    border-radius: var(--r);
    background: var(--card);
    color: var(--text2);
    font-size: .82rem;
    font-weight: 600;
    text-decoration: none;
    border: 1px solid var(--border);
    transition: background .15s, color .15s, border-color .15s;
}
.sn-mv-page-btn:hover {
    background: var(--green);
    color: #fff;
    border-color: var(--green);
}
.sn-mv-page-btn--active {
    background: var(--green);
    color: #fff;
    border-color: var(--green);
}
.sn-mv-page-ellipsis {
    color: var(--text3);
    font-size: .85rem;
    padding: 0 2px;
}
.sn-mv-page-info {
    text-align: center;
    font-size: .72rem;
    color: var(--text3);
    margin: 0 0 8px;
}

.sn-mv-updated {
    text-align: center;
    font-size: .75rem;
    color: var(--text3);
    margin-top: 8px;
}
.sn-mv-updated a { color: var(--green); }

/* ═══════════════════════════════════════════════════════════════════════════ */
/* ─── LAYOUTS ─── Switchable from Apariencia > Personalizar > Layout        */
/* ═══════════════════════════════════════════════════════════════════════════ */

/* 1. SOCIAL — default, no overrides needed (.sn-layout base rules apply) */

/* ─── 2. MAGAZINE ─── Tipo medio de comunicación, max-width centrado ─── */
.layout-magazine .sn-layout {
    max-width: 1400px; margin: 0 auto;
    grid-template-columns: 260px 1fr 260px;
}
.layout-magazine .sn-sidebar-left,
.layout-magazine .sn-sidebar-right { position: sticky; top: 84px; }
@media(max-width:1024px){
    .layout-magazine .sn-layout { grid-template-columns: 240px 1fr; }
    .layout-magazine .sn-sidebar-right { display: none; }
}
@media(max-width:768px){
    .layout-magazine .sn-layout { grid-template-columns: 1fr; padding: 12px; gap: 12px; padding-bottom: 80px; }
    .layout-magazine .sn-sidebar-left { position: relative; top: auto; }
}

/* ─── 3. FOCUSED ─── Lectura centrada, 1 columna, sidebars debajo ─── */
.layout-focused .sn-layout {
    display: flex; flex-direction: column;
    max-width: 780px; margin: 0 auto;
    padding: 24px 20px 80px; gap: 24px;
}
.layout-focused .sn-sidebar-left {
    order: 2; position: relative; top: auto;
    display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
}
.layout-focused .sn-feed { order: 1; }
.layout-focused .sn-sidebar-right {
    order: 3; display: grid !important;
    grid-template-columns: 1fr 1fr; gap: 16px;
    position: relative; top: auto;
}
.layout-focused .sn-post__img { margin: 12px 0; border-radius: var(--r); }
@media(max-width:1024px){
    .layout-focused .sn-layout { max-width: 680px; }
    .layout-focused .sn-sidebar-right { display: grid !important; }
}
@media(max-width:768px){
    .layout-focused .sn-layout { padding: 12px; gap: 12px; padding-bottom: 80px; }
    .layout-focused .sn-sidebar-left,
    .layout-focused .sn-sidebar-right { grid-template-columns: 1fr; }
}

/* ─── 4. WIDE ─── Dashboard, 2 columnas, sidebar izq oculto ─── */
.layout-wide .sn-layout {
    max-width: 1200px; margin: 0 auto;
    grid-template-columns: 1fr 320px;
}
.layout-wide .sn-sidebar-left { display: none; }
.layout-wide .sn-sidebar-right { position: sticky; top: 84px; }
.layout-wide .sn-feed { gap: 20px; }
.layout-wide .sn-post {
    display: grid; grid-template-columns: 1fr;
}
@media(max-width:1024px){
    .layout-wide .sn-layout { grid-template-columns: 1fr; max-width: 800px; }
    .layout-wide .sn-sidebar-right {
        display: grid !important; grid-template-columns: repeat(3, 1fr);
        gap: 16px; position: relative; top: auto;
    }
}
@media(max-width:768px){
    .layout-wide .sn-layout { padding: 12px; gap: 12px; padding-bottom: 80px; }
    .layout-wide .sn-sidebar-right { grid-template-columns: 1fr; }
}

/* ─── 5. CINEMA ─── Inmersivo, sidebars estrechos, contenido grande ─── */
.layout-cinema .sn-layout {
    grid-template-columns: 200px 1fr 200px;
    gap: clamp(8px, 1vw, 16px);
    padding: clamp(8px, 1vw, 16px);
}
.layout-cinema .sn-post__img {
    margin: 0; border-radius: 0;
    max-height: 400px; overflow: hidden;
}
.layout-cinema .sn-post__img img { width: 100%; height: auto; }
.layout-cinema .sn-post__title { font-size: 1.2rem; }
.layout-cinema .sn-post { border-radius: var(--r); }
.layout-cinema .sn-sidebar-left,
.layout-cinema .sn-sidebar-right { position: sticky; top: 84px; }
@media(max-width:1024px){
    .layout-cinema .sn-layout { grid-template-columns: 1fr; max-width: 860px; margin: 0 auto; }
    .layout-cinema .sn-sidebar-left,
    .layout-cinema .sn-sidebar-right { display: none; }
}
@media(max-width:768px){
    .layout-cinema .sn-layout { padding: 0; gap: 8px; padding-bottom: 80px; }
    .layout-cinema .sn-post { border-radius: 0; }
    .layout-cinema .sn-post__body { padding: 0 16px 14px; }
    .layout-cinema .sn-post__head { padding: 14px 16px 10px; }
    .layout-cinema .sn-post__foot { padding: 10px 16px; }
}

/* ─── 6. COMPACT ─── Grid tipo Pinterest, sidebars en barra horizontal ─── */
.layout-compact .sn-layout {
    display: flex; flex-direction: column;
    max-width: 1300px; margin: 0 auto;
    padding: 12px; gap: 10px;
}
.layout-compact .sn-sidebar-left,
.layout-compact .sn-sidebar-right { display: none; }
.layout-compact .sn-feed {
    order: 2;
    display: grid !important; flex-direction: unset;
    grid-template-columns: repeat(4, 1fr); gap: 10px;
}
/* Full-width elements span all columns */
.layout-compact .sn-post--pinned,
.layout-compact .sn-portada-sticky,
.layout-compact .sn-feed > .sn-card,
.layout-compact .sn-feed > div[style],
.layout-compact #feed-sentinel { grid-column: 1 / -1; }
.layout-compact .sn-post { border-radius: var(--r-sm); }
.layout-compact .sn-post__excerpt { -webkit-line-clamp: 2; }
.layout-compact .sn-post__img { margin: 0; border-radius: 0; }
.layout-compact .sn-post__head { padding: 10px 10px 6px; gap: 8px; }
.layout-compact .sn-post__body { padding: 0 10px 8px; }
.layout-compact .sn-post__foot { padding: 6px 10px; }
.layout-compact .sn-post__avatar { width: 28px; height: 28px; }
.layout-compact .sn-post__author-name { font-size: .78rem; }
.layout-compact .sn-post__title { font-size: .88rem; }
.layout-compact .sn-post__excerpt { font-size: .78rem; }
@media(max-width:1024px){
    .layout-compact .sn-feed { grid-template-columns: repeat(3, 1fr); }
}
@media(max-width:768px){
    .layout-compact .sn-layout { padding: 6px; gap: 6px; padding-bottom: 80px; }
    .layout-compact .sn-feed { grid-template-columns: repeat(2, 1fr); gap: 6px; }
    .layout-compact .sn-post__head { padding: 8px 8px 4px; gap: 6px; }
    .layout-compact .sn-post__body { padding: 0 8px 6px; }
    .layout-compact .sn-post__foot { padding: 4px 8px; }
    .layout-compact .sn-post__title { font-size: .8rem; }
}
