@charset 'utf-8';
/*
  Theme Name: CasaMia Child
Theme URI: http://casamia.ancorathemes.com/
Description: CasaMia - excellent WordPress theme with many different blog and header layouts
Author: AncoraThemes
Author URI: http://ancorathemes.com/
  Template: casamia
  Version: 1.0
  Tags: light, responsive-layout, flexible-header, accessibility-ready, custom-background, custom-colors, custom-header, custom-menu, featured-image-header, featured-images, full-width-template, microformats, post-formats, theme-options, threaded-comments, translation-ready

*/

@import url('https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,300..800;1,300..800&display=swap');

/* =Theme customization starts here
-------------------------------------------------------------- */

#bkg-inner-title.bkg-inner-title h6 {
    color: #fff;
}
#footer-section.footer-section .widget_title, #footer-section.footer-section .widgettitle {
    color: #EBC44A;
    font-weight: 500;
}
#footer-section.footer-section p {
    color: #fff;
}
#footer-section.footer-section a {
    color: #EBC44A;
}
header.top_panel nav ul#menu_main li a {
    font-weight: 600 !important;
}
header.top_panel .wpb_wrapper img.logo_image {
    max-height: unset !important;
    max-width: 85px;
}
body .sc_properties_info .sc_properties_slider_title a:hover {
    color: #EBC44A !important;
}
body .post_featured.hover_icon .icons a {
    background: linear-gradient(to right, #EBC44A 0%, #EBC44A 100%);
}
body .post_featured.hover_icon .icons a:hover{
    background: #EBC44A;
}
body .post_featured.hover_icon .icons a:hover{
    background: #211E19;
}
body .sc_testimonials_slider .sc_testimonials_item {
    background: linear-gradient(to right, #EBC44A 0%, #EBC44A 100%);
    }
form.wpcf7-form .contact_us .sc_form_field_button input[type="submit"] {
    color: #fff !important;
}
#proeprty-list p {
    margin-bottom: 10px;
}
#proeprty-list h6 {
    font-size: 48px;
    margin-bottom: 30px;
    color: #fff;
}
div#whyus-section .sc_item_descr p {
    font-size: 16px;
    line-height: 24px;
    margin-bottom: 10px;
}
#logo-wrapper .wpb_wrapper h2 {
    margin: 0;
    font-size: 26px;
}
#logo-wrapper .wpb_wrapper {
    display: flex;
    align-items: center;
    gap: 10px;
}
.highlight-point-section {
    border: 1px solid #ebc44a;
    padding: 25px;
        margin-top: 30px;
    margin-bottom: 60px !important;
        background: #EBC44A;
    color: #fff;
}
.highlight-list ul {
    display: flex;
    flex-wrap: wrap;
    gap: 30px;
    padding-left: 0;
}
.highlight-list ul li {
    width: calc(50% - 15px);
    font-size: 18px;
    text-transform: capitalize;
}
.property-overview-section {
    border: 2px solid #ebc44a;
    padding: 40px 5px 10px;
    margin-bottom: 50px;
}
.banner-section {
    max-width: 650px;
    margin: 0 auto;
    padding-bottom: 25px;
}
.property-overview-detail .property-overview p {
    margin-bottom: 10px;
    font-size: 18px;
}

