/* custom.css */

body{
    font-family: 'Inter', sans-serif;
    background:#0b0b0b;
    color:#fff;
}

h1,h2,h3,h4{
    font-family:'Playfair Display', serif;
}

.custom-navbar{
    background:rgba(0,0,0,.75);
    backdrop-filter:blur(10px);
    padding:20px 0;
}

.navbar-brand{
    font-size:1.6rem;
    color:#fff;
}

.nav-link{
    color:#ddd !important;
    margin-left:15px;
}

.btn-gold{
    background:#c59b5f;
    border:none;
    color:#fff;
    padding:14px 28px;
    font-weight:600;
}

.btn-gold:hover{
    background:#ae8448;
    color:#fff;
}

.hero-section{
    position:relative;
    background:url('/img/restaurant-bg.jpg') center center/cover no-repeat;
    overflow:hidden;
}

.overlay{
    position:absolute;
    inset:0;
    background:rgba(0,0,0,.72);
}

.hero-badge{
    color:#c59b5f;
    letter-spacing:2px;
    font-size:.9rem;
}

.hero-title{
    font-size:5rem;
    line-height:1;
    margin:20px 0;
}

.hero-text{
    font-size:1.2rem;
    color:#ddd;
    max-width:580px;
}

.hero-features{
    display:flex;
    gap:20px;
    flex-wrap:wrap;
    color:#c59b5f;
}

.hero-mockup{
    max-width:100%;
}

.section-title{
    font-size:2.8rem;
}

.problem-card{
    background:#fff;
    padding:35px;
    border-radius:16px;
    height:100%;
    color:#111;
}

.services-section{
    background:#111;
}

.service-card{
    background:#1b1b1b;
    padding:30px;
    border-radius:16px;
    height:100%;
}

.pricing-section{
    background:#f5f5f5;
    color:#111;
}

.pricing-card{
    background:#fff;
    border-radius:20px;
    padding:40px;
    height:100%;
    position:relative;
    box-shadow:0 10px 30px rgba(0,0,0,.08);
}

.pricing-card.featured{
    border:3px solid #c59b5f;
    transform:scale(1.03);
}

.popular-badge{
    position:absolute;
    top:-12px;
    right:20px;
    background:#c59b5f;
    color:#fff;
    padding:8px 14px;
    border-radius:30px;
    font-size:.8rem;
}

.price{
    font-size:4rem;
    font-weight:700;
    margin:20px 0;
}

.pricing-card ul{
    padding-left:20px;
}

.pricing-card li{
    margin-bottom:12px;
}

.monthly{
    margin-top:30px;
    font-weight:700;
    color:#c59b5f;
}

.cta-section{
    background:url('/img/cta-bg.jpg') center center/cover no-repeat;
    padding:120px 0;
    position:relative;
}

.footer{
    background:#080808;
}

.footer-links{
    list-style:none;
    padding:0;
}

.footer-links li{
    margin-bottom:10px;
}

.footer-links a{
    color:#ccc;
    text-decoration:none;
}


.problems-section{
    background:#f5f3ef;
}

.section-mini-title{
    color:#b08b57;
    letter-spacing:2px;
    font-size:.85rem;
    font-weight:600;
}

.section-title-dark{
    font-size:3rem;
    color:#111;
    font-family:'Playfair Display', serif;
}


.py-7{
    padding-top:7rem;
    padding-bottom:7rem;
}



.section-mini-title{
    color:#b08b57;
    font-size:.9rem;
    font-weight:600;
    letter-spacing:2px;
}



/* =========================================
   PROBLEMS SECTION
========================================= */

.problems-section{
    background:#f5f3ef;
    overflow:hidden;
}

.problems-wrapper{
    min-height:520px;
}

.problems-content{
    padding:90px 70px;
    height:100%;
    display:flex;
    flex-direction:column;
    justify-content:center;
}

.section-mini-title{
    display:inline-block;
    color:#b08b57;
    font-size:.85rem;
    font-weight:700;
    letter-spacing:2px;
    margin-bottom:35px;
}

