﻿:root {
    --white: #ffffff;
    --black: #000000;
    --text-primary: #f0ece4;
    --text-secondary: #9a96a8;
    --primary: #194674;
    --primaryButton: linear-gradient(135deg, var(--accent-gold) 0%, var(--accent-gold-light) 100%);
    --accent-gold: #c8a050;
    --accent-gold-light: #e0c070;
    --bg-deep: #0a0a0f;
    --bg-card: #1a1a24;
    --grayBack: #dbe0e5;
    --lightBack: #f1f3f5;
    --midBack: #dee2e6;
    --darkGray: #343a40;
    --messageBad: #B22222;
    --messageGood: #2E6F40;
    --accent-green: #46d369;
    --surface: #181818;
      --surface-hover: #222222;
      --surface-border: #2a2a2a;
      --gold: #c9a227;
    --gold-light: #dbb84a;
    --gold-glow: rgba(201,162,39,0.3);
    --card-bg: linear-gradient(145deg, rgba(20,25,35,0.95), rgba(10,14,22,0.98));
    --card-border: rgba(201,162,39,0.2);
    --input-bg: rgba(255,255,255,0.06);
    --input-border: rgba(255,255,255,0.12);
    --text-primary: #ffffff;
    --text-muted: rgba(255,255,255,0.5);
    --text-dim: rgba(255,255,255,0.35);
    --green-accent: #4ade80;
    --red-accent: #ef4444;
    --border-input: rgba(255, 255, 255, 0.10);
    --radius-sm: 8px;
    --accent-gold: #c8a050;
    --input-primary: #f0ece4;
    --bg-highlight: #232333;
    --border-subtle: rgba(255, 255, 255, 0.06);
    --accent-red: #ff453a;
    --bg-deep: #0a0a0f;
    --bg-card: #1a1a24;
    --bg-input: #16161f;
    --bg-highlight: #232333;
    --border-subtle: rgba(255, 255, 255, 0.06);
    --border-input: rgba(255, 255, 255, 0.10);
    --border-input-focus: rgba(200, 160, 80, 0.5);
    --text-primary: #f0ece4;
    --text-secondary: #8a8698;
    --text-muted: #5a5768;
    --accent-gold: #c8a050;
    --accent-gold-light: #e0c070;
    --accent-gold-glow: rgba(200, 160, 80, 0.15);
    --accent-red: #ff453a;
    --radius-sm: 8px;
    --radius-md: 14px;
    --radius-lg: 20px;
    --bs-btn-focus-box-shadow: rgba(200, 160, 80, 0.5);
    --border-accent: rgba(200, 160, 80, 0.3);
}

@keyframes fadeSlideUp {
    from { opacity: 0; transform: translateY(16px); }
    to   { opacity: 1; transform: translateY(0); }
}

a {color: var(--text-secondary);}

.grecaptcha-badge { visibility: hidden; }

 .card-header.bg-primary,
  .bg-primary,
  
  .btn-primary,
  .avatar.bg-primary,
  h5.mb-4.text-white.bg-primary,
  .bg-primary {
    background: var(--primaryButton) !important;
    border-color: var(--accent-gold) !important;
    color: var(--bg-deep) !important;
    transition: all 0.25s ease;
  }

.btn-outline-primary {border-color: var(--accent-gold) !important; color: var(--accent-gold) !important; background: var(--surface-hover); }
    .btn-outline-primary:hover, .btn-outline-primary:active, :not(.btn-check) + .btn:active {transform: translateY(-1px); box-shadow: 0 8px 32px rgba(200, 160, 80, 0.35); background: var(--surface-hover); }

.btn-primary:hover { transform: translateY(-1px); box-shadow: 0 8px 32px rgba(200, 160, 80, 0.35); }

.btn-login {padding: 14px 24px;}

.btn:focus-visible {color: var(--bg-deep)!important;  background-color: var(--accent-gold); border-color: var(--accent-gold); outline: 0; box-shadow: var(--bs-btn-focus-box-shadow); }

.card.contentMain {color: var(--text-primary); padding: 0rem; animation: fadeSlideUp 0.5s ease both;}

.card.contentMain h1, .card.contentMain h2 {font-size: 28px; font-weight: 700; color: var(--text-primary);}

.card.sideBar {
               color: var(--text-secondary);
    padding: 1rem;
  animation: fadeSlideUp 0.5s ease both;
}

    .card.sideBar .card-header h2 {font-size: 18px; margin-bottom: .5em; font-weight: 700;}
    .card.sideBar .card-header { border-bottom: 1px solid var(--surface-border);}