.home-contact-form .contact_us {
        background: #fff;
    padding: 20px;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.05);
}
.home-contact-form .wpcf7-response-output {
    display: block;
    padding: 0 !important;
    top: 20px;
}
#about-us-top-section {
    border: 2px solid #ebc44a;
    padding: 50px 25px;
    margin-top: 50px;
    margin-bottom: 50px;
}
.img-text-section .wpb_wrapper {
    display: flex;
    align-items: center;
    gap: 40px;
    padding-top: 20px;
}
.img-text-section .wpb_wrapper .wpb_single_image {
    width: 40%;
}
.img-text-section .wpb_wrapper .wpb_text_column.wpb_content_element {
    width: 60%;
}
.img-text-section .wpb_wrapper .wpb_text_column.wpb_content_element h6 b {
    color: #ebc44a;
}
.img-text-section .wpb_wrapper .wpb_text_column.wpb_content_element .wpb_wrapper p {
    margin-bottom: 10px;
}
.img-text-section .wpb_wrapper .wpb_text_column.wpb_content_element .wpb_wrapper {
    display: block;
}
#about-us-top-section .sc_item_button {
    margin-top: 50px;
}
#about-us-top-section h6.sc_item_subtitle {
    font-size: 42px;
}
#about-us-top-section h2 {
    font-size: 30px;
}
body .breadcrumbs_item {
    font-weight: bold;
}
body .breadcrumbs_item.current {
    color: #000 !important;
}
#mobile-logo .wpb_wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
}
@media (min-width: 1024px) {
.home-contact-form .contact_us .message textarea {
    min-height: unset;
    height: 73px;
}
.home-contact-form .contact_us input.wpcf7-form-control {
    margin-top: 0 !important;
}
.home-contact-form .contact_us .row {
    padding-bottom: 0;
}
.home-contact-form .contact_us {
    display: flex;
    gap: 20px;
    padding: 50px 20px 70px;
    margin-bottom: 30px;
}
.home-contact-form .contact_us .flex {
    width: 55%;
}
.home-contact-form .contact_us .sub-btn {
    flex-basis: 100%;
    position: absolute;
    bottom: 20px;
}
.home-contact-form .contact_us input ,
.home-contact-form .contact_us .message textarea{
    height: 73px;
}
.home-contact-form .contact_us input.wpcf7-form-control {
    line-height: 0;
}
}
@media (max-width: 1023px) {
  .home-contact-form .wpcf7-response-output {
    top: -15px;
}
#proeprty-list h6 {
    font-size: 34px;
    line-height: 38px;
}
.img-text-section .wpb_wrapper {
    flex-direction: column;
}
.img-text-section .wpb_wrapper .wpb_single_image ,
.img-text-section .wpb_wrapper .wpb_text_column.wpb_content_element{
    width: 100%;
}
#about-us-top-section {
    width: 90%;
    margin: 40px auto;
}
#about-us-top-section h6.sc_item_subtitle {
    font-size: 34px;
}

#about-us-top-section h2 {
    font-size: 20px;
}

.img-text-section .wpb_wrapper .wpb_text_column.wpb_content_element .wpb_wrapper p {
    font-size: 14px;
}
.img-text-section .wpb_wrapper .wpb_text_column.wpb_content_element h6 b {
    font-size: 21px;
    line-height: 26px;
}
.img-text-section .wpb_wrapper .wpb_text_column.wpb_content_element h6 {
    margin-bottom: 24px;
}
.img-text-section .wpb_wrapper {
    gap: 10px;
    }
}
@media (max-width: 1679px) {
div#whyus-section .sc_content.custom_background_offset_right_content_right{
        padding-right: 2rem !important;

    }
}
@media (max-width: 767px) {
.highlight-list ul li {
    width: 100%;
    font-size: 16px;
}
#proeprty-list h6 {
    font-size: 24px;
    line-height: 30px;
}
.highlight-list ul li {
    width: 100%;
    font-size: 14px;
    }
    .property-overview-detail .property-overview p {
    font-size: 14px;
}
}


/* Global style 13-1-26*/
body {
    font-family: 'Open Sans', sans-serif;
    overflow: visible !important;
}
h1, h2, h3, h4, h5, h6 {
    font-weight: 700;
    letter-spacing: -.025em;

}
.page_wrap {
    overflow: visible;
}