.problems-grid{
    background:#fff;
    border-radius:12px;
    overflow:hidden;
    border:1px solid #f5f3ef;
    box-shadow:
        0 10px 30px rgba(0,0,0,.04);
}

.problem-col{
    border-right: 20px solid #f5f3ef;
}

.problem-col:last-child{
    border-right:none;
}

.problem-card{
    padding:55px 35px;
    height:100%;
    background:#fff;
    transition:.25s ease;
}

.problem-card:hover{
    background:#faf8f4;
}

.problem-icon{
    width: 58px;
    height: 58px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    margin: auto;
    margin-bottom: 28px;
}
.problem-icon span.bi{
    font-size:3.2rem;
    color:#b08b57;
}

.problem-card h5{
    font-size:1.45rem;
    line-height:1.35;
    color:#111;
    font-weight:700;
    margin-bottom:18px;
    font-family:'Inter', sans-serif;
}

.problem-card p{
    font-size:1rem;
    line-height:1.8;
    color:#6b6b6b;
    margin:0;
}

.problems-image{
    width:100%;
    height:100%;
    min-height:520px;
    background:
        linear-gradient(
            rgba(0,0,0,.12),
            rgba(0,0,0,.12)
        ),
        url('/img/cta-bg.jpg');

    background-size:cover;
    background-position:center center;
}




/* =========================================
   HERO
========================================= */

.services-hero{
    position:relative;
    min-height:100vh;
    background:
        linear-gradient(
            90deg,
            rgba(0,0,0,.88) 0%,
            rgba(0,0,0,.72) 40%,
            rgba(0,0,0,.15) 100%
        ),
        url('/img/restaurante-elegante.png');

    background-size:cover;
    background-position:center center;
}

.hero-overlay{
    position:absolute;
    inset:0;
}

.services-title{
    font-size:5rem;
    line-height:1.05;
    margin-top:20px;
    max-width:700px;
}

.services-text{
    max-width:600px;
    color:#d2d2d2;
    font-size:1.2rem;
    line-height:1.8;
}

/* =========================================
   SERVICES GRID
========================================= */

.services-grid-section{
    padding:120px 0;
    background:#080808;
}

.section-title-light{
    font-size:3.5rem;
}

.service-box{
    background:#101010;
    border:1px solid rgba(255,255,255,.05);
    padding:55px 40px;
    height:100%;
    transition:.3s;
}

.service-box:hover{
    transform:translateY(-10px);
    border-color:#b08b57;
}

.service-icon{
    margin-bottom:30px;
}

.service-icon i{
    font-size:3rem;
    color:#b08b57;
}

.service-box h3{
    font-size:2rem;
    line-height:1.3;
    margin-bottom:20px;
}

.service-box p{
    color:#bcbcbc;
    line-height:1.9;
    margin:0;
}

/* =========================================
   CTA
========================================= */

.services-cta{
    background:#0b0b0b;
}

.cta-image{
    min-height:520px;
    background:url('/img/plato-servicios.png') center center/cover no-repeat;
}

.cta-content{
    padding:100px 90px;
    display:flex;
    flex-direction:column;
    justify-content:center;
    height:100%;
}

.cta-content h2{
    font-size:4rem;
    line-height:1.15;
    margin-bottom:30px;
}

.cta-content p{
    font-size:1.2rem;
    line-height:1.9;
    color:#cfcfcf;
    margin-bottom:40px;
    max-width:700px;
}



/* =========================================
   HERO
========================================= */

.pricing-hero{
    position:relative;
    min-height:100vh;

    background:
        linear-gradient(
            90deg,
            rgba(0,0,0,.9),
            rgba(0,0,0,.55)
        ),
        url('/img/restaurant-bg.jpg');

    background-size:cover;
    background-position:center center;
}

.pricing-overlay{
    position:absolute;
    inset:0;
}

.pricing-title{
    font-size:5rem;
    line-height:1.05;
    margin-top:20px;
    max-width:800px;
}

.pricing-subtitle{
    max-width:650px;
    font-size:1.2rem;
    line-height:1.9;
    color:#d4d4d4;
}

/* =========================================
   PRICING
========================================= */

