/*
    Construction Responsive
*/

@media (max-width: 1024px) {
	
}

/* ---- Start of max-width 992px CSS ---- */
@media (max-width: 992px) {
    :root {
        --site-header-offset: 82px;
    }
    .main-slider,
    .main-slider .owl-stage-outer,
    .main-slider .owl-stage,
    .main-slider .owl-item,
    .main-slider .slide-item,
    .hero-bootstrap-row {
        min-height: 680px;
    }
    .container {
        width: 100%;
        max-width: 100%;
    }
    .sm-padding{ padding: 15px; }
    .sm-br-none br{
        display: none;
    }
    .fz-45{ font-size: 35px;}
    h2 { font-size: 30px; }
    .slider-content h1,
    .slider-content .hero-slide-title,
    .page-heading .hero-content h2 { max-width: 16ch; }
    .page-heading .hero-content h1 { max-width: 16ch; }
    .slider-content p,
    .page-heading .hero-content p { max-width: 52ch; }
    .header-bottom {
        padding-top: 4px;
        padding-bottom: 4px;
    }
    .video-content{
        padding: 0;
    }
    .sm-no-padding{
        padding: 0;
    }
    .height-500, 
    .height-550, 
    .height-600, 
    .height-650, 
    .height-660, 
    .height-670, 
    .height-700, 
    .height-750{
        min-height: 450px;
        height: auto;
    }
    .mainmenu li a{
        font-size: 14px;
    }
    .navbar-links > li > a{
        margin-left: 16px;
        font-size: 14px;
    }
    .b-nav-btn { padding: 11px 18px; margin-left: 14px; }
    .navbar-njm {
        min-height: 72px;
    }
    .navbar-njm .navbar-collapse {
        width: calc(100% - 140px);
        padding-left: 16px;
    }
    .widget-section {
        padding: 72px 0 48px;
    }
    .footer-nav-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.875rem 1rem;
    }
    .owl-nav-1 .owl-nav div,
    .owl-nav-3 .owl-nav div,
    .main-slider .owl-nav .owl-prev,
    .main-slider .owl-nav .owl-next {
        width: 46px;
        height: 46px;
        line-height: 46px;
    }
    .wedding-content-block .ptb-95{
        padding: 30px;
    }
    .content-block-full .ptb-115,
    .content-block-full .entry-content{
        padding: 45px 0;
        margin-left: 15px;
    }
    .content-block-full h2 br{
        display: none;
    }
    .tab-menus li a{
        padding: 8px 15px;
    }
    .pricing-content.pl-50{ padding-left: 0; }

    .hero-bootstrap-row {
        padding-top: calc(var(--site-header-offset) + 8rem);
        padding-bottom: 44px;
    }

}
/* ---- End of max-width 992px CSS ---- */


/* ---- Start of min-width 480px and max-width 768px CSS ---- */
@media all and (min-width: 480px) and (max-width: 768px) {
	
}
/* ---- End of min-width 480px and max-width 768px CSS ---- */


