:root{
    --lf-brand-gradient:linear-gradient(135deg, #b8d800 0%, #5fbf00 45%, #00a65a 100%);
    --lf-brand-gradient-hover:linear-gradient(135deg, #cbe600 0%, #6fd100 45%, #00b562 100%);

    --lf-accent-yellow:#ffd400;
    --lf-accent-yellow-hover:#ffe45c;

    --lf-brand-on:#fff;
    --lf-brand-on-soft:rgba(255,255,255,0.92);

    --lf-glass-light:rgba(255,255,255,0.78);
    --lf-glass-light-hover:rgba(255,255,255,0.12);
    --lf-glass-border:rgba(255,255,255,0.15);

    --lf-glass-dark:rgba(0,0,0,0.55);

    --lf-text:rgba(17,24,39,0.92);
}

html,body{
    color:var(--lf-text);
    background-image:
        var(--lf-brand-gradient),
        url("/img/fondobanner.jpg");
    background-size:cover;
    background-position:center;
    background-repeat:no-repeat;
    background-attachment:fixed;
}

/* Brand gradient for solid brand backgrounds */
.bg-brand,
.hero-header,
.header-carousel::before{
    background-image:var(--lf-brand-gradient)!important;
    background-color:transparent!important;
}

/* Hero header background image */
.hero-header{
    background-image:
        linear-gradient(135deg, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0.35) 45%, rgba(0,0,0,0.40) 100%)!important;
    background-size:cover!important;
    background-position:center!important;
    background-repeat:no-repeat!important;
}

.hero-header{
    position:relative;
    overflow:hidden;
}

.hero-header .hero-video-bg{
    position:absolute;
    inset:0;
    z-index:0;
}

.hero-header .hero-video{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
}

.hero-header .hero-video-bg::after{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(135deg, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.40) 45%, rgba(0,0,0,0.55) 100%);
}

.hero-header > .container{
    position:relative;
    z-index:1;
}

.hero-header .header-carousel .owl-item img,
.hero-header .header-carousel img{
    height:520px;
    object-fit:cover;
    width:100%;
}

.hero-header,
.hero-header h1,
.hero-header h2,
.hero-header h3,
.hero-header h4,
.hero-header h5,
.hero-header h6,
.hero-header p,
.hero-header a,
.hero-header i{
    color:var(--lf-brand-on-soft)!important;
}

.bg-brand:hover{
    background-image:var(--lf-brand-gradient-hover)!important;
}

.bg-brand,
.bg-brand a,
.bg-brand i,
.hero-header,
.hero-header a,
.hero-header i{
    color:var(--lf-brand-on-soft);
}

/* Glass look for most surfaces */
.navbar,
.dropdown-menu,
.modal-content,
.card,
.service-item,
.project-item,
.team-item,
.testimonial-item,
.footer{
    background:var(--lf-glass-light);
    border:1px solid var(--lf-glass-border);
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
}

/* Brand gradient navbar */
.navbar{
    background-image:none!important;
    background-color:rgba(0,0,0,0.08)!important;
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
    border:0!important;
}

.sticky-top.bg-white{
    background-color:transparent!important;
}

.sticky-top.bg-white .navbar{
    background-image:var(--lf-brand-gradient)!important;
    background-color:transparent!important;
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
}

.navbar .navbar-brand,
.navbar .navbar-brand h1,
.navbar .navbar-nav .nav-link{
    color:rgba(255,255,255,0.92)!important;
}

.navbar .navbar-nav .nav-link:hover,
.navbar .navbar-nav .nav-link:focus,
.navbar .navbar-nav .nav-link.active{
    color:#ffffff!important;
}

.navbar .navbar-toggler{
    border-color:rgba(255,255,255,0.35)!important;
}

.navbar .navbar-toggler-icon{
    filter:invert(1);
}

.navbar.border-bottom,
.sticky-top .navbar.border-bottom{
    border-bottom:0!important;
}

/* Full-width navbar (template wraps nav in .container inside .sticky-top) */
.sticky-top > .container{
    max-width:100%!important;
    width:100%!important;
    padding-left:0!important;
    padding-right:0!important;
}

.sticky-top .navbar{
    padding-left:1rem;
    padding-right:1rem;
}

.card:hover,
.service-item:hover,
.project-item:hover,
.dropdown-menu .dropdown-item:hover{
    background-color:var(--lf-glass-light-hover);
}

.card.no-hover:hover{
    background:var(--lf-glass-light)!important;
}

/* Yellow for primary UI elements */
:root{--bs-primary:var(--lf-accent-yellow);}

.text-primary{color:var(--lf-accent-yellow)!important;}