.pricing-section-main{
    background:#080808;
    padding:120px 0;
}

.price-card{
    background:#101010;
    border:1px solid rgba(255,255,255,.06);
    overflow:hidden;
    height:100%;
    position:relative;
    transition:.3s;
}

.price-card:hover{
    transform:translateY(-10px);
    border-color:#b08b57;
}

.featured-card{
    border:2px solid #b08b57;
}

.popular-tag{
    position:absolute;
    top:20px;
    right:20px;
    background:#b08b57;
    color:#fff;
    padding:8px 16px;
    font-size:.8rem;
    font-weight:700;
    letter-spacing:1px;
    z-index:3;
}

.plan-image{
    height:240px;
    background-size:cover;
    background-position:center center;
}

.basic-image{
    background-image:url('/img/basic-plan.jpg');
}

.pro-image{
    background-image:url('/img/pro-plan.jpg');
}

.premium-image{
    background-image:url('/img/premium-plan.jpg');
}

.price-card-content{
    padding:45px;
}

.plan-name{
    color:#b08b57;
    letter-spacing:2px;
    font-size:.85rem;
    font-weight:700;
}

.plan-price{
    font-size:5rem;
    font-weight:700;
    margin-top:20px;
    line-height:1;
}

.plan-monthly{
    color:#999;
    margin-top:10px;
    margin-bottom:40px;
}

.plan-features{
    list-style:none;
    padding:0;
    margin:0 0 40px;
}

.plan-features li{
    display:flex;
    align-items:center;
    gap:15px;
    margin-bottom:18px;
    color:#ddd;
}

.plan-features i{
    color:#b08b57;
}

.btn-outline-gold{
    border:1px solid #b08b57;
    color:#b08b57;
    padding:15px 25px;
    border-radius:0;
}

.btn-outline-gold:hover{
    background:#b08b57;
    color:#fff;
}

/* =========================================
   COMPARISON
========================================= */

.comparison-section{
    background:#0d0d0d;
    padding:120px 0;
}

.comparison-image{
    height:650px;

    background:
        linear-gradient(
            rgba(0,0,0,.15),
            rgba(0,0,0,.15)
        ),
        url('/img/comparison.jpg');

    background-size:cover;
    background-position:center center;
}

.comparison-content{
    padding-left:80px;
}

.comparison-content h2{
    font-size:4rem;
    margin:25px 0;
    line-height:1.1;
}

.comparison-content p{
    color:#c5c5c5;
    line-height:1.9;
    margin-bottom:35px;
}

.comparison-list{
    list-style:none;
    padding:0;
}

.comparison-list li{
    display:flex;
    align-items:center;
    gap:15px;
    margin-bottom:22px;
    font-size:1.1rem;
}

.comparison-list i{
    color:#b08b57;
    font-size:1.3rem;
}

/* =========================================
   CTA
========================================= */

.pricing-cta{
    background:#050505;
    padding:140px 0;
}

.pricing-cta h2{
    font-size:4rem;
    margin:25px 0;
}

.pricing-cta p{
    max-width:700px;
    margin:0 auto 40px;
    color:#c7c7c7;
    line-height:1.9;
}




.budget-section{
    padding:140px 0;
    background:#080808;
}

.budget-header{
    margin-bottom:80px;
}

.budget-header h1{
    font-size:4.5rem;
    margin:25px 0;
    font-family:'Playfair Display', serif;
}

.budget-header p{
    max-width:800px;
    margin:auto;
    color:#bdbdbd;
    line-height:1.9;
    font-size:1.15rem;
}

.budget-form-wrapper{
    background:#101010;
    padding:50px;
    border:1px solid rgba(255,255,255,.05);
}

.budget-info{
    position:sticky;
    top:120px;
}

.budget-image{
    height:300px;

    background:
        linear-gradient(
            rgba(0,0,0,.25),
            rgba(0,0,0,.25)
        ),
        url('/img/budget-side.jpg');

    background-size:cover;
    background-position:center center;

    margin-bottom:30px;
}

.info-card{
    background:#101010;
    border:1px solid rgba(255,255,255,.05);
    padding:40px;
}

