/* Full width layout for single video pages */
body.nfs-single-page .container {
    max-width: 100% !important;
    width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}
/* UNLOCK TOTAL LAYOUT BuddyBoss (single) */
body.nfs-single-page .bb-grid,
body.nfs-single-page .bb-grid > .container,
body.nfs-single-page #primary,
body.nfs-single-page #main {
    max-width: 100% !important;
    width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}
body.nfs-single-page #report-post-modal {
    display: none;
}
body.nfs-single-page #report-post-modal.is-open {
    display: flex;
}

body.nfs-single-page .report-modal.is-open {
    display: flex;
}
body.nfs-single-page .content-area {
    padding-top: 0!important;
}
/*.js-chapter-link{
    color: #e32c2c!important;
}*/

body.nfs-single-page .nfs-single-layout .chapter-time {
    color: #4CAF50!important; /* vert stylé */
    font-weight: 600!important;
}

body.nfs-single-page .nfs-single-layout .chapter-separator {
    color: #ffffff!important;
    opacity: 0.6!important;
}

body.nfs-single-page .nfs-single-layout .chapter-title {
    color: #ffffff!important;
    font-weight: 400!important;
}

body.nfs-single-page .nfs-single-layout .js-chapter-link:hover .chapter-time {
    color: #66bb6a!important;
}

body.nfs-single-page .nfs-single-layout .js-chapter-link:hover .chapter-title {
    color: #f5f5f5!important;
}
/* ==========================================
   🎬 Design single.php – Style YouTube
   ========================================== */

/* === META BLOCK STRUCTURE (sous la vidéo) === */
body.nfs-single-page .nfs-video-meta-block {
    max-width: 800px;
    margin: 16px auto 20px;
    padding: 0 15px;
}

/* === Ligne titre + partage (YouTube-like) === */
body.nfs-single-page .nfs-video-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

/* Titre */
body.nfs-single-page .video-title {
    margin: 0;
    font-size: 24px;
    font-weight: 600;
    color: #ffffff;
    line-height: 1.3;
}

/* Boutons à droite */
body.nfs-single-page .mycred-share-buttons {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}
/* === MyCred share icons – resize propre === */
body.nfs-single-page .mycred-social-wrapper a.mycred-social-icons {
    width: 20px;
    height: 20px;
}
body.nfs-single-page a.mycred-social-icons {
    font-size: 14px!important;
}
body.nfs-single-page .mycred-share-buttons {
    display: flex;
    align-items: center;
    gap: 8px;
}


/* === TITRE === */

body.nfs-single-page .video-description {
    margin-top: 12px;
    background-color: #ffffff0f;
    border-radius: 4px;
}
body.nfs-single-page .video-description-title {
    margin-top: 0;
}

/* === YouTube-like info row (override) === */
body.nfs-single-page .video-info-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: nowrap;
    padding: 12px 16px;
    border-radius: 12px;
}



/* Bloc auteur + badge */
body.nfs-single-page .author-section {
    gap: 8px;
}

/* Réactions compactes */
body.nfs-single-page .reactions-section {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: 8px;
}

/* === AUTEUR === */
body.nfs-single-page .author-avatar {
    border-radius: 50%;
    border: 2px solid #e9b425;
}
body.nfs-single-page .author-name {
   /* color: #3ea6ff !important;*/
    text-decoration: none;
    font-weight: 500;
}
body.nfs-single-page .author-name:hover {
    text-decoration: underline;
}

/* === RÉACTIONS === */
body.nfs-single-page .reactions-section button {
    color: #ffffff;
}
body.nfs-single-page .reaction-bar {
    background: rgba(0, 0, 0, 0.15);
}

body.nfs-single-page .reactions-section button {
    background: transparent;
    border: none;
    font-size: 22px;
    cursor: pointer;
    color: #ffffff!important;
}

#nfs-love-count-articles{
    color: #ffffff;
}
#nfs-meh-count-articles{
    color: #ffffff;
}

/* === VUES === */
body.nfs-single-page .views-section {
    margin-left: 10px;
    font-size: 14px;
    white-space: nowrap;
    color: #ffffff;
}


/* === DESCRIPTION (texte dynamique) === */
body.nfs-single-page #article-description a {
    color: #ffffff;
    text-decoration: none;
    font-weight: 500;
}
body.nfs-single-page #article-description a:hover {
    text-decoration: underline;
}

body.nfs-single-page #article-desc-short {
    color: #ffffff;
}

body.nfs-single-page .article-chapters p {
    margin: 5px 0;
    color: #ffffff;
    font-size: 14px;
}
body.nfs-single-page .article-chapters a {
    color: #3ea6ff;
    text-decoration: none;
}
body.nfs-single-page .article-chapters a:hover {
    text-decoration: underline;
}
/* === TITRES DANS DESCRIPTION === */
body.nfs-single-page .video-description-title {
    font-size: 18px;
    color: #ffffff ;
    font-weight: 600;
    margin-bottom: 12px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

body.nfs-single-page .chapters-title {
    font-size: 16px;
    color: #ffffff;
    font-weight: 500 ;
    margin: 15px 0 8px;
}

/* === COMMENTS === */
body.nfs-single-page .comments-section {
    background-color: rgba(255, 255, 255, 0.03) !important;
    border-radius: 16px !important;
    padding: 25px !important;
    margin: 30px auto 50px !important;
    color: #ddd !important;
    max-width: 800px !important;
}
body.nfs-single-page .comments-section h2 {
    color: #3ea6ff !important;
    font-size: 20px !important;
    margin-bottom: 15px !important;
}
body.nfs-single-page .comments-section p {
    color: #ccc !important;
    font-size: 15px !important;
}

body.nfs-single-page .nfs-video-container {
    max-width: 800px;
    margin: 20px auto;
    position: relative;
    width: 100%;
    padding-top: 56.25%;  
}
  
body.nfs-single-page .nfs-video-container iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: none;
    border-radius: 12px;
}
  
/* Emojis des Articles/Guides */
body.nfs-single-page .nfs-reaction-btn-articles.selected {
    background-color: #e6ffe6;
    border-radius: 8px;
    font-weight: bold;
}

body.nfs-single-page .nfs-reaction-btn-articles.active {
    animation: nfsBounce 0.3s ease;
}

@keyframes nfsBounce {
    0%   { transform: scale(1); }
    50%  { transform: scale(1.3); }
    100% { transform: scale(1); }
}

@keyframes emojiPulse {
    0%   { transform: scale(1); }
    30%  { transform: scale(1.8) rotate(15deg); }
    60%  { transform: scale(0.9) rotate(-15deg); }
    100% { transform: scale(1) rotate(0); }
}

body.nfs-single-page .nfs-reaction-btn-articles {
    all: unset;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 1.4rem;
    padding: 6px 10px;
    border-radius: 8px;
    transition: background 0.2s ease;
    background: none !important;
    border: none !important;
    box-shadow: none !important;
    color: inherit !important;
    overflow: visible !important;
    position: relative !important;
}

body.nfs-single-page .nfs-reaction-main-emoji {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.25em;
    height: 1.25em;
    line-height: 1;
    flex: 0 0 auto;
    overflow: visible;
    isolation: isolate;
}

body.nfs-single-page .nfs-reaction-main-emoji img.emoji,
body.nfs-single-page .nfs-reaction-main-emoji img.wp-smiley,
body.nfs-single-page .nfs-reaction-main-emoji img.emojioneemoji {
    width: 1em !important;
    height: 1em !important;
    margin: 0 !important;
    vertical-align: middle !important;
}

body.nfs-single-page .nfs-reaction-main-icon {
    color: rgba(226, 233, 244, 0.86);
}