/*Button style*/
.primary-button {
box-shadow: rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(247, 130, 29, 0.4) 0px 4px 16px -2px;
    background: #f7821d !important;
    padding: 0 32px !important;
    transition-property: all;
    transition-timing-function: 
cubic-bezier(.4, 0, .2, 1);
    transition-duration: .15s;
    height: 44px;
    border-radius: 6px;
    line-height: 20px;
    text-transform: none !important;
    line-height: 39px !important;
    letter-spacing: 0 !important;
    font-weight: 600 !important;
    color: #fff;
}
.primary-button:hover {
    box-shadow: 0 8px 24px -4px rgba(247, 130, 29, 0.5);
    background: #ec7309 !important;
    color: #fff;    
}
.primary-button .elementor-button {
    box-shadow: rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(247, 130, 29, 0.4) 0px 4px 16px -2px;
    background: #f7821d !important;
    padding: 0 32px !important;
    transition-property: all;
    transition-timing-function: 
cubic-bezier(.4, 0, .2, 1);
    transition-duration: .15s;
    height: 44px;
    border-radius: 6px;
    text-transform: none !important;
    line-height: 44px !important;
    letter-spacing: 0 !important;
    color: #fff;
    font-weight: 600 !important;
}

.primary-button .elementor-button:hover {
    box-shadow: 0 8px 24px -4px rgba(247, 130, 29, 0.5);
    background: #ec7309 !important;
    color: #fff;    
}

.primary-button.elementor-widget {
    background: none !important;
    box-shadow: none;
    padding: 0 !important;
    line-height: normal !important;
    height: auto !important;
    border-radius: 0 !important;
}
/* Header */

.top_panel {
    background: rgb(255 255 255);
    border-bottom: 1px solid #dae0e7;
    box-shadow: none;
    /* -webkit-box-shadow: 0 2px 10px 0 rgba(0, 0, 0, 0.2);
    -ms-box-shadow: 0 2px 10px 0 rgba(0,0,0,0.2);
    box-shadow: 0 2px 10px 0 rgba(0, 0, 0, 0.2); */
    position: sticky;
    top: 0;
    z-index: 100;
}
.top_panel > div {
    margin-left: auto;
    margin-right: auto;
    max-width: 1280px;
    padding-left: 15px;
    padding-right: 15px;
    /* position: static; */
    /* box-shadow: none; */
}

header.top_panel nav ul#menu_main li a,
header.top_panel nav ul#menu_main li {
    text-transform: none !important;
    font-size: 16px;
    color: rgba(19,35,57,0.8);
    letter-spacing: 0;
}
.top_panel_custom_header-fullwidth .sc_layouts_column .sc_layouts_item {
    margin: 0;
}

header.top_panel nav ul#menu_main li a {
    padding: 0 10px !important;
}

/* .top_panel_custom_header-fullwidth .sc_layouts_column .wpb_wrapper {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.top_panel_custom_header-fullwidth .sc_layouts_column  .sc_layouts_item:first-child {
    margin: 0 auto;
} */

/* @media (min-width: 640px) {
.top_panel > div {
        padding-left: 24px;
        padding-right: 24px;
    }
}
@media (min-width: 1024px) {
.top_panel > div {
        padding-left: 32px;
        padding-right: 32px;
    }
} */


/* Home page style */
div.content_wrap {
    width: 100%;
}
/* .hero-banner:after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    background: linear-gradient(to right, rgba(25, 53, 93, 0.25), rgba(25, 53, 93, 0.8), rgba(25, 53, 93, 0.25));
    z-index: 1;
} */

.hero-banner .elementor-element.elementor-pagination-position-outside .swiper {
    padding-bottom: 0;
}

.gallery-section .gallery .gallery-item img{
    transition-property: transform;
    transition-timing-function: 
cubic-bezier(.4, 0, .2, 1);
transition-duration: .5s;
}

.gallery-section .gallery .gallery-item .gallery-icon {
    margin: 0;
    position: relative;
    overflow: hidden;    
}

.gallery-section .gallery .gallery-icon::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    opacity: 0;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0), rgba(0, 0, 0, 0));
    z-index: 1;
    transition-property: transform;
    transition-timing-function: 
cubic-bezier(.4, 0, .2, 1);
transition-duration: .5s;  
pointer-events: none;  
}


.gallery-section .gallery .gallery-item:hover  img{
    transform: scale(1.1);
}

.gallery-section .gallery .gallery-item:hover .gallery-icon::before {
    opacity: 1;
}

.section-title .elementor-heading-title {
    font-family: sans-serif !important;
}

.section-title  span {
    color: #19355d;
}

