
.home-category-banner-section{
    background:#f5f7fb;
}
.home-category-banner-grid{
    display:grid;
    grid-template-columns:260px minmax(0,1fr);
    gap:30px;
    align-items:stretch;
}
.home-category-menu-card{
    background:#fff;
    border-radius:6px;
    overflow:hidden;
    box-shadow:0 18px 40px rgba(15,23,42,.06);
    min-height:420px;
}
.home-category-menu-title{
    display:flex;
    align-items:center;
    gap:18px;
    background:#ffc400;
    color:#0f172a;
    font-weight:800;
    padding:17px 18px;
    letter-spacing:.02em;
}
.home-category-menu-icon{
    font-size:22px;
    line-height:1;
}
.home-category-menu-list{
    padding:8px 0;
}
.home-category-menu-link{
    display:flex;
    align-items:center;
    gap:14px;
    padding:10px 16px;
    color:#111827;
    text-decoration:none;
    transition:.18s ease;
}
.home-category-menu-link:hover{
    background:#f8fafc;
    color:var(--primary,#0f766e);
    transform:translateX(3px);
}
.home-category-menu-thumb{
    width:34px;
    height:34px;
    flex:0 0 34px;
    border-radius:6px;
    background:#f3f4f6;
    border:1px solid #e5e7eb;
    display:flex;
    align-items:center;
    justify-content:center;
    overflow:hidden;
    font-weight:800;
    color:#0f172a;
}
.home-category-menu-thumb img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}
.home-category-menu-name{
    flex:1;
    font-size:15px;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}
.home-category-menu-arrow{
    color:#111827;
    font-size:22px;
    line-height:1;
    opacity:.75;
}
.home-main-banner-slider,
.home-main-banner-slider .carousel-inner,
.home-main-banner-slider .carousel-item{
    height:100%;
}
.home-main-banner-slider{
    min-height:420px;
    border-radius:6px;
    overflow:hidden;
    box-shadow:0 18px 40px rgba(15,23,42,.06);
}
.home-main-banner-slide{
    min-height:420px;
    position:relative;
    overflow:hidden;
    display:flex;
    align-items:center;
    padding:46px 55px;
    isolation:isolate;
}
.home-main-banner-slide:before{
    content:"";
    position:absolute;
    inset:0;
    background:
        radial-gradient(circle at 25% 20%,rgba(255,255,255,.18),transparent 22%),
        radial-gradient(circle at 70% 70%,rgba(255,255,255,.13),transparent 20%);
    z-index:-1;
}
.home-main-banner-content{
    max-width:560px;
    color:#fff;
    position:relative;
    z-index:2;
}
.home-main-banner-badge{
    font-size:13px;
    text-transform:uppercase;
    letter-spacing:.05em;
    margin-bottom:12px;
}
.home-main-banner-content h2{
    font-size:clamp(38px,5vw,74px);
    line-height:.95;
    font-weight:900;
    margin:0 0 18px;
}
.home-main-banner-content p{
    font-size:16px;
    font-weight:700;
    max-width:520px;
    margin-bottom:28px;
    line-height:1.6;
}
.home-main-banner-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:160px;
    height:48px;
    background:#ffc400;
    color:#111827;
    border-radius:5px;
    text-decoration:none;
    font-weight:700;
    transition:.18s ease;
}
.home-main-banner-btn:hover{
    color:#111827;
    filter:brightness(.96);
    transform:translateY(-1px);
}
.home-main-banner-image{
    position:absolute;
    right:35px;
    bottom:0;
    top:22px;
    max-width:46%;
    max-height:92%;
    width:auto;
    height:auto;
    object-fit:contain;
    z-index:1;
    filter:drop-shadow(0 28px 35px rgba(15,23,42,.26));
}
.home-main-banner-slider .carousel-indicators{
    margin-bottom:18px;
}
.home-main-banner-slider .carousel-indicators [data-bs-target]{
    width:12px;
    height:12px;
    border-radius:999px;
    border:2px solid #fff;
    background:transparent;
    opacity:1;
}
.home-main-banner-slider .carousel-indicators .active{
    background:#fff;
}
@media (max-width:991.98px){
    .home-category-banner-grid{
        grid-template-columns:1fr;
        gap:18px;
    }
    .home-category-menu-card{
        min-height:auto;
    }
    .home-category-menu-list{
        display:grid;
        grid-template-columns:repeat(2,minmax(0,1fr));
    }
    .home-main-banner-slide{
        min-height:360px;
        padding:38px 28px;
    }
    .home-main-banner-image{
        max-width:42%;
        right:10px;
        opacity:.88;
    }
}
@media (max-width:575.98px){
    .home-category-menu-list{
        grid-template-columns:1fr;
    }
    .home-main-banner-slide{
        min-height:330px;
        padding:32px 22px;
    }
    .home-main-banner-content h2{
        font-size:38px;
    }
    .home-main-banner-content p{
        font-size:14px;
        max-width:80%;
    }
    .home-main-banner-image{
        max-width:55%;
        opacity:.28;
        right:-30px;
    }
}