body.nfs-single-page .nfs-reaction-btn-articles[data-reaction="love"] {
    --nfs-reaction-accent: #22c55e;
    --nfs-reaction-accent-light: #86efac;
    --nfs-reaction-accent-soft: rgba(34, 197, 94, 0.14);
    --nfs-reaction-accent-glow: rgba(34, 197, 94, 0.34);
}

body.nfs-single-page .nfs-reaction-btn-articles[data-reaction="meh"] {
    --nfs-reaction-accent: #ef4444;
    --nfs-reaction-accent-light: #fca5a5;
    --nfs-reaction-accent-soft: rgba(239, 68, 68, 0.14);
    --nfs-reaction-accent-glow: rgba(239, 68, 68, 0.34);
}

body.nfs-single-page .nfs-reaction-icon {
    width: 1.05em;
    height: 1.05em;
    display: block;
    stroke: currentColor;
    transition: color 0.18s ease, transform 0.18s ease;
}

body.nfs-single-page .nfs-reaction-btn-articles[data-reaction="love"] .nfs-reaction-icon,
body.nfs-single-page .nfs-reaction-btn-articles[data-reaction="meh"] .nfs-reaction-icon {
    color: #cdd8e8;
}

body.nfs-single-page .nfs-reaction-btn-articles:hover .nfs-reaction-icon,
body.nfs-single-page .nfs-reaction-btn-articles.selected .nfs-reaction-icon {
    transform: translateY(-1px);
}

body.nfs-single-page .nfs-reaction-btn-articles[data-reaction="love"]:hover .nfs-reaction-icon,
body.nfs-single-page .nfs-reaction-btn-articles[data-reaction="love"].selected .nfs-reaction-icon,
body.nfs-single-page .nfs-reaction-btn-articles[data-reaction="meh"]:hover .nfs-reaction-icon,
body.nfs-single-page .nfs-reaction-btn-articles[data-reaction="meh"].selected .nfs-reaction-icon {
    color: var(--nfs-reaction-accent);
}

body.nfs-single-page .nfs-reaction-main-emoji.animate {
    animation: nfsSingleReactionPulse 0.5s ease;
}

body.nfs-single-page .nfs-reaction-main-emoji .nfs-reaction-effect,
body.nfs-single-page .nfs-reaction-main-icon .nfs-reaction-effect {
    position: absolute !important;
    display: block !important;
    top: 50% !important;
    left: 50% !important;
    width: 0 !important;
    height: 0 !important;
    transform: translate(-50%, -50%) !important;
    pointer-events: none !important;
    z-index: 10 !important;
}

body.nfs-single-page .nfs-reaction-main-emoji .nfs-reaction-effect::before,
body.nfs-single-page .nfs-reaction-main-icon .nfs-reaction-effect::before {
    content: "";
    position: absolute;
    width: 2.25rem;
    height: 2.25rem;
    margin: -1.125rem 0 0 -1.125rem;
    border: 1px solid var(--nfs-reaction-accent);
    border-radius: 999px;
    opacity: 0;
    animation: nfsSingleReactionRipple 0.62s ease-out forwards;
}

body.nfs-single-page .nfs-reaction-main-emoji .nfs-reaction-particle,
body.nfs-single-page .nfs-reaction-main-icon .nfs-reaction-particle {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 0.72rem !important;
    height: 0.16rem !important;
    margin: -0.08rem 0 0 -0.36rem !important;
    border-radius: 999px !important;
    background: var(--nfs-reaction-particle-color, var(--nfs-reaction-accent)) !important;
    box-shadow: 0 0 12px var(--nfs-reaction-particle-glow, var(--nfs-reaction-accent-glow)) !important;
    font-size: 0 !important;
    line-height: 1 !important;
    transform-origin: 50% 50% !important;
    animation: nfsSingleReactionBurst 0.68s cubic-bezier(0.16, 1, 0.3, 1) var(--delay, 0s) forwards !important;
    will-change: transform, opacity;
}

body.nfs-single-page .nfs-reaction-particle.is-primary {
    --nfs-reaction-particle-color: var(--nfs-reaction-accent);
    --nfs-reaction-particle-glow: var(--nfs-reaction-accent-glow);
}

body.nfs-single-page .nfs-reaction-particle.is-secondary {
    --nfs-reaction-particle-color: rgba(255, 255, 255, 0.88);
    --nfs-reaction-particle-glow: rgba(255, 255, 255, 0.26);
}

body.nfs-single-page .nfs-reaction-particle.is-accent {
    --nfs-reaction-particle-color: var(--nfs-reaction-accent-light);
    --nfs-reaction-particle-glow: var(--nfs-reaction-accent-glow);
}

@keyframes nfsSingleReactionPulse {
    0% { transform: scale(1) rotate(0deg); }
    30% { transform: scale(1.35) rotate(12deg); }
    62% { transform: scale(0.92) rotate(-10deg); }
    100% { transform: scale(1) rotate(0deg); }
}

@keyframes nfsSingleReactionRipple {
    0% {
        opacity: 0;
        transform: scale(0.42);
    }
    28% {
        opacity: 0.52;
    }
    100% {
        opacity: 0;
        transform: scale(1.18);
    }
}

@keyframes nfsSingleReactionBurst {
    0% {
        opacity: 0;
        transform: rotate(var(--burst-angle)) translateX(7px) scaleX(0.42);
    }
    18% {
        opacity: 1;
        transform: rotate(var(--burst-angle)) translateX(14px) scaleX(1);
    }
    100% {
        opacity: 0;
        transform: rotate(var(--burst-angle)) translateX(32px) scaleX(0.16);
    }
}

@media (prefers-reduced-motion: reduce) {
    body.nfs-single-page .nfs-reaction-main-emoji.animate {
        animation: none;
    }

    body.nfs-single-page .nfs-reaction-main-emoji .nfs-reaction-effect,
    body.nfs-single-page .nfs-reaction-main-icon .nfs-reaction-effect {
        display: none !important;
    }
}

body.nfs-single-page .nfs-reaction-btn-articles:hover {
    background: rgba(255,255,255,0.05);
}

body.nfs-single-page .nfs-reaction-btn-articles.selected {
    background-color: rgba(255, 255, 255, 0.07);
    font-weight: bold;
    border-radius: 8px;
}

body.nfs-single-page .nfs-reaction-btn-articles[data-reaction="love"].selected {
    background-color: var(--nfs-reaction-accent-soft);
}

body.nfs-single-page .nfs-reaction-btn-articles[data-reaction="meh"].selected {
    background-color: var(--nfs-reaction-accent-soft);
}
body.nfs-single-page .nfs-reaction-btn-articles:focus,
body.nfs-single-page .nfs-reaction-btn-articles:active {
    outline: none !important;
    background: none !important;
    box-shadow: none !important;
    color: inherit !important;
}

body.nfs-single-page .nfs-video-share-button,
body.nfs-single-page .nfs-video-cast-button,
body.nfs-single-page .nfs-flag-button {
    all: unset;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.4rem;
    height: 1.4rem;
    transition: color .2s ease;
    background: transparent !important;
}

body.nfs-single-page .nfs-video-share-button {
    color: #b8c6e4;
}

body.nfs-single-page .nfs-video-share-button svg {
    display: block;
    width: 20px;
    height: 20px;
}

body.nfs-single-page .nfs-video-cast-button {
    color: #8ab4ff;
}

body.nfs-single-page .nfs-video-cast-button[hidden] {
    display: none !important;
}

body.nfs-single-page .nfs-flag-button {
    color: #e74c3c;
}

body.nfs-single-page .nfs-video-share-button:hover,
body.nfs-single-page .nfs-video-share-button.is-copied {
    color: #f1d785;
    background: transparent !important;
}

body.nfs-single-page .nfs-video-cast-button:hover {
    color: #b7cdfd;
    background: transparent !important;
}

body.nfs-single-page .nfs-flag-button:hover {
    color: #c0392b;
    background: transparent !important;
}

/* commentaires */