/* card style */
  
  .titan-card {
    display: flex;
    flex-direction: column;
    gap: 24px;
    border-radius: 12px;
    background-color: #fff;
    padding: 24px;
    transition-property: all;
    transition-timing-function: 
cubic-bezier(.4, 0, .2, 1);
    transition-duration: .3s;
    animation-duration: .3s;
    box-shadow: 0 4px 24px -4px rgba(21, 53, 93, 0.08);    
  }


  .titan-card:hover {
    box-shadow: 0 12px 32px -8px rgba(25,53,93,.15);
    transform: translate(0, -8px);
}

  .titan-card .icon-box:before {
    content: '';
}
  
  @media (min-width: 768px) {
    .titan-card {
      flex-direction: row;
    }
  }
  
  /* Icon */
  .titan-card .icon-wrapper {
    flex-shrink: 0;
  }
  
  .titan-card .icon-box {
    width: 64px;
    height: 64px;
    border-radius: 12px;
    background: linear-gradient(135deg, #0b1f33, #071726);
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .titan-card .icon-box:before {
    display: none;
  }
  
  .titan-card .icon {
    width: 32px;
    height: 32px;
    color: #f97316;
  }
  
  /* Content */
  .titan-card .content h3 {
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 8px;
    margin: 0 0 8px;
    color: #132339;
    height: auto;
    line-height: 28px;
  }
  
  .titan-card  .content p {
    color: #5c6f8a;
    margin-bottom: 16px;
    line-height: 1.6;
  }
  
  /* Tags */
  .titan-card .tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }
  
  .titan-card .tags span {
    padding: 4px 12px;
    background: #f3f4f6;
    border-radius: 999px;
    font-size: 14px;
    color: rgba(19,35,57,0.7)
  }

  .flex-badge {
    display: inline-block;
    background: #FFE8D6;
    color: #FF7A00;
    font-size: 14px;
    font-weight: 600;
    padding: 6px 12px;
    border-radius: 20px;
    font-family: sans-serif;
}

.section-description {
    font-family: sans-serif !important;
}
.top-use-section .e-grid .elementor-widget.elementor-widget-html {
    height: 100%;
}

.top-use-section .e-grid .elementor-widget.elementor-widget-html .titan-card {
    height: 100%;
}
/* Section title */
.sub-title {
    display: flex;
    align-items: center;
    font-size: 18px;
    line-height: 28px;
    font-weight: 700;
    margin-top: 0;
    margin-bottom: 16px;
    color: #111827;
  }
  
  .title-icon {
    width: 20px;
    height: 20px;
    margin-right: 8px;
    color: #f97316;
  }
  
  /* Grid */
  .destinations-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }
  
  @media (min-width: 640px) {
    .destinations-grid {
      grid-template-columns: repeat(3, 1fr);
    }
  }
  
  /* Card */
  .destination-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    background: #fff;
    border-radius: 12px;
  }
  
  .destination-icon {
    width: 20px;
    height: 20px;
    color: #0b1f33;
  }
  
  /* Text */
  .destination-name {
    font-size: 14px;
    line-height: 20px;
    font-weight: 500;
    color: #111827;
    margin: 0;
  }
  
  .destination-time {
    font-size: 12px;
    font-weight: 600;
    color: #f97316;
    margin: 0;    
  }
  
  .map-container .elementor-widget-google_maps {
    box-shadow: rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(25, 53, 93, 0.15) 0px 12px 32px -8px;
    border-radius: 16px;
  }
  .contact-info {
    display: flex;
    flex-direction: column;
    gap: 24px;
    max-width: 600px;
    font-family: sans-serif !important;
  }
  
  .info-item {
    display: flex;
    align-items: flex-start;
    gap: 16px;
  }
  
  .icon-box {
    width: 48px;
    height: 48px;
    background: rgba(245, 158, 11, 0.2); /* titan orange */
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
  }
  
  .icon-box svg {
    width: 24px;
    height: 24px;
    stroke: #f59e0b;
    fill: none;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
  }
  
  .info-content h3 {
    margin: 0 0 4px;
    font-size: 16px;
    font-weight: 700;
    color: #ffffff;
    line-height: 24px;
  }
  
  .info-content p,
  .info-content a {
    margin: 0;
    font-size: 16px;
    line-height: 24px;
    color: rgba(255, 255, 255, 0.8);
    text-decoration: none;
  }
  
  .info-content a:hover {
    color: #f59e0b;
  }

  .about-img {
    box-shadow:  0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgb(0 0 0 / .1);
    border-radius: 12px;
  }
  
  /* Responsive */
  @media (max-width: 480px) {
    .info-item {
      gap: 12px;
    }
  
    .icon-box {
      width: 44px;
      height: 44px;
    }
  }

  .contact-section .flex-badge{
    background: rgba(247, 130, 29, 0.2);
    color: #f7821d;
  }
  .contact-section .icon-box::before {
    display: none;
  }
  .stats-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
    max-width: 600px;
  }
  
  .stat-card {
    background: #f3f5f7; /* secondary */
    padding: 24px;
    border-radius: 16px;
    text-align: center;
  }
  
  .stat-value {
    font-size: 36px;
    font-weight: 800;
    color: #f59e0b; /* titan orange */
    margin-bottom: 8px;
    line-height: 1;
  }
  
  .stat-label {
    font-size: 14px;
    color: #5c6f8a;
    margin: 0;
  }
  
  /* Responsive */
  @media (max-width: 480px) {
    .stats-grid {
      grid-template-columns: 1fr;
    }
  
    .stat-value {
      font-size: 32px;
    }
  }

  .brand-note {
    margin-top: 32px;
    padding: 24px;
    background-color: rgba(15, 23, 42, 0.05); /* titan navy / 5% */
    border: 1px solid rgba(15, 23, 42, 0.1);  /* titan navy / 10% */
    border-radius: 16px;
    text-align: center;
  }
  
  .brand-note p {
    margin: 0;
    font-size: 16px;
    color: #6b7280; /* muted foreground */
    line-height: 1.5;
  }
  
  .brand-note .highlight {
    font-weight: 600;
    color: #132339; /* foreground */
  }
  
  /* footer */
  .footer-section [class*="sc_content_width_"]:not([class*="sc_margin_"]) {
    max-width: 1246px;
    width: 100%;
}

