: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;
}

img{
    max-width:100%;
    height:auto;
}

/* 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{
    width:100%;
    height:clamp(240px, 42vw, 520px);
    object-fit:cover;
    display:block;
}

.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);
}

@media (max-width: 575.98px){
    .navbar{
        padding-top:0.35rem;
        padding-bottom:0.35rem;
    }

    body{
        padding-bottom:76px;
    }

    .navbar .navbar-brand{
        padding-top:0;
        padding-bottom:0;
        display:flex;
        align-items:center;
    }

    .navbar .navbar-brand img.navbar-logo{
        max-height:48px;
        width:auto;
        max-width:190px;
        filter:none;
    }

    .navbar .navbar-collapse{
        padding-top:0.75rem;
    }

    .navbar .navbar-collapse.show{
        background:var(--lf-glass-dark);
        border:1px solid rgba(255,255,255,0.15);
        border-radius:14px;
        padding:0.75rem 0.9rem;
        margin-top:0.5rem;
    }

    .navbar .navbar-nav{
        width:100%;
    }

    .navbar .navbar-nav .nav-link{
        display:block;
        margin-left:0!important;
        padding:0.65rem 0.25rem;
    }

    .hero-header{
        margin-top:-70px;
        padding-top:110px;
        padding-bottom:2.25rem;
    }

    .hero-header .display-1{
        font-size:clamp(1.8rem, 6.5vw, 2.4rem);
        line-height:1.12;
        margin-bottom:0.75rem!important;
    }

    .hero-header h5{
        font-size:1rem;
        padding:0.6rem 1rem!important;
    }
}

@media (max-width: 575.98px){
    .mobile-cta-bar{
        position:fixed;
        left:0;
        right:0;
        bottom:0;
        z-index:1085;
        padding:0.6rem 0.75rem calc(0.6rem + env(safe-area-inset-bottom));
        background:linear-gradient(135deg,
            rgba(184, 216, 0, 0.92) 0%,
            rgba(95, 191, 0, 0.90) 45%,
            rgba(0, 166, 90, 0.90) 100%
        );
        border-top:1px solid rgba(255,255,255,0.20);
        box-shadow:0 -10px 24px rgba(0,0,0,0.22);
    }

    .mobile-cta-bar .mobile-cta-inner{
        max-width:1140px;
        margin:0 auto;
        display:flex;
        gap:0.5rem;
    }

    .mobile-cta-bar .btn{
        flex:1 1 auto;
        padding:0.75rem 0.9rem;
        font-weight:700;
        border-radius:14px;
    }

    .mobile-cta-bar .btn-outline-light{
        border-color:rgba(255,255,255,0.70);
        color:rgba(255,255,255,0.96);
    }
}

@media (max-width: 575.98px){
    .mobile-nav-offcanvas{
        background:linear-gradient(135deg,
            rgba(184, 216, 0, 0.86) 0%,
            rgba(95, 191, 0, 0.82) 45%,
            rgba(0, 166, 90, 0.82) 100%
        );
        color:rgba(255,255,255,0.92);
        border-left:1px solid rgba(255,255,255,0.14);
    }

    @supports ((-webkit-backdrop-filter: blur(10px)) or (backdrop-filter: blur(10px))){
        .mobile-nav-offcanvas{
            -webkit-backdrop-filter: blur(10px);
            backdrop-filter: blur(10px);
        }
    }

    .mobile-nav-offcanvas .offcanvas-title{
        color:rgba(255,255,255,0.92);
    }

    .mobile-nav-offcanvas .btn-close{
        filter:invert(1) grayscale(1) brightness(2);
        opacity:0.9;
    }

    .mobile-nav-offcanvas .navbar-nav{
        width:100%;
    }

    .mobile-nav-offcanvas .nav-link{
        display:block;
        padding:0.7rem 0.25rem;
        color:rgba(255,255,255,0.92)!important;
    }

    .mobile-nav-offcanvas .nav-link.active,
    .mobile-nav-offcanvas .nav-link:hover{
        color:rgba(255,193,7,0.98)!important;
    }
}

/* 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;
}