a{color:var(--lf-accent-yellow);}
a:hover{color:var(--lf-accent-yellow-hover);}

.btn-primary,
.bg-primary,
.badge-primary,
.badge.bg-primary,
.btn.btn-primary{
    background-image:none!important;
    background-color:var(--lf-accent-yellow)!important;
    border-color:rgba(0,0,0,0.10)!important;
    color:rgba(17,24,39,0.92)!important;
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active,
.btn-primary.active,
.show > .btn-primary.dropdown-toggle{
    background-color:var(--lf-accent-yellow-hover)!important;
    border-color:rgba(0,0,0,0.12)!important;
    color:rgba(17,24,39,0.92)!important;
}

/* Brand gradient button (used in hero CTA) */
.btn-brand-gradient{
    background-image:var(--lf-brand-gradient)!important;
    background-color:transparent!important;
    border:1px solid rgba(255,255,255,0.15)!important;
    color:var(--lf-brand-on)!important;
    font-weight:700;
    letter-spacing:0.02em;
}

.btn-brand-gradient:hover,
.btn-brand-gradient:focus,
.btn-brand-gradient:active{
    background-image:var(--lf-brand-gradient-hover)!important;
    background-color:transparent!important;
    border:1px solid rgba(255,255,255,0.18)!important;
    color:var(--lf-brand-on)!important;
}

/* Hero play image CTA */
.hero-play-link{
    display:inline-block;
    text-decoration:none;
}

.hero-play-img{
    display:block;
    max-width:min(260px, 80vw);
    height:auto;
    filter:drop-shadow(0 12px 28px rgba(0,0,0,0.35));
    transition:transform .18s ease, filter .18s ease;
}

.hero-play-link:hover .hero-play-img,
.hero-play-link:focus .hero-play-img{
    transform:translateY(-2px) scale(1.02);
    filter:drop-shadow(0 16px 34px rgba(0,0,0,0.45));
}

/* Number balls (play selection) */
.number-ball-input{
    position:absolute;
    opacity:0;
    pointer-events:none;
}

.number-ball{
    width:42px;
    height:42px;
    border-radius:9999px;
    display:flex;
    align-items:center;
    justify-content:center;
    border:2px solid rgba(255,255,255,0.25);
    color:rgba(17,24,39,0.92);
    cursor:pointer;
    user-select:none;
    font-weight:700;
    background:rgba(255,255,255,0.78);
    box-shadow:0 4px 12px rgba(0,0,0,0.10);
    transition:transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease;
}

.number-ball:hover{
    transform:translateY(-1px);
    box-shadow:0 10px 22px rgba(0,0,0,0.14);
    border-color:rgba(95,191,0,0.55);
}

.number-ball-input:checked + .number-ball{
    background-image:var(--lf-brand-gradient)!important;
    border-color:rgba(255,255,255,0.35);
    color:#fff;
    box-shadow:0 10px 22px rgba(95,191,0,0.22), 0 10px 22px rgba(0,166,90,0.14);
}

.number-ball-input:disabled + .number-ball{
    opacity:0.45;
    cursor:not-allowed;
    transform:none;
    box-shadow:0 4px 12px rgba(0,0,0,0.06);
}

/* Navbar links */
.navbar .navbar-nav .nav-link{color:var(--lf-brand-on-soft)!important;}
.navbar .navbar-nav .nav-link:hover,
.navbar .navbar-nav .nav-link.active{color:var(--lf-accent-yellow)!important;}

.navbar-brand h1,
.navbar-brand,
.navbar .navbar-toggler{
    color:var(--lf-brand-on-soft)!important;
}

.navbar .navbar-toggler-icon{
    filter:invert(1) grayscale(1) brightness(1.4);
}

/* Card headers / section headers that use bg-primary */
.card-header.bg-primary,
.bg-primary .card-title,
.bg-primary h1,
.bg-primary h2,
.bg-primary h3,
.bg-primary h4,
.bg-primary h5,
.bg-primary h6,
.bg-primary a,
.bg-primary i{
    color:rgba(17,24,39,0.92)!important;
}

/* Login dark overlay helper */
body.web-login{
    background-image:
        linear-gradient(135deg, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.55) 100%),
        url("/img/fondobanner.jpg");
}

.web-login .card,
.web-login .navbar,
.web-login .modal-content{
    background:var(--lf-glass-dark);
    border:1px solid rgba(255,255,255,0.15);
    color:var(--lf-brand-on-soft);
}

.hero-fondobanner{
    background-image:
        linear-gradient(135deg, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.45) 100%),
        url("/img/fondobanner.jpg");
    background-size:cover;
    background-position:center;
    background-repeat:no-repeat;
}