/* ---- Start of max-width 767px CSS ---- */
@media all and (max-width: 767px) {
    :root {
        --site-header-offset: 74px;
    }
    .main-slider,
    .main-slider .owl-stage-outer,
    .main-slider .owl-stage,
    .main-slider .owl-item,
    .main-slider .slide-item,
    .hero-bootstrap-row {
        min-height: 560px;
    }
	body{
        overflow-x: hidden;
        overflow-y: auto;
    }
    body, p{
        font-size: 14px;
    }
    .container {
        width: 100%;
        padding-left: 18px;
        padding-right: 18px;
    }
    .padding{ padding: 72px 0; }
    .padding-100, .padding-120{ padding: 80px 0; }
    .fz-40, .fz-45, .fz-50{ font-size: 30px; }
    h2 { font-size: 28px; }
    .xs-padding{
        padding: 15px;
    }
    .xs-text-left{ text-align: left;}
    .xs-text-center{ text-align: center; }
    .xs-no-padding{ padding: 0; }
    .xs-ptb-50{
        padding-top: 50px;
        padding-bottom: 50px;
    }
    .xs-t-white{ color: #fff; }
    .xs-br-none br{ display: none; }
    .mb-xs-20{ margin-bottom: 20px!important; }
    .mb-xs-10{ margin-bottom: 10px; }
    .mb-100{ margin-bottom: 40px; }
    .height-500, 
    .height-550, 
    .height-600, 
    .height-650, 
    .height-660, 
    .height-670, 
    .height-700, 
    .height-750{
        min-height: 400px;
        height: auto;
    }
    .page-heading.height-500,
    .page-heading.height-550,
    .page-heading.height-600,
    .page-heading.height-650,
    .page-heading.height-660,
    .page-heading.height-670,
    .page-heading.height-700,
    .page-heading.height-750 {
        min-height: 420px;
        height: auto;
    }
    .hero-w-form.height-600{
        height: auto;
    }
    .js .slicknav_menu {
        display:none !important;
    }
    .slider-content,
    .page-heading .hero-content {
        max-width: 100%;
        padding-right: 0.5rem;
        padding-top: 1rem;
        padding-bottom: 1rem;
    }
    .slider-content h1,
    .slider-content .hero-slide-title,
    .page-heading .hero-content h2 {
        font-size: 34px;
        line-height: 1.1;
        max-width: 100%;
    }
    .page-heading .hero-content h1 {
        font-size: 34px;
        line-height: 1.1;
        max-width: 100%;
    }
    .slider-content p,
    .page-heading .hero-content p {
        max-width: 100%;
        font-size: 1rem;
        line-height: 1.7;
    }
    .hero-bootstrap-row {
        padding-top: calc(var(--site-header-offset) + 3.5rem);
        padding-bottom: 40px;
    }
    .hero-actions {
        flex-direction: column;
        align-items: stretch;
        gap: 12px;
    }
    .hero-actions .btn {
        width: 100%;
        margin-right: 0;
        margin-left: 0;
    }
    .eyebrow {
        font-size: 13px;
        letter-spacing: 0.06em;
        padding: 7px 12px;
        margin-bottom: 14px;
    }
    .main-slider .owl-nav {
        inset: auto 0 22px;
        transform: none;
        display: flex;
        justify-content: center;
        gap: 12px;
    }
    .main-slider .owl-nav .owl-prev,
    .main-slider .owl-nav .owl-next {
        position: static;
        width: 44px;
        height: 44px;
    }
    .main-slider .owl-dots {
        bottom: 14px;
    }
    .page-heading .display-table,
    .page-heading .table-cell {
        display: block;
        height: auto;
    }
    .page-heading {
        background-attachment: scroll;
    }
    .service-section .service-box,
    .services-items .service-box,
    .why-us-list .service-box,
    .widget-box,
    .footer-card,
    .stat-card,
    .feature-card,
    .contact-panel,
    .split-card { padding: 24px; }
    .service-section .service-box,
    .why-us-list .service-box { padding-left: 24px; }
    .service-section .service-box i,
    .why-us-list .service-box i {
        position: static;
        margin-bottom: 16px;
    }
    .service-section .services-wrap,
    .why-us-section .services-wrap,
    .services-items,
    .trust-band .row,
    .partner-block .row,
    .widget-section .row,
    .content-block .row.g-4,
    section .row.g-4 {
        display: block;
    }
    .service-section .services-wrap > [class*="col-"],
    .why-us-section .services-wrap > [class*="col-"],
    .services-items > [class*="col-"],
    .trust-band .row > [class*="col-"],
    .partner-block .row > [class*="col-"],
    .widget-section .row > [class*="col-"],
    .content-block .row.g-4 > [class*="col-"],
    section .row.g-4 > [class*="col-"] {
        display: block;
    }
    .row,
    .portfolio-items.row {
        margin-left: -10px;
        margin-right: -10px;
    }
    .row > [class*="col-"] {
        padding-left: 10px;
        padding-right: 10px;
    }
    .navbar-njm{
        display: block;
        min-height: 64px;
    }
    .navbar-header {
        width: 100%;
        min-height: 64px;
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 8px 0;
        position: relative;
    }
    .navbar-brand.brand {
        max-width: calc(100% - 96px);
    }
    .navbar-brand.brand img {
        max-width: 118px;
        height: auto;
    }
    .navbar-njm .navbar-collapse { display: none !important; }
    .header-bottom .container { display: block !important; }
    .header-bottom {
        min-height: 74px;
    }
    .b-nav-btn { display: none; }
    .mobile-nav-toggle {
        display: inline-flex;
    }
    .mobile-nav-list {
        display: none;
        position: absolute;
        top: calc(100% + 12px);
        left: 0;
        right: 0;
        padding: 12px;
        background: rgba(8, 17, 32, 0.98);
        border: 1px solid rgba(255,255,255,0.08);
        border-radius: 18px;
        box-shadow: 0 18px 40px rgba(2, 6, 23, 0.28);
        z-index: 1200;
    }
    .mobile-nav-list li + li {
        margin-top: 6px;
    }
    .mobile-nav-list a {
        display: block;
        padding: 12px 14px;
        border-radius: 12px;
        color: #ffffff;
        text-decoration: none;
        font-weight: 600;
    }
    .mobile-nav-list a:hover,
    .mobile-nav-list a:focus-visible,
    .mobile-nav-list .current_page_item > a,
    .mobile-nav-list .active > a {
        background: rgba(22, 163, 74, 0.18);
        color: #ffffff;
    }
    .mobile-nav-toggle__label {
        position: absolute;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: -1px;
        overflow: hidden;
        clip: rect(0, 0, 0, 0);
        white-space: nowrap;
        border: 0;
    }
    .mobile-nav-toggle__icon {
        width: 22px;
        display: inline-flex;
        flex-direction: column;
        gap: 4px;
    }
    .mobile-nav-toggle__icon span {
        display: block;
        width: 100%;
        height: 2px;
        border-radius: 999px;
        background: currentColor;
        transition: transform 0.2s ease, opacity 0.2s ease;
    }
    .mobile-nav-toggle {
        align-items: center;
        justify-content: center;
        width: 46px;
        height: 46px;
        padding: 0;
        border: 1px solid rgba(255,255,255,0.16);
        border-radius: 14px;
        background: rgba(255,255,255,0.08);
        color: #ffffff;
    }
    .mobile-nav-toggle.is-open .mobile-nav-toggle__icon span:nth-child(1) {
        transform: translateY(6px) rotate(45deg);
    }
    .mobile-nav-toggle.is-open .mobile-nav-toggle__icon span:nth-child(2) {
        opacity: 0;
    }
    .mobile-nav-toggle.is-open .mobile-nav-toggle__icon span:nth-child(3) {
        transform: translateY(-6px) rotate(-45deg);
    }
    .brand-item { min-height: 90px; }
	.footer-nav-list {
		grid-template-columns: 1fr;
	}
    .widget-section {
        padding: 64px 0 40px;
    }
    .widget-section h4,
    .footer-card h4,
    .widget-box h4 {
        margin-bottom: 18px;
    }
    .footer-section {
        padding: 20px 0;
    }
	.portfolio-items.row > [class*="col-"] + [class*="col-"] {
		margin-top: 24px;
	}
    .project.owl-carousel .owl-stage-outer {
        padding-bottom: 8px;
    }
    .owl-nav-1 .owl-nav,
    .owl-nav-3 .owl-nav {
        margin-top: 18px;
    }
	.portfolio-box .overlay .portfolio-content,
	.portfolio-box .overlay .display-table,
	.portfolio-box .overlay .table-cell {
		padding-left: 18px;
		padding-right: 18px;
	}
	.testi-content{
		margin-left: 0;
	}
    .bg-color{
        width: 100%;
    }
    .google-map{
      height: 280px;
    }
    .filter-items .padding-10{ padding: 5px; }
    .subs-custom .email-field{ line-height: 43px; }
}
/* ---- End of max-width 767px CSS ---- */


/* ---- Start of max-width 480px CSS ---- */
@media all and (max-width: 520px) {
    :root {
        --site-header-offset: 70px;
    }
    .col-xs-6{
        float: left;
        width: 50%;
    }
    .counter-section .col-xs-6{
        float: left;
        width: 50%;
    }
    .food-menu .padding-50{
        padding: 40px;
    }
    .menu_list li h4, .menu_list li span.price{
        font-size: 16px;
    }
    .ptb-140{
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .subs-custom .col-xs-8,
    .subs-custom .col-xs-4{
        width: 100%;
        padding: 10px;
    }
    .subs-custom .b-btn{ margin: 0; }
    .slider-content h1,
    .slider-content .hero-slide-title,
    .page-heading .hero-content h2 {
        font-size: 28px;
    }
    .page-heading .hero-content h1 {
        font-size: 28px;
    }
    .slider-content p,
    .page-heading .hero-content p {
        font-size: 0.95rem;
        line-height: 1.65;
    }
    .slider-content,
    .page-heading .hero-content {
        padding-top: 1rem;
        padding-bottom: 1rem;
    }
    .hero-bootstrap-row {
        min-height: 520px;
        padding-top: calc(var(--site-header-offset) + 5rem);
        padding-bottom: 36px;
    }
    .eyebrow {
        font-size: 12px;
        width: fit-content;
        max-width: 100%;
    }
    .widget-section {
        padding: 56px 0 32px;
    }
    .widget-box,
    .footer-card,
    .contact-panel,
    .split-card,
    .feature-card,
    .stat-card {
        border-radius: 14px;
    }
    .widget-section .col-xs-6,
    .services-items .col-xs-6,
    .service-section .col-xs-6,
    .why-us-list .col-xs-6,
    .portfolio-items .col-xs-6,
    .trust-band .col-xs-6,
    .partner-block .col-xs-6,
    .row.g-4 .col-xs-6 {
        float: none;
        width: 100%;
    }
    .scroll-to-top {
        width: 44px;
        height: 44px;
        right: 18px;
        bottom: 18px;
    }

}
/* ---- End of max-width 480px CSS ---- */


/* ---- Start of max-width 420px CSS ---- */
@media all and (max-width: 420px) {
    .tab-container{
        min-height: 330px;
    }
}
/* ---- End of max-width 420px CSS ---- */


/* ---- Start of max-width 380px CSS ---- */
@media all and (max-width: 380px) {
	h1.fz-45{
		font-size: 20px;
	}
	h1.fz-60{
		font-size: 30px;
	}
}
/* ---- End of max-width 380px CSS ---- */