#nfs-vl-comments {
  max-width: 100%;
  margin-top: 32px;
}

.nfs-vl-comments-title {
  font-size: 18px;
  margin-bottom: 16px;
}

.nfs-vl-comment {
  display: flex;
  gap: 12px;
  margin-bottom: 18px;
  max-width: 100%;
  min-width: 0;
}

.nfs-vl-comment-avatar {
  width: 35px;
  height: 35px;
  border-radius: 50%;
}

.nfs-vl-comment-meta {
    font-size: 13px;
    color: #ffffff;
}

.nfs-vl-comment-meta strong {
    color: #ffffff;
    margin-right: 8px;
}

.nfs-vl-comment-content {
    color: #ffffff;
    font-size: 14px;
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.nfs-vl-comment-form {
  display: flex;
  gap: 12px;
  margin-bottom: 24px;
}

.nfs-vl-comment-form img.avatar,
.nfs-vl-comment-form .avatar {
  flex: 0 0 35px;
}

.nfs-vl-comment-input textarea {
  width: 100%;
  background: transparent;
  border: none;
  border-bottom: 1px solid #333;
  color: #ffffff;
  resize: none;
  overflow-y: hidden;
}

.nfs-vl-comment-input button {
    margin-top: 8px;
    background: #ffffff1a;
    border: none;
    color: #000;
    padding: 6px 14px;
    border-radius: 999px;
    cursor: pointer;
}

.nfs-vl-author .user-badge {
  margin-left: 6px;
  vertical-align: middle;
}

.nfs-vl-author .profile-badge {
  height: 16px;
  width: auto;
}

/* ==========================================
   Layout single.php – YouTube-style
   ========================================== */
body.nfs-single-page .nfs-single-layout {
    display: grid;
    gap: 24px;
    padding: 16px;
}

.nfs-single-main,
.nfs-single-sidebar {
    min-width: 0;
}

.nfs-video-container-article {
    position: relative;
    background: #000;
    border-radius: 14px;
    overflow: hidden;
    aspect-ratio: 16 / 9;
}

.nfs-video-iframe {
    width: 100%;
    height: 100%;
    border: 0;
    display: block;
}

.nfs-video-missing {
    color: #ff6b6b;
    text-align: center;
    margin: 24px 0;
}

.nfs-single-main .nfs-video-meta-block {
    max-width: 100% !important;
    margin: 16px 0 24px !important;
    padding: 0 !important;
}

.nfs-single-main .comments-section {
    max-width: 100% !important;
    margin: 24px 0 40px !important;
}

.reaction-bar {
    height: 6px;
    background: rgba(255, 255, 255, 0.12);
    border-radius: 999px;
    overflow: hidden;
    margin: 6px 0;
}

.bar-love-articles {
    height: 100%;
    width: 0;
    background: linear-gradient(90deg, #6ee7ff, #3ea6ff);
}

#nfs-feedback-msg-articles {
    display: none;
    margin-top: 6px;
    color: #a7f3d0;
}

.nfs-description-empty,
.nfs-comments-disabled {
    text-align: center;
    color: #9ca3af;
}

.article-desc-full[hidden] {
    display: none;
}

.nfs-comments-wrapper {
    margin-top: 24px;
}

.nfs-sidebar-block {
    background: rgba(255, 255, 255, 0.04);
    border-radius: 16px;
    padding: 16px;
    margin-bottom: 16px;
}

.nfs-sidebar-title {
    font-size: 16px;
    color: #ffffff;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 12px;
}

.nfs-suggested-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 12px;
}

.nfs-suggested-item {
    display: grid;
    grid-template-columns: 120px 1fr;
    gap: 12px;
    align-items: center;
}