.info-item{
    display:flex;
    gap:25px;
    margin-bottom:35px;
}

.info-item:last-child{
    margin-bottom:0;
}

.info-item i{
    color:#b08b57;
    font-size:2rem;
    min-width:40px;
}

.info-item h5{
    margin-bottom:10px;
    font-size:1.3rem;
}

.info-item p{
    margin:0;
    color:#a8a8a8;
    line-height:1.8;
}

.form-control{
    background:#0b0b0b;
    border:1px solid rgba(255,255,255,.08);
    color:#fff;
    padding:18px 20px;
    border-radius:0;
}

.form-control:focus{
    background:#111;
    border-color:#b08b57;
    box-shadow:none;
    color:#fff;
}

.form-label{
    margin-bottom:12px;
    color:#d0d0d0;
}


/* ==================================
   BudgetRequest
 ===================================*/
.budget-success-section{
    min-height:100vh;
    padding:140px 0;

    background:
        linear-gradient(
            rgba(0,0,0,.88),
            rgba(0,0,0,.88)
        ),
        url('/img/pricing-bg.jpg');

    background-size:cover;
    background-position:center center;

    display:flex;
    align-items:center;
}

.success-card{
    background:rgba(10,10,10,.92);
    border:1px solid rgba(255,255,255,.06);
    padding:80px 70px;
    backdrop-filter:blur(8px);
}

.success-icon{
    margin-bottom:30px;
}

.success-icon i{
    font-size:5rem;
    color:#b08b57;
}

.success-title{
    font-size:4rem;
    line-height:1.1;
    margin:25px 0;
    font-family:'Playfair Display', serif;
}

.success-text{
    max-width:700px;
    margin:0 auto 60px;
    color:#c4c4c4;
    line-height:1.9;
    font-size:1.15rem;
}

.success-steps{
    text-align:left;
    margin-bottom:60px;
}

.step-item{
    display:flex;
    gap:25px;
    margin-bottom:35px;
    padding-bottom:35px;
    border-bottom:1px solid rgba(255,255,255,.05);
}

.step-item:last-child{
    margin-bottom:0;
    padding-bottom:0;
    border-bottom:none;
}

.step-number{
    width:55px;
    height:55px;
    min-width:55px;

    background:#b08b57;
    color:#fff;

    display:flex;
    align-items:center;
    justify-content:center;

    font-weight:700;
    font-size:1.2rem;
}

.step-content h5{
    margin-bottom:12px;
    font-size:1.4rem;
}

.step-content p{
    margin:0;
    color:#b5b5b5;
    line-height:1.8;
}

.success-actions{
    display:flex;
    justify-content:center;
    gap:20px;
    flex-wrap:wrap;
}




/* =========================================
   RESPONSIVE
========================================= */

@media(max-width:991px){

    .problems-content{
        padding:70px 25px;
    }

    .problem-col{
        border-right:none;
        border-bottom: 20px solid #f5f3ef;
    }

    .problem-col:last-child{
        border-bottom:none;
    }

    .problems-image{
        min-height:300px;
    }

    .services-title{
        font-size:3.5rem;
    }

    .section-title-light{
        font-size:2.5rem;
    }

    .cta-content{
        padding:70px 30px;
    }

    .cta-content h2{
        font-size:2.8rem;
    }

    .pricing-title{
        font-size:3.5rem;
    }

    .comparison-content{
        padding-left:0;
        padding-top:50px;
    }

    .comparison-content h2{
        font-size:2.8rem;
    }

    .pricing-cta h2{
        font-size:2.8rem;
    }

    .budget-header h1{
        font-size:3rem;
    }

    .budget-form-wrapper{
        padding:35px;
    }

    .budget-info{
        position:relative;
        top:auto;
    }


    .success-card{
        padding:50px 35px;
    }

    .success-title{
        font-size:2.8rem;
    }

    .success-text{
        font-size:1rem;
    }
}

@media(max-width:992px){

    .hero-title{
        font-size:3.5rem;
    }

    .hero-section{
        padding-top:120px;
        text-align:center;
    }

}