.card.contentMain .card-header {color: var(--text-primary)}
.card.contentMain .card-body, .card.sideBar .card-body {background: var(--bg-card); border-radius: 6px;
  border: 1px solid var(--surface-border);padding: 32px;color: var(--text-primary)}

.card-body-schedule ul {margin: 0; padding: 0; list-style: none; display: flex; flex-direction: row; flex-wrap: wrap; gap: 3%;}
    .card-body-schedule ul li {margin-bottom: 1em; flex-basis: 30.3%; padding: 10px; align-items: center;
  background: var(--surface);
  border: 1px solid var(--surface-border);
  border-radius: 4px;
  padding: 10px 10px;
  font-size: 0.78rem;
  color: var(--text-primary);
  font-weight: 500;
  line-height: 1.7em;
    }
        .card-body-schedule ul li span, .card-body-schedule ul li strong, .card-body-schedule ul li i {display: block;}
        .card-body-schedule ul li i {font-size: .8em;}
        .card-body-schedule ul li strong {font-size: 1.25em;}


.card-body-faq {animation: fadeSlideUp 0.6s ease both}


.containerFAQ {max-width: 860px; color: var(--text-primary);}
    .containerFAQ .card-header {animation: fadeSlideUp 0.3s ease both;}
    .containerFAQ p {margin-bottom: 20px;border-bottom: solid 1px var(--border-accent);padding-bottom: 20px; }

.faqQuestion {font-size: 16px;font-style: italic; margin-bottom: .1em; display: block;display: flex; flex-direction: row; column-gap: 10px; color: var(--secondary); align-items: center;}
.faqAnswer {display: flex; flex-direction: row; column-gap: 14px;}


    .faqQ, .faqA
    {width: 56px;
  height: 56px;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--accent-gold-glow), rgba(200, 160, 80, 0.08));
  border: 1px solid var(--border-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0; font-size: 24px;
  color: var(--accent-gold);}



@media (max-width: 576px) {
    .faqQuestion {font-size: 14px; align-items: flex-start;}
    .faqQ, .faqA {width: 40px; height: 40px; font-size: 18px;}
    .card.contentMain {padding: .5rem; }
    .card-body-schedule ul li {flex-basis: 100%; }
}




.text-primary {color: var(--primary)!important;}