#footer-section.footer-section a {
    color: rgba(255,255,255,0.7) !important;
    font-size: 14px;
    font-weight: 400;
    line-height: 20px;
    text-transform: none;
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
    transition-timing-function: 
cubic-bezier(.4, 0, .2, 1);
    transition-duration: .15s;
    letter-spacing: 0;
    padding: 30px 12px !important;    
    font-family: sans-serif !important;
}

p.text-primary-foreground\/50.text-sm {}

.footer-bottom {
    text-align: center;
}

.footer-bottom .widget.widget_text {
    padding-top: 32px;
    border-top: 1px solid rgb(255 255 255 / 10%);
    margin: 32px auto 0;
    width: 1246px;
    font-size: 12px;
    line-height: 16px;
    max-width: 100%;
}

.footer-section .sc_layouts_item {
    margin: 0 !important;
}

#footer-section.footer-section .widget.widget_text {
    font-size: 14px;
    line-height: 20px;
    color: rgba(255,255,255,0.5);
    margin: 30px 0;
}

#footer-section.footer-section .widget.widget_text p {
    color: rgba(255, 255, 255, 0.5);
}
.footer-logo {
    width: auto;
    /* margin-right: auto !important; */
}

#footer-section.footer-section .footer-logo a {
    padding: 0 !important;
}

 footer.footer_wrap {
    background: #0F223D;
 }
 .top_panel {
    margin-bottom: 0;
}

.gallery-filter  {
    border-radius: 30px;
    padding: 10px 22px;
    background: #eef2f6;
    color: #3a4a5b;
    transition: all 0.3s ease;
  }
  
  .gallery-filter.active {
    background: #1f3b5c;
    color: #ffffff;
  }
 
  .floating-buttons {
    position: fixed;
    bottom: 92px;
    right: 22px;
    z-index: 100;
}