.nfs-suggested-thumb {
    width: 100%;
    aspect-ratio: 16 / 9;
    border-radius: 10px;
    background: linear-gradient(135deg, #1f2937, #111827);
}

.nfs-suggested-title {
    margin: 0;
    font-size: 14px;
    color: #ffffff;
}

.nfs-suggested-sub {
    margin: 4px 0 0;
    font-size: 12px;
    color: #ffffff;
}

.nfs-playlists-placeholder {
    color: #ffffff;
    font-size: 14px;
}

.report-modal {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    justify-content: center;
    align-items: center;
    z-index: 9999;
    padding: 20px;
}

.report-modal__dialog {
    background: #fff;
    color: #111;
    padding: 20px;
    border-radius: 10px;
    max-width: 400px;
    width: 100%;
}

.report-modal__label {
    display: block;
    font-weight: 600;
    margin: 12px 0 6px;
}

.report-required {
    color: #e74c3c;
}

.report-modal__select,
.report-modal__textarea {
    width: 100%;
    margin-bottom: 10px;
}

.report-modal__actions {
    text-align: right;
    display: flex;
    justify-content: flex-end;
    gap: 8px;
}

.nfs-suggested-link {
    display: grid;
    grid-template-columns: 120px 1fr;
    gap: 12px;
    text-decoration: none;
    color: inherit;
}

.nfs-suggested-thumb-wrapper {
    position: relative;
    aspect-ratio: 16 / 9;
    border-radius: 10px;
    overflow: hidden;
}

.nfs-suggested-thumb,
.nfs-suggested-preview {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.nfs-suggested-preview {
    opacity: 0;
    transition: opacity .25s ease;
}

.nfs-suggested-link:hover .nfs-suggested-preview {
    opacity: 1;
}

.nfs-suggested-thumb-wrapper .video-duration {
    position: absolute;
    right: 8px;
    bottom: 8px;
    z-index: 5;
    pointer-events: none;
    padding: 4px 8px;
    border-radius: 6px;
    background: rgba(0, 0, 0, 0.82);
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.2px;
}

.nfs-sidebar-empty {
    color: #9ca3af;
    font-size: 14px;
}

/* === Commentaires vidéo longue – interactions === */
.nfs-vl-comment-body {
    flex: 1;
    min-width: 0;
    max-width: 100%;
}

.nfs-vl-comment-actions {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 6px;
    font-size: 12px;
    color: #555;
}

.nfs-vl-reaction-count {
    min-width: 16px;
    text-align: center;
    font-size: 12px;
    color: #555;
}

/* Groupe compteur + icône = inline, jamais en colonne */
.nfs-vl-reaction-group {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.nfs-vl-action-btn {
    background: transparent;
    border: none;
    color: #ffffff;
    font-size: 12px;
    padding: 2px 6px;
    cursor: pointer;
    transition: transform .16s ease, opacity .16s ease;
}

.nfs-vl-action-btn:hover {
    text-decoration: underline;
}

.nfs-vl-comment-tools {
    display: flex;
    gap: 12px;
    margin-top: 6px;
}

.nfs-vl-tool-btn {
    background: transparent;
    border: none;
    color: #555;
    font-size: 12px;
    cursor: pointer;
    padding: 2px 0;
    transition: transform .16s ease, opacity .16s ease;
}

.nfs-vl-tool-btn:hover {
    text-decoration: underline;
}

.nfs-vl-reply-box {
    margin-top: 8px;
}

.nfs-vl-reply-text,
.nfs-vl-edit-text {
    width: 100%;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    padding: 8px;
    font-size: 13px;
    resize: none;
    overflow-y: hidden;
}

.nfs-vl-reply-actions,
.nfs-vl-edit-actions {
    display: flex;
    gap: 8px;
    margin-top: 6px;
}

.nfs-vl-children {
    margin-top: 12px;
    padding-left: 20px;
    border-left: 2px solid rgba(0, 0, 0, 0.08);
}

.nfs-vl-comment.is-child {
    margin-top: 12px;
}

.nfs-vl-comment.is-deleted .nfs-vl-comment-content {
    color: #777;
    font-style: italic;
}

/* ================================================= */
/* BOUTON RÉACTION – mode bulldozer                  */
/* ================================================= */

body.nfs-single-page .nfs-vl-reaction-btn {
    background: transparent !important;
    border: none !important;
    padding: 4px !important;
    border-radius: 999px !important;

    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;

    cursor: pointer !important;

    color: #ffffff !important;

    box-shadow: none !important;
    outline: none !important;
    filter: none !important;
    transform: none !important;
}


/* ================================================= */
/* SVG – ÉCRASÉ TOTAL                                */
/* ================================================= */

body.nfs-single-page .nfs-vl-reaction-btn svg {
    width: 18px !important;
    height: 18px !important;

    fill: none !important;
    stroke: #ffffff !important;
    stroke-width: 1.8 !important;

    opacity: 1 !important;

    transition: transform .15s ease !important;
    pointer-events: none !important;
}


/* ================================================= */
/* HOVER – RIEN (juste zoom)                         */
/* ================================================= */

body.nfs-single-page .nfs-vl-reaction-btn:hover svg {
    transform: scale(1.1) !important;
}

body.nfs-single-page .nfs-vl-reaction-btn svg path,
body.nfs-single-page .nfs-vl-reaction-btn svg use,
body.nfs-single-page .nfs-vl-reaction-btn svg g {
    fill: transparent !important;
    stroke: #ffffff !important;
}


/* ================================================= */
/* ACTIF – REMPLISSAGE + FEEDBACK                    */
/* ================================================= */

body.nfs-single-page .nfs-vl-reaction-btn.is-active svg {
    fill: #ffffff !important;
    stroke: #ffffff !important;
    transform: scale(1.15) !important;
}

body.nfs-single-page .nfs-vl-reaction-btn.is-active svg path,
body.nfs-single-page .nfs-vl-reaction-btn.is-active svg use,
body.nfs-single-page .nfs-vl-reaction-btn.is-active svg g {
    fill: #ffffff !important;
    stroke: #ffffff !important;
}

@media (min-width: 1024px) {
    body.nfs-single-page .nfs-single-layout {
        grid-template-columns: minmax(0, 1fr) 360px;
        align-items: start;
    }

    body.nfs-single-page .nfs-single-sidebar {
        position: sticky;
        top: 24px;
    }
}

@media (max-width: 768px) {
    body.nfs-single-page .nfs-single-layout {
        grid-template-columns: 1fr;
        gap: 16px;
        padding: 12px;
    }

    body.nfs-single-page .nfs-single-main .nfs-video-meta-block {
        margin-top: 12px !important;
    }

    body.nfs-single-page .nfs-video-container-article {
        width: 100%;
    }

    body.nfs-single-page .video-title {
        font-size: 20px !important;
        margin: 10px 0 !important;
    }

    body.nfs-single-page .video-info-row {
        align-items: flex-start !important;
        gap: 10px !important;
    }

    body.nfs-single-page .author-section,
    body.nfs-single-page .reactions-section,
    body.nfs-single-page .views-section {
        width: 100%;
    }

    body.nfs-single-page .reactions-section {
        display: flex;
        flex-wrap: wrap;
        gap: 10px;
        align-items: center;
    }

    body.nfs-single-page .nfs-reaction-btn-articles {
        padding: 8px 12px;
        font-size: 1.6rem;
    }

    body.nfs-single-page .mycred-share-buttons {
        display: flex;
        flex-wrap: wrap;
        gap: 10px;
        align-items: center;
    }

    body.nfs-single-page .nfs-video-share-button,
    body.nfs-single-page .nfs-video-cast-button,
    body.nfs-single-page .nfs-flag-button {
        width: 44px;
        height: 44px;
    }

    body.nfs-single-page .nfs-single-sidebar {
        margin-top: 8px;
    }

    body.nfs-single-page .nfs-sidebar-block {
        padding: 14px;
    }

    body.nfs-single-page .nfs-suggested-item {
        grid-template-columns: 96px 1fr;
    }

    body.nfs-single-page .comments-section {
        padding: 18px !important;
    }

    body.nfs-single-page .nfs-vl-comment {
        gap: 10px;
    }

    body.nfs-single-page .nfs-vl-comment-actions {
        gap: 10px;
    }
}

@media (min-width: 769px) and (max-width: 1024px) {
    body.nfs-single-page .nfs-single-layout {
        grid-template-columns: 1fr;
        gap: 20px;
        padding: 20px;
    }

    body.nfs-single-page .nfs-single-main .nfs-video-meta-block {
        margin-top: 16px !important;
    }

    body.nfs-single-page .video-title {
        font-size: 22px !important;
    }

    body.nfs-single-page .video-info-row {
        flex-wrap: wrap !important;
        gap: 12px !important;
    }

    body.nfs-single-page .reactions-section {
        display: flex;
        flex-wrap: wrap;
        gap: 12px;
        align-items: center;
    }

    body.nfs-single-page .nfs-reaction-btn-articles {
        padding: 8px 12px;
    }

    body.nfs-single-page .mycred-share-buttons {
        display: flex;
        flex-wrap: wrap;
        gap: 10px;
        align-items: center;
    }

    body.nfs-single-page .nfs-video-share-button,
    body.nfs-single-page .nfs-video-cast-button,
    body.nfs-single-page .nfs-flag-button {
        width: 40px;
        height: 40px;
    }

    body.nfs-single-page .nfs-single-sidebar {
        margin-top: 12px;
    }

    body.nfs-single-page .comments-section {
        padding: 20px !important;
    }
}

@media (max-width: 640px) {
    body.nfs-single-page .nfs-video-title-row {
        flex-wrap: wrap;
        align-items: flex-start;
    }

    body.nfs-single-page .mycred-share-buttons {
        margin-left: auto;
    }
}
@media (min-width: 768px) {
    body.nfs-single-page .nfs-single-layout {
        padding: 24px;
    }
}

/* === RESPONSIVE === */
@media (max-width: 768px) {
    .guide-header {
        flex-direction: column !important;
        text-align: center !important;
    }
    .guide-header h1 {
        margin-left: 0 !important;
        margin-top: 10px !important;
    }
}

/* ==========================================
   SPA-05 – Architecture single refondue
   ========================================== */

body.nfs-single-page .nfs-single-layout {
    display: flex !important;
    flex-direction: column;
    gap: 28px;
    padding: 18px 18px 42px !important;
    --nfs-single-video-height: min(calc((100vw - 36px) * 9 / 16), calc(100vh - 190px));
    --nfs-reaction-color: #ffffff;
}

body.nfs-single-page .nfs-single-hero {
    width: 100%;
    max-width: 100%;
    margin: 0;
}

body.nfs-single-page .nfs-video-container-article {
    width: 100%;
    height: var(--nfs-single-video-height);
    border-radius: 22px;
    overflow: hidden;
    background:
        radial-gradient(circle at top left, rgba(255,255,255,.08), transparent 32%),
        linear-gradient(180deg, rgba(8,11,18,.92), rgba(4,5,8,.96));
    box-shadow:
        0 24px 80px rgba(0, 0, 0, 0.38),
        inset 0 1px 0 rgba(255,255,255,0.08);
}

body.nfs-single-page .nfs-single-body {
    width: 100%;
    max-width: 100%;
    margin: 0;
    display: grid;
    grid-template-columns: minmax(0, 1.75fr) minmax(300px, 0.75fr);
    gap: 28px;
    align-items: start;
}

body.nfs-single-page .nfs-single-main {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 24px;
}

body.nfs-single-page .nfs-single-sidebar {
    min-width: 0;
    position: sticky;
    top: 24px;
    align-self: start;
}

body.nfs-single-page .nfs-video-meta-block,
body.nfs-single-page .nfs-single-comments-panel,
body.nfs-single-page .nfs-sidebar-block {
    background:
        linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.03));
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 20px;
    box-shadow: 0 18px 48px rgba(0, 0, 0, 0.24);
    backdrop-filter: blur(8px);
}

body.nfs-single-page .nfs-video-meta-block {
    max-width: 100% !important;
    margin: 0 !important;
    padding: 22px 24px 24px !important;
}

body.nfs-single-page .nfs-single-comments-panel {
    padding: 22px 24px 24px;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
    min-width: 0;
    max-width: 100%;
}

body.nfs-single-page .nfs-sidebar-block {
    padding: 18px;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
}

body.nfs-single-page .nfs-video-title-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 18px;
    margin-bottom: 16px;
}