html, body {margin: 0; padding: 0; -webkit-text-size-adjust: 100%;}
html, body {width: 100%;}
body {background: linear-gradient(165deg, #000000 0%, #333333 40%, #000000 100%);min-height: 100vh; font: 500 14px/1.3 "Montserrat", Arial, sans-serif; color: var(--white); text-align: center;display: flex; flex-direction: column;}
form {margin: 0; padding: 0; cursor: default; display: flex; flex-direction: column;}

html.login {
background: rgba(0, 0, 0, 1.0);
background: linear-gradient(180deg, rgba(0, 0, 0, 1.0), rgba(0, 0, 0, 0.8))!important;}



main.main {position: relative;padding-top: 90px; padding-bottom: 100px;}

.container.container-fluid {width: 100%;}

/*.info-banner {background: var(--green-accent); max-width: 300px; border: solid 1px var(--border-subtle);}*/

/*HEADER*/

.navbar { background: linear-gradient(to bottom, rgba(0,0,0,1), rgba(0,0,0,0)) !important; width: 100%; transition: background 0.3s ease; position: fixed; top: 0; left: 0; z-index: 9999999;}

    .navbar .container-fluid {padding-left: 0!important; padding-right: 0!important;}
        .navbar.scrolled { background: #000 !important; box-shadow: 0 2px 8px rgba(0,0,0,0.3); }
        .navbar-brand, .navbar-nav .nav-item {margin-right: 40px;}
        .navbar-nav .nav-link { color: rgba(255,255,255,0.9); font-size: 0.95rem; transition: color 0.2s; }
        .navbar-nav .nav-link:hover { color: white; }
        .search-container { position: relative; }
        .search-btn { background: none; border: none; cursor: pointer; padding: 0.5rem; color: rgba(255,255,255,0.8); transition: color 0.2s; }
        .search-btn:hover { color: white; }
        .search-input { position: absolute; right: 0; top: 50%; transform: translateY(-50%); width: 0; opacity: 0; transition: all 0.3s ease; pointer-events: none; background: white; color: #333; }
        .search-input.active { width: 240px; opacity: 1; pointer-events: auto; }
        .btn-signin { background: #0d6efd; color: white; border: none; padding: 0.6rem 1.5rem; border-radius: 6px; font-size: 0.95rem; font-weight: 500; transition: background 0.2s; white-space: nowrap; }
        .btn-signin:hover { background: #0b5ed7; color: white; }
        .navbar-toggler { border: none; padding: 0.5rem; }
        .navbar-toggler:focus { box-shadow: none; }
        .navbar-toggler-icon { width: 24px; height: 2px; background-color: white; display: block; position: relative; transition: all 0.3s; }
        .navbar-toggler-icon::before, .navbar-toggler-icon::after { content: ''; width: 24px; height: 2px; background-color: white; position: absolute; left: 0; transition: all 0.3s; }
        .navbar-toggler-icon::before { top: -7px; }
        .navbar-toggler-icon::after { top: 7px; }
        .navbar-toggler[aria-expanded="true"] .navbar-toggler-icon { background-color: transparent; }
        /*.navbar-toggler[aria-expanded="true"] .navbar-toggler-icon::before { top: 0; transform: rotate(45deg); }
        .navbar-toggler[aria-expanded="true"] .navbar-toggler-icon::after { top: 0; transform: rotate(-45deg); }*/


a.headerAccount {color: rgba(255,255,255,.8); margin-right: 1rem;}
    a.headerAccount:hover {color: rgba(255,255,255,1);}


        @media (max-width: 991px) {
            /*.navbar {background: #000!important;}*/
            .navbar-nav {padding-bottom: 40px;}
            .search-input.active { width: 180px; }
            .navbar-collapse {background: rgba(0,0,0,.5); margin-top: 1rem; }
        }
        @media (max-width: 575px) {
            .search-input.active { width: 150px; }
            .btn-login { padding: 0.25rem .5rem; font-size: 0.9rem; }
            .navbar-brand {margin-right: 10px;}
            .navbar-brand img {max-width: 100px;}
            a.headerAccount { margin-right: .5em; }
            .navbar .btn-primary {font-size: .8em;}
        }


/*FOOTER*/

footer { background: transparent;  width: 100%; padding: 10px !important; font-size: 10px !important; color: #fff; }
footer ul.footerNav {margin: 0; padding: 0; list-style: none;}
    footer ul.footerNav li {font-size: 12px; display: inline-block; width: auto;}
        footer ul.footerNav li:first-child a {padding-left: 0!important;}
        footer ul.footerNav li:last-child a {padding-right: 0!important;}


@media (max-width: 910px) {

    footer .col-12 {margin-bottom: 1rem; text-align: center!important;}

    footer ul.footerNav {padding-bottom: .5rem; font-size: 12px;}
        footer ul.footerNav li a.px-3, footer ul.footerNav li a.ps-3 {padding-left: .15rem!important; padding-right: .25rem!important;}

}

.form-control {padding: 12px 14px;
  background: var(--bg-input);
  border: 1px solid var(--border-input);
  border-radius: var(--radius-sm);
  color: var(--input-primary);
}

    .form-control:focus {color: var(--input-primary); border-color: var(--accent-gold); box-shadow: 0 0 0 3px rgba(200, 160, 80, 0.3); background: var(--surface); }

    .form-control::placeholder { color: #9ca3af!important; opacity: 1; }

/*LOGIN

        .login-container {
            width: 100%;
            width: 440px;
            padding: 20px;
            box-sizing: content-box;
        }

        .logo {
            text-align: center;
            margin-bottom: 40px;
        }

        .logo svg {
            width: 180px;
            height: auto;
        }

        .login-card {
            background: #ffffff;
            border-radius: 8px;
            box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
            padding: 48px 40px;
            overflow: hidden;
        }

        .login-header {
            text-align: center;
            margin-bottom: 32px;
        }

        .login-header h1 {
            font-size: 28px;
            font-weight: 600;
            color: #1a1a1a;
            margin-bottom: 8px;
        }

        .login-header p {
            font-size: 14px;
            color: #666;
        }

        .form-group {
            margin-bottom: 20px;
        }

        .login-container .form-label {
            display: block;
            font-size: 14px;
            font-weight: 500;
            color: #333;
            margin-bottom: 8px;
        }

        .login-container .form-input {
            width: 100%;
            padding: 12px 16px;
            font-size: 15px;
            border: 1px solid #d1d5db;
            border-radius: 6px;
            outline: none;
            transition: all 0.2s;
        }

        .form-input:focus {
            border-color: #3b82f6;
            box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
        }

        .form-input::placeholder {
            color: #9ca3af;
        }

        .forgot-password {
            text-align: right;
            margin-bottom: 24px;
        }

        .forgot-password a {
            font-size: 14px;
            color: #3b82f6;
        }


        .submit-btn {
            width: 100%;
            padding: 14px;
            font-size: 16px;
            font-weight: 600;
            color: #ffffff;
            background: #3b82f6;
            border: none;
            border-radius: 6px;
            cursor: pointer;
            transition: background 0.2s;
        }

        .submit-btn:hover {
            background: #2563eb;
        }

        .submit-btn:active {
            background: #1d4ed8;
        }

        .divider {
            display: flex;
            align-items: center;
            margin: 12px 0;
            color: #9ca3af;
            font-size: 14px;
        }

        .divider::before,
        .divider::after {
            content: '';
            flex: 1;
            height: 1px;
            background: #e5e7eb;
        }

        .divider span {
            padding: 0 16px;
        }

        .signup-link {
            text-align: center;
            margin-top: 32px;
            padding-top: 32px;
            border-top: 1px solid #e5e7eb;
            font-size: 14px;
            color: #666;
        }

        .signup-link a {
            color: #3b82f6;
            font-weight: 500;
        }


        .footer {
            text-align: center;
            margin-top: 32px;
            font-size: 13px;
            color: #9ca3af;
        }

        .footer a {
            color: #9ca3af;
        }

        .footer a:hover {
            color: #666;
        
        }

        .checkbox-group {
            display: flex;
            align-items: center;
            margin-bottom: 24px;
        }

        .checkbox-group input[type="checkbox"] {
            width: 18px;
            height: 18px;
            margin-right: 8px;
            cursor: pointer;
        }

        .checkbox-group label {
            font-size: 14px;
            color: #666;
            cursor: pointer;
        }
*/
/*INITIAL ANIMATION - FADE input*/

.animationSlide.loginScreen { animation: fadeIn 0.8s ease-out 0.1s backwards;}
@keyframes fadeIn {
            0% {
                opacity: 0;
            }
            100% {
                opacity: 1;
            }
        }

/*SECOND ANIMATION - FADE slide from right*/

@keyframes slideInFade {
            0% {
                opacity: 0;
                transform: translate(400px, 0px);
            }
            100% {
                opacity: 1;
                transform: translate(0, 0);
            }
        }

.animationSlide.signinScreen { animation: slideDownFade 0.8s ease-out 0.1s backwards;}


/*LAST ANIMATION - Slide Down*/

@keyframes slideDownFade {
            0% {
                opacity: 0;
                transform: translate( 0px, -400px);
            }
            100% {
                opacity: 1;
                transform: translate(0, 0);
            }
        }


.animationSlide.signinVerify { animation: slideDownFade 0.8s ease-out 0.1s;}


@media (max-width: 575px) {

    .login-container {width: 320px;}
}


/*Hero Carousel*/

#heroCarousel {height: 600px; margin-bottom: 40px;}
#heroCarousel .hero-image, #heroCarousel .carousel-inner, #heroCarousel .carousel-item {height: 100%; overflow: hidden;}

#heroCarousel .hero-content {max-width: 50%; position: absolute; left: 3rem; bottom: 3rem;}

@media (max-width: 992px){
    #heroCarousel {height: 400px;}

    #heroCarousel .hero-content.p-5 {padding: 1rem!important; padding-bottom: 2rem!important; left: 1rem; bottom: 1rem;}

    #heroCarousel .hero-content h1.display-3 {font-size: calc(1.525rem + 1.1vw)}
    #heroCarousel .hero-content .btn {font-size: 14px;}
    #heroCarousel .hero-content .btn.d-flex {display: inline-block;}
}

@media (max-width: 576px) {
    #heroCarousel { height: 300px; }
        #heroCarousel .hero-content { max-width: 100%; }
}
/*CAROUSELS*/

.content-row { margin-bottom: 80px; padding: 0 60px; }
.row-title { font-size: 1.4em; font-weight: 600; margin-bottom: 20px; color: #e5e5e5; }
    .row-title .linkMore {margin-left: 20px;font-size: .65em; font-weight: 500; color: rgba(255,255,255, .5); display: inline-block; text-decoration: none; transition: color 0.3s ease, transform 0.3s ease;}
        .row-title .linkMore:hover {color: #fff;}
.content-row .carousel-inner { padding: 10px 0; overflow: visible; }
.carousel { overflow: visible; }
.card { background: transparent; border: none; margin: 0 5px; position: relative; }
.card-thumbnail { aspect-ratio: 16/9; border-radius: 4px; display: flex; align-items: center; justify-content: center; font-size: 2em; font-weight: bold; color: white; text-shadow: 2px 2px 4px rgba(0,0,0,0.5); cursor: pointer; position: relative; z-index: 1; }
.card-thumbnail.active { z-index: 1000; }

    .card-thumbnail i.bi-lock-fill,
    .card-modal i.bi-lock-fill {color: #e0d916; font-size: 1rem; position: absolute; left: 10px; top: 10px;}

.card-modal i.bi-lock-fill {left: 20px; top: 20px;}

.card-modal { position: absolute; top: 0; left: 0; width: 100%; background: #181818; border-radius: 4px; padding: 15px; opacity: 0; transition: opacity 0.3s ease, transform 0.3s ease; pointer-events: none; box-shadow: 0 8px 16px rgba(0,0,0,0.8); z-index: 999; transform: scale(1); transform-origin: center top; }
.card-modal.active { opacity: 1; pointer-events: auto; z-index: 1001; transform: scale(1.2); }
.modal-image { aspect-ratio: 16/9; border-radius: 4px; display: flex; align-items: center; justify-content: center; font-size: 1.5em; font-weight: bold; color: white; text-shadow: 2px 2px 4px rgba(0,0,0,0.5); margin-bottom: 15px; }

.modal-actions { display: flex; justify-content: space-between; align-items: center; gap: 8px; margin-bottom: 15px; }

    .modal-actions .modal-aux-actions {display: flex; gap: 8px; margin-left: auto;}

.action-btn { width: 36px; height: 36px; border-radius: 50%; border: 2px solid #808080; background: transparent; color: white; display: flex;align-self: flex-start; align-items: center; justify-content: center; cursor: pointer; transition: all 0.2s; }
    .action-btn .btn-aux {justify-content: flex-end}

    .action-btn.btn-play i:before {margin-top: 4px; margin-left: 2px;}

.action-btn:hover { border-color: white; background: rgba(255,255,255,0.1); }
.action-btn.play { background: white; border-color: white; }
.modal-meta { display: flex; flex-direction: row; gap: 10px; font-size: 1.25em; margin-bottom: 10px; flex-wrap: wrap; text-align: left;}
    .modal-meta .title {flex: 1;}
    .modal-meta .year {flex-basis: 10%;}
.match-score { color: #46d369; font-weight: bold; }
.rating { border: 1px solid #808080; padding: 0 4px; }
.modal-description { font-size: 0.9em; margin-bottom: 10px; line-height: 1.4; }
.modal-genres { font-size: 0.85em; color: #999; }

.modal-classes {color: var(--accent-green);
  /*border: solid 1px rgba(70,211,105,0.8);*/
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--surface);
  border-radius: 4px;
  padding: 4px 10px;
  font-size: 0.65rem;
  font-weight: 500;
  width: auto; display: inline-block;
  font-weight: 400;
}

/*Thumb Carousels*/
.carousel-control-prev, .carousel-control-next { width: 50px; height: auto;opacity: 0; transition: opacity 0.3s; z-index: 1100; }
.carousel-control-prev { background: rgba(0,0,0,0.5);  left: -50px; }
.carousel-control-next { background: rgba(0,0,0,0.5);  right: -50px; }
.content-row:hover .carousel-control-prev, .content-row:hover .carousel-control-next { opacity: 1; }
.carousel-control-prev:hover, .carousel-control-next:hover { background: rgba(0,0,0,0.8); }
.carousel-control-prev-icon, .carousel-control-next-icon { width: 2rem; height: 2rem; }
/*.carousel-indicators { display: none; }*/
.carousel-item { overflow: visible; }
.carousel-item .row { margin: 0 -5px; flex-wrap: nowrap; overflow: visible; }
.carousel-item .col { padding: 0 5px; flex: 0 0 auto; width: 25%; }


@media (max-width: 1200px) {
    .modal-meta {font-size: 1em;}

}

@media (max-width: 991px) {

    .content-row { margin-bottom: 40px; padding: 0 20px; }

    .carousel-item .col { width: 25%; }

    .modal-actions {padding: 5px 20px;}
    .action-btn { width: 24px; height: 24px;}

        .action-btn .bi-play-fill.fs-4, .action-btn .bi:before {font-size: 14px !important}

    
  } 




}
@media (max-width: 767px) { .carousel-item .col { width: 25%; } }

@media (max-width: 576px) {

    .carousel-item .col { width: 33.3%; }
}




.nf-section-title{font-size:1rem;font-weight:700;padding:0 16px;margin-bottom:10px;display:flex;align-items:center;gap:8px;}
.nf-badge{font-size:.6rem;background:#e50914;color:#fff;padding:2px 7px;border-radius:3px;font-weight:700;letter-spacing:.4px;}

/* CAROUSEL WRAPPER */
.nf-carousel-wrap{position:relative;padding-bottom:4px;touch-action:pan-y;}
/* alias — mobile carousels use this class name */
.mobile-carousel-wrap{position:relative;padding-bottom:4px;touch-action:pan-y;}
.nf-carousel-wrap .carousel,.mobile-carousel-wrap .carousel{touch-action:pan-y;}
.nf-carousel-wrap .carousel-inner{padding:0 16px;overflow:hidden;}
.nf-carousel-wrap .carousel-item{transition:transform .32s ease;}

/* Arrow controls — desktop pointer devices only */
.nf-carousel-wrap .carousel-control-prev,
.nf-carousel-wrap .carousel-control-next{width:40px;top:0;bottom:0;opacity:1;z-index:10;display:none;}
@media(hover:hover) and (pointer:fine){
  .nf-carousel-wrap .carousel-control-prev,
  .nf-carousel-wrap .carousel-control-next{display:flex;}
}
.nf-carousel-wrap .carousel-control-prev{left:0;background:linear-gradient(to right,rgba(20,20,20,.95) 55%,transparent);}
.nf-carousel-wrap .carousel-control-next{right:0;background:linear-gradient(to left,rgba(20,20,20,.95) 55%,transparent);}
.nf-carousel-wrap .carousel-control-prev-icon,
.nf-carousel-wrap .carousel-control-next-icon{width:20px;height:20px;}

/* Dot indicators */
.nf-carousel-wrap .carousel-indicators{position:relative;bottom:auto;margin:10px 0 2px;justify-content:center;}
.nf-carousel-wrap .carousel-indicators button{width:5px;height:5px;border-radius:50%;border:none;background:#444;opacity:1;margin:0 3px;transition:background .2s,transform .2s;}
.nf-carousel-wrap .carousel-indicators button.active{background:var(--primary);transform:scale(1.35);}

/* PORTRAIT CARD */

.nf-carousel-wrap .carousel-item .row-cols-3 > * {width: 33.3%; display: flex;
  flex-direction: column;}

.nf-card{padding:0 5px;}

/* Thumb — relative so the absolute play btn sits over it */
.nf-thumb{position:relative;width:100%;aspect-ratio:2/3;border-radius:8px;overflow:hidden;background:#222;}

.nf-thumb i.bi-lock-fill {color: #e0d916; font-size: 1rem; position: absolute; left: 5px; top: 5px;}

.nf-match-badge{position:absolute;top:7px;left:7px;background:var(--primary);color:#fff;font-size:.55rem;font-weight:700;padding:2px 6px;border-radius:3px;letter-spacing:.4px;}
.nf-new-badge{position:absolute;top:7px;right:7px;background:#46d369;color:#000;font-size:.5rem;font-weight:800;padding:2px 5px;border-radius:3px;letter-spacing:.3px;}
.thumb-label{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;text-align:center;padding:6px;letter-spacing:.3px;line-height:1.3;}

/* Play button — absolutely centred over thumbnail */
.nf-thumb-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.88);border:none;color:#000;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;padding:0;line-height:1;box-shadow:0 2px 8px rgba(0,0,0,.5);transition:background .15s,transform .15s;}
.nf-thumb-play:active{background:#fff;transform:translate(-50%,-50%) scale(.93);}
.nf-thumb-play i{font-size:1.5rem;margin-left:5px; margin-top: 5px;}

/* Card text */
.nf-card-title{font-size:.7rem;font-weight:600;margin-top:6px; margin-bottom: 2px;white-space:wrap;color:#e5e5e5;padding:0 2px;text-align:center;}
.nf-card-sub{font-size:.6rem;color:#888;margin-top:auto; margin-bottom: 6px; white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 2px;text-align:center;}

/* Action buttons row — centred, 20×20 perfect circles */
.modal-actions{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:auto;padding:0;}
.modal-actions .action-btn{width:20px;height:20px;min-width:20px;min-height:20px;border-radius:50%;border:1px solid rgba(255,255,255,.5);background:transparent;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;line-height:1;flex-shrink:0;transition:border-color .15s,background .15s;}
.modal-actions .action-btn:active{border-color:#fff;background:rgba(255,255,255,.15);}
.modal-actions .action-btn i,.modal-actions .action-btn .bi{font-size:.6rem !important;}

/* Hide the old desktop play btn inside modal-actions on mobile 
.modal-actions .btn-play{display:none;}*/

.action-btn.btn-play i:before {font-size: 16px; margin-top: -0px;}

.modal-actions .action-btn:hover {opacity: .8;}

/* Tablet — 4 columns, slightly larger text */
@media(min-width:600px){
    .nf-carousel-wrap .carousel-item .row-cols-3 > * {width:25%;}
    .nf-card-title{font-size:.75rem;}
    .nf-card-sub{font-size:.65rem;}
}

/* PLACEHOLDER COLORS */
.c1{background:linear-gradient(145deg,#e50914,#7b0a0a);}
.c2{background:linear-gradient(145deg,#0b3d91,#061d47);}
.c3{background:linear-gradient(145deg,#1a472a,#0a1f12);}
.c4{background:linear-gradient(145deg,#6a0dad,#380660);}
.c5{background:linear-gradient(145deg,#c96a0b,#6b3806);}
.c6{background:linear-gradient(145deg,#1b4f72,#0a2033);}
.c7{background:linear-gradient(145deg,#4a235a,#200d29);}
.c8{background:linear-gradient(145deg,#2c3e50,#111820);}
.c9{background:linear-gradient(145deg,#922b21,#430f0a);}
.c10{background:linear-gradient(145deg,#0e7a5f,#063d2e);}
.c11{background:linear-gradient(145deg,#1f618d,#0b2a40);}
.c12{background:linear-gradient(145deg,#7e5109,#3d2604);}
.thumb-label{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;text-align:center;padding:6px;letter-spacing:.3px;line-height:1.3;}





.card-modal {
    overflow: visible; /* allow tooltip to escape the modal box */
}

.tooltip {
    z-index: 9999;
}




/* ─── SPONSORED AD BAND ─────────────────────────────────────────────────────
   Sits between content rows. Shows a horizontally scrolling strip of ads
   on mobile; a centered, evenly-spaced row on desktop.
   ─────────────────────────────────────────────────────────────────────────── */

.ad-band {
    position: relative;
    padding: 18px 60px;
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    gap: 0;
}

/* Subtle top/bottom rule so the band feels intentionally placed */
.ad-band::before,
.ad-band::after {
    content: '';
    position: absolute;
    left: 60px;
    right: 60px;
    height: 1px;
    background: linear-gradient(to right, transparent, rgba(255,255,255,0.08), transparent);
}
.ad-band::before { top: 0; }
.ad-band::after  { bottom: 0; }

/* "Sponsored" label */
.ad-band-label {
    font-size: 0.6rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.3);
    white-space: nowrap;
    writing-mode: vertical-rl;
    transform: rotate(180deg);
    margin-right: 16px;
    flex-shrink: 0;
    align-self: center;
}

/* Scrollable track */
.ad-band-track {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;          /* Firefox */
    flex: 1;
    justify-content: center;        /* center on desktop when ads fit */
}
.ad-band-track::-webkit-scrollbar { display: none; }

/* Individual ad slot */
.ad-slot {
    flex-shrink: 0;
    scroll-snap-align: start;
    width: 300px;
    height: 120px;
    border-radius: 6px;
    overflow: hidden;
    position: relative;
    background: #111;
    /* Subtle border so empty slots don't look broken */
    outline: 1px solid rgba(255,255,255,0.06);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.ad-slot a {
    display: block;
    width: 100%;
    height: 100%;
}

.ad-slot img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Hover lift — subtle, doesn't compete with card hover */
@media (hover: hover) and (pointer: fine) {
    .ad-slot:hover {
        transform: translateY(-2px);
        box-shadow: 0 8px 24px rgba(0,0,0,0.5);
        outline-color: rgba(255,255,255,0.15);
    }
}

/* Collapse slots and entire band when no ads are loaded */
.ad-slot:not(:has(img)) { display: none; }
.ad-band:not(:has(img)) { display: none; }

/* ── Responsive ───────────────────────────────────────────────────────────── */

@media (max-width: 1400px) {
    .ad-band-track {flex-wrap: wrap; column-gap: 5px; justify-content: space-between;}
    .ad-band {max-width: 1040px; margin: 0 auto;}
    .ad-slot {flex-basis: calc(25% - 10px); width: auto; height: auto;}
        .ad-slot a img {width: 100%; height: auto;}

}

@media (max-width: 1200px) {
    /* Allow scrolling when ads don't all fit */

    .ad-band-track { justify-content: flex-start;}

}

@media (max-width: 991px) {
    .ad-band-track {flex-wrap: wrap; column-gap: 5px; justify-content: space-between;}
    .ad-band { padding: 14px 20px; }
    .ad-band::before,
    .ad-band::after { left: 20px; right: 20px; }
    .ad-slot {width: auto; flex-basis: calc(25% - 10px); }
}

@media (max-width: 576px) {
    .ad-band-track {flex-wrap: wrap; column-gap: 5px; justify-content: space-between;}
    .ad-band { padding: 12px 16px; }
    .ad-band::before,
    .ad-band::after { left: 16px; right: 16px; }
    .ad-band-label { display: none; }   /* too cramped on small phones */
    .ad-slot {width: auto; flex-basis: calc(50% - 10px); }
}













/*IPAD LANDSCAP*/

@media (max-width: 1080px) and (orientation: landscape) {

    .d-none.d-lg-block.rtvLg {display: none!important;}
    .d-block.d-lg-none.rtvSm {display: block!important;}

    .nf-thumb-play i {font-size: 1.5rem; }
    .nf-thumb-play i:before {margin-top: 2px; margin-left: 2px;}
}


/* ── Upgrade Button (header) ── */
.btn-upgrade {
    background: var(--surface);
    border: 1.5px solid #c8a050;
    color: #c8a050;
    padding: 0.45rem 1.1rem;
    margin-right: 10px;           /* ← adds breathing room before Sign Out */
    border-radius: 6px;
    font-size: 0.85rem;
    font-weight: 600;
    white-space: nowrap;
    transition: all 0.25s ease;
    text-decoration: none;
}

.btn-upgrade:hover {
    background: rgba(200, 160, 80, 0.12);
    border-color: #e0c070;
    color: #e0c070;
    text-decoration: none;
}

.btn-upgrade:active {
    background: rgba(200, 160, 80, 0.2);
}

.btn-upgrade .bi {
    font-size: 0.8rem;
}

@media (max-width: 992px) {
    .btn-upgrade {background: transparent; border-width: 0; margin-left: -40px; padding-right: 30px;}

}

/* ── Guest CTA bar ─────────────────────────────────────────── */
.guest-cta-bar {
    background: rgba(24,24,24,.5);
    border: 1px solid var(--card-border)!important;
    border-radius: 12px!important;
    padding: 1.1rem 1.5rem;
    position: absolute; top: 20px; right: 16px;
    max-width: 500px;
    z-index: 9999998;
    text-align: left;
}

    .guest-cta-bar:before {content: '';
    position: absolute;
    top: -1px; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, transparent, var(--gold), transparent);
    border-radius: 12px 12px 0 0;}


.guest-cta-inner {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}
.guest-cta-text {
    color: var(--text-primary);
    font-size: .8rem;
}
.guest-cta-actions {
    display: flex;
    align-items: center;
    gap: .75rem;
    flex-shrink: 0;
}
.guest-cta-btn-secondary {
    color: var(--text-primary);
    border-color: rgba(255,255,255,.4);
    font-size: .9rem;
    white-space: nowrap;
}
.guest-cta-btn-secondary:hover {
    background: rgba(255,255,255,.1);
    border-color: var(--text-primary);
    color: var(--text-primary);
}
@media (max-width: 600px) {
    .guest-cta-inner { flex-direction: column; align-items: flex-start; }
    .guest-cta-actions { width: 100%; text-align: right;}
    .guest-cta-btn, .guest-cta-btn-secondary { flex: 1; text-align: center; }
}


@media (max-width: 992px) {

    .guest-cta-bar {max-width: 100%; right: 0; top: 0; border-radius: 0!important;}

        .guest-cta-bar .btn {font-size: 12px;}

    .guest-cta-inner {display: flex; flex-direction: row; flex-wrap: nowrap;}
    .guest-cta-inner .guest-cta-text {flex-basis: 70%; }
        .guest-cta-inner .guest-cta-actions {flex-basis: 30%;}

}

@media (max-width: 576px) {

    .guest-cta-bar {position: relative; }
    .guest-cta-inner { flex-direction: column!important; flex-wrap: wrap;}
    .guest-cta-inner .guest-cta-text {flex-basis: 100%; }
        .guest-cta-inner .guest-cta-actions {flex-basis: 100%;}

        .guest-cta-bar .btn {font-size: 10px; flex-basis: 50%; }


}

/* ============================================================
   ACCESSIBILITY
   ============================================================ */

/* Required field indicator */
.required-star {
    color: var(--messageBad);
    margin-left: 2px;
}

/* Skip-to-content link — visually hidden until focused */
.skip-to-content {
    position: absolute;
    left: -9999px;
    top: auto;
    width: 1px;
    height: 1px;
    overflow: hidden;
    z-index: -1;
    background: red;
    opacity: 1;
}
.skip-to-content:focus {
    position: fixed;
    top: 0;
    left: 0;
    width: auto;
    height: auto;
    overflow: visible;
    z-index: 99999999999;
    padding: 12px 24px;
    background: var(--accent-gold);
    color: var(--bg-deep);
    font-weight: 700;
    font-size: 14px;
    text-decoration: none;
    border-radius: 0 0 8px 0;
    opacity: 1;
}