.floating-buttons .wpb_wrapper {
    display: flex;
    flex-direction: column;
    gap: 0;
    align-items: flex-end;
}

.secondary-button {
    box-shadow: rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0.1) 0px 10px 15px -3px, rgba(0, 0, 0, 0.1) 0px 4px 6px -4px;
    background: #fff !important;
    padding: 0 32px !important;
    transition-property: all;
    transition-timing-function: 
cubic-bezier(.4, 0, .2, 1);
    transition-duration: .15s;
    height: 44px;
    border-radius: 6px;
    border: 1px solid #ebc44a !important;
    line-height: 20px;
    text-transform: none !important;
    line-height: 39px !important;
    letter-spacing: 0 !important;
    font-weight: 600 !important;
    color: #f7821d !important;
}

.floating-buttons .primary-button:before,.floating-buttons .secondary-button:before {
    content: '';
    width: 18px;
    height: 18px;
    display: inline-block;
    position: relative;
    vertical-align: middle;
    margin: auto 12px auto 0;

}
.floating-buttons .primary-button:before {
    background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-calendar w-5 h-5 mr-2"><path d="M8 2v4"></path><path d="M16 2v4"></path><rect width="18" height="18" x="3" y="4" rx="2"></rect><path d="M3 10h18"></path></svg>') no-repeat;
    background-position: left 0 center;
    background-size: 18px;
    filter: invert(1);
} 
.floating-buttons .primary-button,.floating-buttons .secondary-button {
    padding: 0 15px  !important;
    position: relative;
    width: 100%;
}

.floating-buttons .secondary-button:before {
    background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="%23f7821d" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucid   e-phone w-5 h-5 mr-2"><path d="M22 16.92v3a2 2 0 0 1-2.18 2 19.79 19.79 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6 19.79 19.79 0 0 1-3.07-8.67A2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72 12.84 12.84 0 0 0 .7 2.81 2 2 0 0 1-.45 2.11L8.09 9.91a16 16 0 0 0 6 6l1.27-1.27a2 2 0 0 1 2.11-.45 12.84 12.84 0 0 0 2.81.7A2 2 0 0 1 22 16.92z"></path></svg>');
    background-position: left 0 center;
    background-size: 18px;
}

.floating-buttons .wpb_wrapper > div {
    width: 100%;
    padding: 0 !important;
    margin: 0;
}

.unit-testing-grid .titan-card h3 {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 8px;
    margin: 0 0 8px;
    color: #132339;
    height: auto;
    line-height: 28px;
}

.unit-testing-grid .titan-card {flex-direction: column;}

.unit-testing-grid .titan-card .icon-wrapper {
    display: flex;
    gap: 16px;
    align-items: center;
}

.unit-testing-grid .titan-card .tags span {
    border-radius: 0;
    position: relative;
    padding: 0 0 0 22px;
    font-size: 14px;
    margin-bottom: 8px;
    display: block;
    background: none;
}

.unit-testing-grid .titan-card .tags {
    display: block;
}

.unit-testing-grid .titan-card .tags span:before {
    content: "";
    position: absolute;
    left: 0;
    color: #f59e0b;
    font-weight: bold;
    background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="%23f7821d" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-check w-4 h-4 text-titan-orange flex-shrink-0"><path d="M20 6 9 17l-5-5"></path></svg>');
    width: 16px;
    height: 16px;
    background-size: 16px;
    top: 5px;
}