body.nfs-single-page .video-title {
    margin: 0;
    font-size: clamp(28px, 3vw, 38px);
    line-height: 1.15;
    font-weight: 700;
    letter-spacing: -0.02em;
}

body.nfs-single-page .mycred-share-buttons {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 10px;
}

body.nfs-single-page .video-info-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 0;
    margin-bottom: 18px;
}

body.nfs-single-page .author-section {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

body.nfs-single-page .author-name {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
}

body.nfs-single-page .author-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
}

body.nfs-single-page .reactions-section {
    margin-left: auto;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}

body.nfs-single-page .video-description {
    margin-top: 0;
    padding: 18px 18px 20px;
    border-radius: 18px;
    background: rgba(0, 0, 0, 0.16);
    border: 1px solid rgba(255,255,255,0.05);
}

body.nfs-single-page .views-section {
    margin-left: 0;
    margin-bottom: 14px;
    font-size: 13px;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.72);
}

body.nfs-single-page #article-description p,
body.nfs-single-page .article-desc-full p,
body.nfs-single-page .article-desc-short,
body.nfs-single-page .nfs-description-empty {
    margin: 0;
    font-size: 15px;
    line-height: 1.7;
    color: #f5f7fb;
}

body.nfs-single-page #article-description a {
    color: #ffffff;
    font-weight: 600;
}

body.nfs-single-page .article-desc-full,
body.nfs-single-page .article-desc-short {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

body.nfs-single-page .article-chapters {
    padding-top: 6px;
    display: grid;
    gap: 8px;
}

body.nfs-single-page .article-chapters p {
    margin: 0;
}

body.nfs-single-page .chapters-title {
    margin: 0 0 4px;
    font-size: 14px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.74);
}

body.nfs-single-page .nfs-sidebar-title {
    margin: 0 0 14px;
    font-size: 13px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.72);
}

body.nfs-single-page .nfs-suggested-list {
    gap: 14px;
}

body.nfs-single-page .nfs-suggested-item {
    display: block;
}

body.nfs-single-page .nfs-suggested-link {
    display: grid;
    grid-template-columns: 128px minmax(0, 1fr);
    gap: 12px;
}

body.nfs-single-page .nfs-suggested-link {
    align-items: stretch;
    padding: 8px;
    border-radius: 14px;
    transition: background .2s ease, transform .2s ease;
}

body.nfs-single-page .nfs-suggested-link:hover {
    background: rgba(255,255,255,0.05);
    transform: translateY(-1px);
}

body.nfs-single-page .nfs-suggested-thumb-wrapper {
    aspect-ratio: 16 / 9;
    border-radius: 8px;
    background: rgba(255,255,255,0.04);
}

body.nfs-single-page .nfs-suggested-meta {
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

body.nfs-single-page .nfs-suggested-title {
    margin: 0;
    font-size: 14px;
    line-height: 1.45;
    color: #ffffff;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    overflow-wrap: anywhere;
    word-break: break-word;
}

body.nfs-single-page .nfs-suggested-author {
    margin: 6px 0 0;
    font-size: 12px;
    line-height: 1.45;
    color: rgba(255,255,255,0.82);
}

body.nfs-single-page .nfs-suggested-sub {
    margin: 8px 0 0;
    font-size: 12px;
    line-height: 1.5;
    color: rgba(255,255,255,0.66);
    overflow-wrap: anywhere;
}

body.nfs-single-page #nfs-vl-comments {
    margin-top: 0;
    max-width: 100%;
    min-width: 0;
}

body.nfs-single-page .nfs-vl-comments-title {
    margin: 0 0 18px;
    font-size: 20px;
    color: #ffffff;
}

body.nfs-single-page .nfs-vl-comment-form {
    align-items: flex-start;
    padding-bottom: 18px;
    margin-bottom: 22px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}

body.nfs-single-page .nfs-vl-comment-input {
    flex: 1;
    min-width: 0;
    position: relative;
}

body.nfs-single-page .nfs-vl-reply-box,
body.nfs-single-page .nfs-vl-edit-box {
    position: relative;
}

body.nfs-single-page .nfs-vl-comment-submit-row,
body.nfs-single-page .nfs-vl-reply-actions,
body.nfs-single-page .nfs-vl-edit-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

body.nfs-single-page .nfs-vl-comment-submit-row {
    margin-top: 10px;
}