.titan-suite-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    position: relative;
  }
  
  /* Card */
  .titan-card {
    position: relative;
    background: #ffffff;
    border-radius: 18px;
    padding: 32px 24px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.08);
    transition: transform .3s ease, box-shadow .3s ease;
  }
  
  .titan-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 18px 40px rgba(0,0,0,0.14);
  }
  
  /* Featured */
  .titan-card.featured {
    border: 2px solid #f59e0b;
  }
  
  /* Badge */
  .titan-card .badge {
    position: absolute;
    top: -12px;
    left: 50%;
    transform: translateX(-50%);
    background: #f59e0b;
    color: #ffffff;
    font-size: 11px;
    font-weight: 700;
    padding: 4px 12px;
    border-radius: 999px;
    letter-spacing: 0.04em;
  }
  
  /* Text */
  .text-center {
    text-align: center;
  }
  
  .suite-size {
    font-size: 36px;
    font-weight: 800;
    color: #f59e0b;
    margin-bottom: 8px;
  }
  
  .suite-title {
    font-size: 18px;
    font-weight: 600;
    margin-bottom: 0;
    color: #111827;
  }
  
  .suite-desc {
    font-size: 14px;
    color: #6b7280;
    margin-bottom: 0;
  }

  .titan-suite-grid .titan-card {
    flex-direction: column;
    gap: 12px;
}
.btn-container .primary-button {
    color: #ffff !important;
    margin-right: 10px;
}
.btn-container .primary-button,.btn-container .secondary-button {
    display: inline-block;
    height: 56px;
    line-height: 56px !important;
}

.btn-container .secondary-button {
    border-color: rgba(255, 255, 255, 0.3) !important;
    border-width: 2px !important;
    background: none !important ;
    color: #fff !important;
}

footer.footer_wrap {
    margin: 0;
}

.about-img {
    height: 100%;
}

.about-img img {
    height: 100%;
    object-fit: cover;
    object-position: center center;
}

.contact_us input[type="text"], .contact_us input[type="email"], .contact_us textarea {
    text-transform: none;
}

  /* Responsive */
  @media (max-width: 1024px) {
    .titan-suite-grid {
      grid-template-columns: repeat(2, 1fr);
    }
  }
  
  @media (max-width: 767px) {
    .titan-suite-grid {
      grid-template-columns: 1fr;
    }
  }

@media (max-width: 1024px) {
    .footer-bottom .widget.widget_text {
        padding-top: 20px;
        margin: 20px auto;
    }
    .footer-top {
        padding-top: 30px !important;
        padding-bottom: 30px !important;
    }
    .top_panel > .vc_row.vc_row-flex {
        flex-wrap: nowrap;
    }    
    .top_panel  .header-logo {
        width: auto !important;
    }
}

@media (max-width: 991px) {
    .footer_wrap .footer-menu {
        text-align: right;
    }
    .top_panel  .header-logo {
        display: none;
    }
    
    footer.footer_wrap .sc_content .footer-logo + .footer-menu + .wpb_column {
        margin-top: 0 !important;
        padding-top: 0 !important;
        text-align: center;
        width: 100% !important;
    }
    
    #footer-section.footer-section .widget.widget_text {
        text-align: center;
    }
    .stats-grid {
        margin: 0 auto;
    }
    .gallery.gallery-columns-3 .gallery-item {
        width: 50% !important;
    }

    .mobile_device .menu_mobile .search_mobile, .mobile_layout .menu_mobile .search_mobile,.mobile_device .menu_mobile .socials_mobile, .mobile_layout .menu_mobile .socials_mobile {
        display: none;
    }
    
    .menu_mobile .menu_mobile_inner {
        color: #000;
    }
    
    .scheme_dark .menu_mobile_inner .sc_layouts_logo img {
        max-height: 100px;
    }
    
    .menu_mobile .menu_mobile_nav_area > ul > li > a {
        color: rgba(19, 35, 57, 0.8) !important;
        font-weight: 600;
        text-align: center;
        text-transform: none;
        letter-spacing: 0;
        padding: 5px;
        font-size: 20px;
    }   
    .top_panel  .header-right {
        display: none !important; 
    } 

    .menu_mobile {
    position: sticky;
        width: 100%;
        left: auto;
        right: 0;
        height: auto;
        top: 74px;
        background: rgba(255, 255, 255, 0.95);
        backdrop-filter: blur(12px);
        bottom: auto;
    }
           .menu_mobile.opened {
    height: calc(100vh - 74px);
}

    .menu_mobile.opened .menu_mobile_inner { 
        padding: 16px;
    }

    header.top_panel .wpb_wrapper img.logo_image {
        max-width: 100%;
        height: 60px;
    }
        
    .menu_mobile .sc_layouts_logo {
        display: none;
    }
    
    .menu_mobile .menu_mobile_inner {
        background: #f3f5f7;
        box-sizing: border-box;
    }
    
    .mobile_layout .menu_mobile .menu_mobile_nav_area {
        margin: 0;
        text-align: left;
    }
    
    .menu_mobile .menu_mobile_nav_area > ul > li > a {
        display: block;
        text-align: left;
    }
    
    .menu_mobile .menu_mobile_nav_area li {margin-bottom: 10px;}
    .mobile_device .menu_mobile .menu_mobile_nav_area, .mobile_layout .menu_mobile .menu_mobile_nav_area {
        margin-top: 20px;
    }
    .scheme_dark .menu_mobile_close:before, .scheme_dark .menu_mobile_close:after {
        border-color: #ebc44a;
        width: 50%;
    }
    .menu_mobile_close.icon-cancel {
        /* display: none; */
        top: 0px;
        width: 40px;
        height: 40px;
        z-index: 1;
        color: #000;
        right: 12px;
        font-size: 20px;
    }

    .footer_wrap > .sc_layouts_row {
        max-width: 100%;
    }
    
    .footer-bottom .wpb_wrapper .wpb_column {
        width: 100%;
        text-align: center !important;
    }
    
    .footer-bottom .wpb_wrapper .wpb_column .vc_column-inner .widget_text {text-align: center !important;}
    
    .footer-bottom .wpb_wrapper .wpb_column .vc_column-inner .widget_text * {text-align: center !important;}
    
    .footer-bottom .wpb_wrapper .wpb_column:last-child .vc_column-inner .widget_text {
        border: none;
    }
    .menu_mobile .menu_mobile_nav_area > ul > li.current-menu-item > a,
    .menu_mobile .menu_mobile_nav_area > ul > li > a:hover {
        color: #ff8b02 !important;
    }
}

@media (min-width: 768px) {
    header.top_panel nav ul#menu_main li.primary-button {
        display: none;
    }
}

@media (max-width: 767px) {
    .top_panel .header-menu {
        /* order: 0; */
        width: auto !important;
        margin-right: 0;
        margin-left: auto;
    }
    
    /* .top_panel  .header-logo {
        order: 1;
    } */
    
    .top_panel  .header-right {
        order: 2;
        display: none !important; 
        width: auto !important;
    }
    .page_content_wrap .content_wrap {
        width: 100% !important;
    }
    .footer-menu >.vc_column-inner {
        padding: 0;
    }
   header.top_panel {
        margin-bottom: 0;
    }
    .sc_layouts_menu_mobile_button:hover .sc_layouts_item_icon {
        color: #ff8b02 !important;
    }
}

@media (max-width: 640px) {
    .gallery.gallery-columns-3 .gallery-item {
        width: 100% !important;
    }
    .primary-button {
        padding: 0 15px !important;
    }
    
    .footer_wrap .footer-top {
        box-sizing: border-box;
        max-width: 100%;
    }
    
    #footer-section.footer-section .footer-logo a {
        text-align: center;
    }
    
    #footer-section.footer-section .footer-logo a .logo_image {
        margin: 0 auto;
        display: block;
    }
    
    footer.footer_wrap .sc_content .wpb_column + .wpb_column {
        text-align: center;
        padding-top: 0 !important;
        margin-top: 0 !important;
    }    
    footer.footer_wrap .sc_content .footer-logo + .footer-menu + .wpb_column {
        clear: both;
    }
}
@media (max-width: 479px) {
    .mobile_device .menu_mobile .menu_mobile_nav_area, .mobile_layout .menu_mobile .menu_mobile_nav_area {
        margin-top: 20px;
    }
    .btn-container {
        display: flex;
        flex-direction: column;
    }
    
    .btn-container .primary-button, .btn-container .secondary-button {
        width: 100%;
        text-align: center;
    }
    .mobile_device .menu_mobile .menu_mobile_nav_area, .mobile_layout .menu_mobile .menu_mobile_nav_area {
        margin-top: 1em;
    }
}