body.nfs-single-page .nfs-vl-nestia-group {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

body.nfs-single-page .nfs-vl-comment-input textarea,
body.nfs-single-page .nfs-vl-reply-text,
body.nfs-single-page .nfs-vl-edit-text {
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 12px;
    color: #ffffff;
    padding: 12px 14px;
}

body.nfs-single-page .nfs-vl-comment-input textarea::placeholder,
body.nfs-single-page .nfs-vl-reply-text::placeholder,
body.nfs-single-page .nfs-vl-edit-text::placeholder {
    color: rgba(255,255,255,0.48);
}

body.nfs-single-page .nfs-vl-comment-input button,
body.nfs-single-page .nfs-vl-action-btn {
    color: #ffffff;
}

body.nfs-single-page .nfs-vl-mention-suggestions {
    position: absolute;
    left: 0;
    right: 0;
    bottom: calc(100% + 8px);
    list-style: none;
    margin: 0;
    padding: 0;
    background: rgba(9, 18, 34, 0.98);
    border: 1px solid rgba(149, 164, 202, 0.18);
    border-radius: 12px;
    box-shadow: 0 18px 48px rgba(3, 9, 20, 0.34);
    overflow: hidden;
    z-index: 20;
    max-height: 240px;
    overflow-y: auto;
}

body.nfs-single-page .nfs-vl-mention-suggestions[hidden] {
    display: none;
}

body.nfs-single-page .nfs-vl-mention-suggestions li {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    cursor: pointer;
    color: #fff;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

body.nfs-single-page .nfs-vl-mention-suggestions li:last-child {
    border-bottom: 0;
}

body.nfs-single-page .nfs-vl-mention-suggestions li:hover,
body.nfs-single-page .nfs-vl-mention-suggestions li.is-active {
    background: rgba(255, 255, 255, 0.08);
}

body.nfs-single-page .nfs-vl-mention-suggestions img,
body.nfs-single-page .nfs-vl-mention-fallback {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    flex: 0 0 32px;
}

body.nfs-single-page .nfs-vl-mention-fallback {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
    font-size: 14px;
    font-weight: 700;
}

body.nfs-single-page .nfs-vl-mention-copy {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

body.nfs-single-page .nfs-vl-mention-copy strong,
body.nfs-single-page .nfs-vl-mention-copy span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

body.nfs-single-page .nfs-vl-mention-copy span {
    color: rgba(255, 255, 255, 0.62);
    font-size: 12px;
}

body.nfs-single-page .nfs-vl-comment-input button {
    padding: 8px 16px;
    background: rgba(255,255,255,0.12);
    border-radius: 999px;
    transition: transform .16s ease, opacity .16s ease;
}

body.nfs-single-page .nfs-vl-nestia-btn {
    padding: 8px 14px;
    border-radius: 999px;
    border: 1px solid rgba(233, 180, 37, 0.42);
    background: rgba(233, 180, 37, 0.08);
    color: #f6d36a !important;
}

body.nfs-single-page .nfs-vl-nestia-btn[disabled] {
    opacity: 0.7;
    transform: none !important;
    cursor: wait;
}

body.nfs-single-page .nfs-vl-comment-input button:hover,
body.nfs-single-page .nfs-vl-comment-input button:focus,
body.nfs-single-page .nfs-vl-comment-input button:active,
body.nfs-single-page .nfs-vl-action-btn:hover,
body.nfs-single-page .nfs-vl-action-btn:focus,
body.nfs-single-page .nfs-vl-action-btn:active,
body.nfs-single-page .nfs-vl-tool-btn:hover,
body.nfs-single-page .nfs-vl-tool-btn:focus,
body.nfs-single-page .nfs-vl-tool-btn:active {
    background: transparent !important;
    background-color: transparent !important;
    box-shadow: none !important;
    outline: none !important;
}

body.nfs-single-page .nfs-vl-comment-input button:hover,
body.nfs-single-page .nfs-vl-comment-input button:focus,
body.nfs-single-page .nfs-vl-comment-input button:active {
    color: #ffffff !important;
    border-color: transparent !important;
    transform: scale(1.04);
}

body.nfs-single-page .nfs-vl-action-btn:hover,
body.nfs-single-page .nfs-vl-action-btn:focus,
body.nfs-single-page .nfs-vl-action-btn:active,
body.nfs-single-page .nfs-vl-tool-btn:hover,
body.nfs-single-page .nfs-vl-tool-btn:focus,
body.nfs-single-page .nfs-vl-tool-btn:active {
    color: #ffffff !important;
    text-decoration: none !important;
    transform: scale(1.04);
}

body.nfs-single-page .nfs-vl-comment {
    margin-bottom: 18px;
    max-width: 100%;
    min-width: 0;
}

body.nfs-single-page .nfs-vl-comment-body {
    min-width: 0;
    max-width: 100%;
}

body.nfs-single-page .nfs-vl-comment-content,
body.nfs-single-page .nfs-vl-comment-content * {
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: break-word;
}

body.nfs-single-page .nfs-vl-comment-meta,
body.nfs-single-page .nfs-vl-comment-meta strong,
body.nfs-single-page .nfs-vl-comment-content,
body.nfs-single-page .nfs-vl-reaction-count,
body.nfs-single-page .nfs-vl-tool-btn,
body.nfs-single-page .nfs-vl-action-btn,
body.nfs-single-page .nfs-vl-login-required {
    color: #ffffff;
}

body.nfs-single-page .nfs-vl-comment-meta span,
body.nfs-single-page .nfs-vl-tool-btn {
    color: rgba(255,255,255,0.62);
}

body.nfs-single-page .nfs-vl-comment-actions,
body.nfs-single-page .nfs-vl-comment-tools {
    margin-top: 8px;
}

body.nfs-single-page .report-modal__dialog {
    background:
        linear-gradient(180deg, rgba(18,22,31,0.98), rgba(9,11,16,0.98));
    color: #ffffff !important;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 16px;
    box-shadow: 0 24px 64px rgba(0,0,0,0.45);
}

body.nfs-single-page .report-modal__dialog h2,
body.nfs-single-page .report-modal__label {
    color: #ffffff !important;
}

body.nfs-single-page .report-modal__select,
body.nfs-single-page .report-modal__textarea {
    background: rgba(255,255,255,0.05);
    color: #ffffff !important;
    border: 1px solid rgba(255,255,255,0.12) !important;
    border-radius: 12px;
    padding: 10px 12px;
    box-shadow: none !important;
}

body.nfs-single-page .report-modal__select option {
    color: #111111;
}

body.nfs-single-page .report-modal__textarea::placeholder {
    color: rgba(255,255,255,0.48);
}

body.nfs-single-page .report-modal__actions .button {
    border-radius: 999px;
}

body.nfs-single-page .report-modal__actions .button:not(.button-primary) {
    background: rgba(255,255,255,0.08) !important;
    border-color: rgba(255,255,255,0.12) !important;
    color: #ffffff !important;
}

body.nfs-single-page .report-modal__actions .button.button-primary {
    color: #ffffff !important;
}

body.nfs-single-page .report-required {
    color: #ff7b7b !important;
}

body.nfs-single-page .nfs-vl-children {
    margin-top: 14px;
    padding-left: 16px;
    border-left: 1px solid rgba(255,255,255,0.1);
}

body.nfs-single-page .nfs-vl-timecode-link {
    color: #7ee787;
    font-weight: 700;
    text-decoration: none;
}

body.nfs-single-page .nfs-vl-timecode-link:hover {
    color: #a8f3b3;
    text-decoration: underline;
}

body.nfs-single-page .nfs-sidebar-empty,
body.nfs-single-page .nfs-video-missing,
body.nfs-single-page .nfs-description-empty,
body.nfs-single-page .nfs-vl-login-required {
    color: rgba(255,255,255,0.66);
}

@media (max-width: 1180px) {
    body.nfs-single-page .nfs-single-layout {
        --nfs-single-video-height: calc((100vw - 36px) * 9 / 16);
    }

    body.nfs-single-page .nfs-single-body {
        grid-template-columns: 1fr;
    }

    body.nfs-single-page .nfs-single-sidebar {
        position: static;
        top: auto;
    }
}

@media (max-width: 768px) {
    body.nfs-single-page .nfs-single-layout {
        gap: 18px;
        padding: 12px 12px 28px !important;
        --nfs-single-video-height: calc((100vw - 24px) * 9 / 16);
    }

    body.nfs-single-page .nfs-single-body {
        gap: 18px;
    }

    body.nfs-single-page .nfs-video-meta-block,
    body.nfs-single-page .nfs-single-comments-panel,
    body.nfs-single-page .nfs-sidebar-block {
        padding: 16px !important;
        border-radius: 16px;
    }

    body.nfs-single-page .nfs-video-container-article {
        border-radius: 16px;
    }

    body.nfs-single-page .nfs-video-title-row,
    body.nfs-single-page .video-info-row {
        flex-direction: column;
        align-items: stretch;
    }

    body.nfs-single-page .video-title {
        font-size: 24px !important;
    }

    body.nfs-single-page .mycred-share-buttons,
    body.nfs-single-page .reactions-section {
        justify-content: flex-start;
        margin-left: 0;
    }

    body.nfs-single-page .nfs-suggested-link {
        grid-template-columns: 112px minmax(0, 1fr);
    }

    body.nfs-single-page .nfs-vl-comment-form {
        flex-direction: column;
    }

    body.nfs-single-page .nfs-vl-children {
        padding-left: 12px;
    }
}

/* Single video player flush with the local site chrome */
body.nfs-single-page .nfs-site-header {
    padding-bottom: 0 !important;
}

body.nfs-single-page .nfs-site-main {
    padding-top: 0 !important;
    padding-right: 0 !important;
    padding-left: 0 !important;
}

body.nfs-single-page .nfs-content-shell__stack,
body.nfs-single-page .nfs-content-shell__surface--single,
body.nfs-single-page .nfs-content-shell__surface--single .nfs-content-shell__content {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

body.nfs-single-page .nfs-content-shell__surface--single {
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: visible !important;
}

body.nfs-theme.nfs-single-page .nfs-content-shell__surface--single::before {
    content: none !important;
}

body.nfs-single-page .nfs-single-layout {
    padding: 0 0 42px !important;
}

body.nfs-single-page .nfs-single-body {
    padding: 0 18px;
}

body.nfs-single-page .nfs-video-container-article {
    height: auto !important;
    aspect-ratio: 16 / 9;
    background: #000 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}

body.nfs-single-page .nfs-video-iframe {
    border-radius: 0 !important;
}

html.nfs-android-pip-mode,
body.nfs-android-pip-mode {
    width: 100% !important;
    height: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    background: #000 !important;
}

body.nfs-android-pip-mode .nfs-site-header,
body.nfs-android-pip-mode .nfs-site-footer,
body.nfs-android-pip-mode .nfs-single-body,
body.nfs-android-pip-mode .nfs-content-shell__hero,
body.nfs-android-pip-mode .nfs-content-shell__brand-context,
body.nfs-android-pip-mode .nfs-content-shell__nav,
body.nfs-android-pip-mode .nfs-content-shell__toolbar {
    display: none !important;
}

body.nfs-android-pip-mode .nfs-site-main,
body.nfs-android-pip-mode .nfs-content-shell__stack,
body.nfs-android-pip-mode .nfs-content-shell__surface--single,
body.nfs-android-pip-mode .nfs-content-shell__surface--single .nfs-content-shell__content,
body.nfs-android-pip-mode .nfs-single-layout,
body.nfs-android-pip-mode .nfs-single-hero {
    display: block !important;
    width: 100vw !important;
    height: 100vh !important;
    min-height: 100vh !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    background: #000 !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}

body.nfs-android-pip-mode .nfs-video-container-article {
    position: fixed !important;
    inset: 0 !important;
    z-index: 2147483647 !important;
    width: 100vw !important;
    height: 100vh !important;
    margin: 0 !important;
    padding: 0 !important;
    aspect-ratio: auto !important;
    overflow: hidden !important;
    background: #000 !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}

body.nfs-android-pip-mode .nfs-video-iframe {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    border: 0 !important;
    border-radius: 0 !important;
}

@media (max-width: 768px) {
    body.nfs-single-page .nfs-single-layout {
        padding: 0 0 28px !important;
    }

    body.nfs-single-page .nfs-single-body {
        padding: 0 12px;
    }
}

/* Suggested video previews and modern report modal */
body.nfs-single-page .nfs-suggested-thumb-wrapper {
    position: relative;
    overflow: hidden;
    background: #05070b;
    isolation: isolate;
}

body.nfs-single-page .nfs-suggested-thumb,
body.nfs-single-page .nfs-suggested-preview {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    transition: opacity .28s ease, transform .28s ease;
}

body.nfs-single-page .nfs-suggested-thumb {
    z-index: 1;
}

body.nfs-single-page .nfs-suggested-preview {
    z-index: 2;
    opacity: 0;
    pointer-events: none;
}

body.nfs-single-page .nfs-suggested-link:hover .nfs-suggested-thumb,
body.nfs-single-page .nfs-suggested-link:focus-visible .nfs-suggested-thumb {
    transform: scale(1.03);
}

body.nfs-single-page .nfs-suggested-link:hover .nfs-suggested-preview,
body.nfs-single-page .nfs-suggested-link:focus-visible .nfs-suggested-preview {
    opacity: 1;
    transform: scale(1.03);
}

body.nfs-single-page .report-modal {
    background:
        radial-gradient(circle at top, rgba(233, 180, 37, 0.12), transparent 34%),
        rgba(3, 6, 11, 0.74);
    align-items: center;
    justify-content: center;
    padding: 24px;
    backdrop-filter: blur(14px);
}

body.nfs-single-page .report-modal__dialog {
    width: min(100%, 520px);
    max-width: 520px;
    padding: 24px;
    border: 1px solid rgba(233, 180, 37, 0.18);
    border-radius: 8px;
    background:
        linear-gradient(180deg, rgba(20, 24, 33, 0.98), rgba(8, 10, 15, 0.98));
    box-shadow:
        0 26px 70px rgba(0, 0, 0, 0.48),
        inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

body.nfs-single-page .report-modal__dialog h2 {
    margin: 0 0 18px;
    font-size: 22px;
    line-height: 1.2;
    color: #ffffff;
}

body.nfs-single-page .report-modal__label {
    margin: 16px 0 8px;
    color: rgba(255, 255, 255, 0.82) !important;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

body.nfs-single-page .report-required {
    color: #e9b425 !important;
}

body.nfs-single-page .report-modal__select,
body.nfs-single-page .report-modal__textarea {
    width: 100%;
    min-height: 46px;
    margin: 0;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.055);
    color: #ffffff !important;
    font-size: 15px;
    line-height: 1.45;
    outline: none;
    box-shadow: none !important;
    transition: border-color .18s ease, background .18s ease, box-shadow .18s ease;
}

body.nfs-single-page .report-modal__select {
    padding: 0 38px 0 12px;
}

body.nfs-single-page .report-modal__textarea {
    min-height: 104px;
    padding: 12px;
    resize: vertical;
}

body.nfs-single-page .report-modal__select:focus,
body.nfs-single-page .report-modal__textarea:focus {
    border-color: rgba(233, 180, 37, 0.62) !important;
    background: rgba(255, 255, 255, 0.08);
    box-shadow: 0 0 0 3px rgba(233, 180, 37, 0.12) !important;
}

body.nfs-single-page .report-modal__textarea::placeholder {
    color: rgba(255, 255, 255, 0.42);
}

body.nfs-single-page .report-modal__actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 22px;
}

body.nfs-single-page .report-modal__actions .button {
    min-height: 42px;
    padding: 0 18px;
    border-radius: 8px;
    font-weight: 700;
    border: 1px solid rgba(255, 255, 255, 0.14) !important;
    box-shadow: none !important;
}

body.nfs-single-page .report-modal__actions .button:not(.button-primary) {
    background: rgba(255, 255, 255, 0.07) !important;
    color: rgba(255, 255, 255, 0.88) !important;
}

body.nfs-single-page .report-modal__actions .button.button-primary {
    border-color: rgba(233, 180, 37, 0.68) !important;
    background: linear-gradient(135deg, #e9b425, #d48a2c) !important;
    color: #121212 !important;
}

body.nfs-single-page .report-modal__actions .button:hover,
body.nfs-single-page .report-modal__actions .button:focus-visible {
    transform: translateY(-1px);
}

body.nfs-single-page .nfs-vl-comment-input textarea,
body.nfs-single-page .nfs-vl-reply-text,
body.nfs-single-page .nfs-vl-edit-text {
    min-height: 48px;
    max-height: 260px;
    overflow-y: hidden;
    resize: none;
}

@media (hover: none) {
    body.nfs-single-page .nfs-suggested-preview {
        display: none;
    }
}

@media (max-width: 520px) {
    body.nfs-single-page .report-modal {
        padding: 14px;
    }

    body.nfs-single-page .report-modal__dialog {
        padding: 18px;
    }

    body.nfs-single-page .report-modal__actions {
        flex-direction: column-reverse;
    }

    body.nfs-single-page .report-modal__actions .button {
        width: 100%;
    }
}

@media (max-width: 768px) {
    body.nfs-single-page .nfs-vl-comment-form {
        display: flex;
        flex-direction: row !important;
        align-items: flex-start;
        gap: 10px;
    }

    body.nfs-single-page .nfs-vl-comment-form img.avatar,
    body.nfs-single-page .nfs-vl-comment-form .avatar {
        width: 38px;
        height: 38px;
        flex: 0 0 38px;
    }

    body.nfs-single-page .nfs-vl-comment-input {
        flex: 1 1 auto;
        min-width: 0;
    }

    body.nfs-single-page .nfs-vl-comment-meta {
        min-height: 38px;
        display: flex;
        align-items: center;
    }

    body.nfs-single-page .nfs-vl-comment-submit-row,
    body.nfs-single-page .nfs-vl-reply-actions {
        display: grid;
        align-items: stretch;
        gap: 6px;
        width: 100%;
    }

    body.nfs-single-page .nfs-vl-comment-submit-row {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    body.nfs-single-page .nfs-vl-reply-actions {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    body.nfs-single-page .nfs-vl-comment-submit-row .nfs-vl-nestia-group,
    body.nfs-single-page .nfs-vl-reply-actions .nfs-vl-nestia-group {
        display: contents;
    }

    body.nfs-single-page .nfs-vl-comment-submit-row button,
    body.nfs-single-page .nfs-vl-reply-actions button {
        width: 100%;
        min-width: 0;
        min-height: 36px;
        margin-top: 0;
        padding: 7px 6px;
        font-size: 11px;
        line-height: 1.15;
        white-space: nowrap;
        text-align: center;
    }
}

/* Keep single content sections unframed */
body.nfs-single-page .nfs-video-meta-block,
body.nfs-single-page .nfs-single-comments-panel,
body.nfs-single-page .nfs-sidebar-block,
body.nfs-single-page .nfs-sidebar-suggested {
    background: transparent !important;
    border: 0 !important;
    border-color: transparent !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
}

/* Keep the desktop meta layout on tablet and mobile */
@media (max-width: 1024px) {
    body.nfs-single-page .nfs-video-title-row,
    body.nfs-single-page .video-info-row {
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 16px !important;
    }

    body.nfs-single-page .nfs-video-title-row {
        align-items: flex-start !important;
        margin-bottom: 16px;
    }

    body.nfs-single-page .video-title {
        flex: 1 1 auto;
        min-width: 0;
        margin: 0 !important;
    }

    body.nfs-single-page .mycred-share-buttons,
    body.nfs-single-page .reactions-section {
        width: auto !important;
        margin-left: auto !important;
        flex: 0 0 auto;
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: flex-end !important;
        flex-wrap: nowrap !important;
    }

    body.nfs-single-page .author-section {
        width: auto !important;
        flex: 1 1 auto;
        min-width: 0;
    }

    body.nfs-single-page .views-section {
        width: auto !important;
    }

    body.nfs-single-page .nfs-video-share-button,
    body.nfs-single-page .nfs-video-cast-button,
    body.nfs-single-page .nfs-flag-button {
        width: 1.4rem !important;
        height: 1.4rem !important;
        flex: 0 0 1.4rem;
    }
}

@media (max-width: 480px) {
    body.nfs-single-page .nfs-video-title-row,
    body.nfs-single-page .video-info-row {
        gap: 12px !important;
    }

    body.nfs-single-page .mycred-share-buttons {
        gap: 8px !important;
    }

    body.nfs-single-page .reactions-section {
        gap: 6px !important;
    }

    body.nfs-single-page .author-avatar {
        width: 44px;
        height: 44px;
    }
}

/* Prevent mobile reaction buttons from overlapping the author badge */
@media (max-width: 560px) {
    body.nfs-single-page .video-info-row {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 10px !important;
    }

    body.nfs-single-page .author-section {
        flex: 1 1 auto !important;
        min-width: 0 !important;
        overflow: hidden;
        gap: 8px !important;
    }

    body.nfs-single-page .author-section .author-avatar {
        flex: 0 0 44px;
    }

    body.nfs-single-page .author-name {
        flex: 1 1 auto;
        min-width: 0;
        max-width: 100%;
        overflow: hidden;
        white-space: nowrap;
        text-overflow: ellipsis;
    }

    body.nfs-single-page .author-name img {
        flex: 0 0 auto;
        max-width: 22px;
        max-height: 22px;
    }

    body.nfs-single-page .reactions-section {
        flex: 0 0 auto !important;
        min-width: max-content;
        margin-left: 0 !important;
        gap: 8px !important;
    }

    body.nfs-single-page .nfs-reaction-btn-articles {
        gap: 4px;
        padding: 4px 3px;
        font-size: 1.18rem;
    }
}

.nfs-video-share-sheet {
    position: fixed;
    inset: 0;
    z-index: 100000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 18px;
    background: rgba(2, 8, 23, 0.72);
    backdrop-filter: blur(10px);
}

.nfs-video-share-sheet__panel {
    width: min(100%, 440px);
    max-height: min(560px, calc(100vh - 24px));
    overflow: auto;
    border: 1px solid rgba(125, 171, 255, 0.22);
    border-radius: 18px;
    background: #071225;
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.5);
    color: #f8fbff;
}

.nfs-video-share-sheet__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 18px 20px 12px;
}

.nfs-video-share-sheet__header h3 {
    margin: 0;
    font-size: 18px;
    font-weight: 800;
    line-height: 1.2;
}

.nfs-video-share-sheet__close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border: 0;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.08);
    color: #fff;
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
}

.nfs-video-share-sheet__preview {
    display: grid;
    gap: 6px;
    margin: 0 18px 12px;
    padding: 12px;
    border: 1px solid rgba(125, 171, 255, 0.16);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.045);
}

.nfs-video-share-sheet__preview strong,
.nfs-video-share-sheet__preview span,
.nfs-video-share-sheet__preview small {
    min-width: 0;
    overflow-wrap: anywhere;
}

.nfs-video-share-sheet__preview strong {
    font-size: 15px;
    line-height: 1.35;
}

.nfs-video-share-sheet__preview span {
    color: rgba(236, 244, 255, 0.8);
    font-size: 13px;
    line-height: 1.4;
}

.nfs-video-share-sheet__preview small {
    color: rgba(168, 190, 220, 0.82);
    font-size: 12px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.nfs-video-share-sheet__preview img.emoji,
.nfs-video-share-sheet__preview .emoji {
    display: inline !important;
    width: 1em !important;
    height: 1em !important;
    margin: 0 0.05em !important;
    border-radius: 0 !important;
    background: transparent !important;
    object-fit: contain !important;
    vertical-align: -0.12em !important;
}

.nfs-video-share-sheet__native,
.nfs-video-share-sheet__copy {
    display: flex;
    align-items: center;
    justify-content: center;
    width: calc(100% - 36px);
    min-height: 44px;
    margin: 0 18px 10px;
    border: 0;
    border-radius: 14px;
    color: #fff;
    font-size: 14px;
    font-weight: 800;
    cursor: pointer;
}

.nfs-video-share-sheet__native {
    background: linear-gradient(135deg, #2f6dff, #56a0ff);
}

.nfs-video-share-sheet__copy {
    background: rgba(255, 255, 255, 0.08);
}

.nfs-video-share-sheet__links {
    display: flex;
    gap: 10px;
    margin: 0 18px 12px;
    padding: 2px 0 6px;
    overflow-x: auto;
    overflow-y: hidden;
    overscroll-behavior-x: contain;
    scrollbar-width: thin;
}

.nfs-video-share-sheet__link {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 48px;
    width: 48px;
    height: 48px;
    border: 0;
    border-radius: 50%;
    color: #fff;
    text-decoration: none;
}

.nfs-video-share-sheet__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    color: #fff;
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.22);
}

.nfs-video-share-sheet__icon i {
    display: block;
    color: currentColor;
    font-size: 24px;
    line-height: 1;
}

.nfs-video-share-sheet__icon--whatsapp {
    background: #25d366;
}

.nfs-video-share-sheet__icon--telegram {
    background: #229ed9;
}

.nfs-video-share-sheet__icon--sms {
    background: #3d8bfd;
}

.nfs-video-share-sheet__icon--email {
    background: #f59f00;
}

.nfs-video-share-sheet__icon--x {
    background: #000;
}

.nfs-video-share-sheet__icon--linkedin {
    background: #0a66c2;
}

.nfs-video-share-sheet__label {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
}

.nfs-video-share-sheet__status {
    margin: 0 18px 16px;
    color: #9dd8ff;
    font-size: 13px;
    font-weight: 700;
    text-align: center;
}

.nfs-video-share-sheet__status[data-type="error"] {
    color: #ff8a8a;
}

@media (max-width: 480px) {
    .nfs-video-share-sheet {
        align-items: flex-end;
        padding: 12px;
    }

    .nfs-video-share-sheet__panel {
        border-radius: 18px 18px 14px 14px;
    }

    .nfs-video-share-sheet__links {
        margin-right: 16px;
        margin-left: 16px;
    }
}
