@charset "UTF-8";
/*
Theme Name: JBP Consultancy
Theme URI: https://wordpress.org/themes/twentytwentyone/
Author: the WordPress team
Author URI: https://wordpress.org/
Description: Twenty Twenty-One is a blank canvas for your ideas and it makes the block editor your best brush. With new block patterns, which allow you to create a beautiful layout in a matter of seconds, this theme’s soft colors and eye-catching — yet timeless — design will let your work shine. Take it for a spin! See how Twenty Twenty-One elevates your portfolio, business website, or personal blog.
Requires at least: 5.3
Tested up to: 6.9
Requires PHP: 5.6 
Version: 2.7
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: twentytwentyone
Tags: one-column, accessibility-ready, custom-colors, custom-menu, custom-logo, editor-style, featured-images, footer-widgets, block-patterns, rtl-language-support, sticky-post, threaded-comments, translation-ready, blog, portfolio

Twenty Twenty-One WordPress Theme, (C) 2020 WordPress.org
Twenty Twenty-One is distributed under the terms of the GNU GPL.
*/
/**
 * SETTINGS
 * File-header..........The file header for the themes style.css file.
 * Fonts................Any font files, if the project needs specific fonts.
 * Global...............Project-specific, globally available variables.
 *
 * TOOLS
 * Functions............Global functions.
 * Mixins...............Global mixins.
 *
 * GENERIC
 * Normalize.css........Normalise browser defaults.
 * Breakpoints..........Mixins and variables for responsive styles
 * Vertical-margins.....Vertical spacing for the main components.
 * Reset................Reset specific elements to make them easier to style in other contexts.
 * Clearings............Clearings for the main components.
 *
 * ELEMENTS
 * Blockquote...........Default blockquote.
 * Forms................Element-level form styling.
 * Headings.............H1–H6
 * Links................Default links.
 * Lists................Default lists.
 * Media................Images, Figure, Figcaption, Embed, iFrame, Objects, Video.
 *
 * BLOCKS
 * Audio................Specific styles for the audio block.
 * Button...............Specific styles for the button block.
 * Code.................Specific styles for the code block.
 * Columns..............Specific styles for the columns block.
 * Cover................Specific styles for the cover block.
 * File.................Specific styles for the file block.
 * Gallery..............Specific styles for the gallery block.
 * Group................Specific styles for the group block.
 * Heading..............Specific styles for the heading block.
 * Image................Specific styles for the image block.
 * Latest comments......Specific styles for the latest comments block.
 * Latest posts.........Specific styles for the latest posts block.
 * Legacy...............Specific styles for the legacy gallery.
 * List.................Specific styles for the list block.
 * Media text...........Specific styles for the media and text block.
 * Navigation...........Specific styles for the navigation block.
 * Paragraph............Specific styles for the paragraph block.
 * Pullquote............Specific styles for the pullquote block.
 * Quote................Specific styles for the quote block.
 * Search...............Specific styles for the search block.
 * Separator............Specific styles for the separator block.
 * Table................Specific styles for the table block.
 * Verse................Specific styles for the verse block.
 * Video................Specific styles for the video block.
 * Utilities............Block alignments.
 *
 * COMPONENTS
 * Header...............Header styles.
 * Footer...............Footer styles.
 * Comments.............Comment styles.
 * Archives.............Archive styles.
 * 404..................404 styles.
 * Search...............Search styles.
 * Navigation...........Navigation styles.
 * Footer Navigation....Footer Navigation styles.
 * Pagination...........Pagination styles.
 * Single...............Single page and post styles.
 * Posts and pages......Misc, sticky post styles.
 * Entry................Entry, author biography.
 * Widget...............Widget styles.
 * Editor...............Editor styles.
 *
 * UTILITIES
 * A11y.................Screen reader text, prefers reduced motion etc.
 * Color Palette........Classes for the color palette colors.
 * Editor Font Sizes....Editor Font Sizes.
 * Measure..............The width of a line of text, in characters.
 */
/* Categories 01 to 03 are the basics. */
@font-face {
  font-family: "Gilroy";
  src: url("./assets/fonts/Gilroy-Regular.woff2") format("woff2"), url("./assets/fonts/Gilroy-Regular.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Gilroy";
  src: url("./assets/fonts/Gilroy-SemiBold.woff2") format("woff2"), url("./assets/fonts/Gilroy-SemiBold.woff") format("woff");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Gilroy";
  src: url("./assets/fonts/Gilroy-ExtraBold.woff2") format("woff2"), url("./assets/fonts/Gilroy-ExtraBold.woff") format("woff");
  font-weight: bold;
  font-style: normal;
  font-display: swap;
}
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: "Gilroy";
  font-weight: normal;
  font-style: normal;
  font-size: 15px;
  background: #111111;
  color: #ffffff;
  line-height: 1.6;
  overflow-x: hidden;
}

img {
  max-width: 100%;
}

input.form-control, textarea.form-control, select.form-control {
  background: rgba(8, 8, 11, 0.2);
  border: 1px solid #373737;
  height: 50px;
  color: #ffffff;
}
input.form-control::-moz-placeholder, textarea.form-control::-moz-placeholder, select.form-control::-moz-placeholder {
  color: #999999;
}
input.form-control::placeholder, textarea.form-control::placeholder, select.form-control::placeholder {
  color: #999999;
}
input.form-control:focus, textarea.form-control:focus, select.form-control:focus {
  background: #07070a;
  box-shadow: none;
  border-color: rgba(197, 160, 89, 0.5);
  color: #ffffff;
}

label.error {
  color: #C5A059;
  font-size: 12px;
}

textarea.form-control {
  height: auto;
}

.section_pad {
  padding: 70px 0;
}

.cmn_hdng {
  font-size: clamp(26px, 3vw, 40px);
  font-weight: 700;
  color: #ffffff;
  line-height: 1.25;
}

.site_header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1000;
  transition: background 0.3s ease;
}
.site_header.scrolled {
  background: rgba(7, 7, 10, 0.92);
}

.navbar {
  padding: 0;
  min-height: 72px;
}
.navbar .container {
  display: flex;
  align-items: center;
  gap: 32px;
}

.navbar-brand {
  flex-shrink: 0;
  padding: 0;
}
.navbar-brand .logo_img {
  height: 52px;
  width: auto;
  display: block;
}

.navbar-toggler {
  all: unset;
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 40px;
  height: 40px;
  cursor: pointer;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.08) !important;
  border: 1px solid rgba(255, 255, 255, 0.15) !important;
  box-shadow: none !important;
  padding: 8px !important;
  flex-shrink: 0;
  margin-left: auto;
}
.navbar-toggler-icon {
  display: none !important;
}
.navbar-toggler .toggler_bar {
  display: block;
  width: 20px;
  height: 2px;
  background: #ffffff;
  border-radius: 2px;
  transition: all 0.25s ease;
  pointer-events: none;
}
.navbar-toggler:focus {
  outline: none !important;
  box-shadow: none !important;
}

.navbar-collapse {
  display: flex;
  align-items: center;
  flex: 1;
}

.navbar-nav {
  display: flex;
  align-items: center;
  list-style: none;
  gap: 4px;
  flex: 1;
  justify-content: center;
}
.navbar-nav .nav-item {
  position: relative;
}
.navbar-nav .nav-item.has_dropdown:hover > .dropdown_menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}
.navbar-nav .nav-link {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 16px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.85);
  text-decoration: none;
  padding: 26px 14px;
  letter-spacing: 0.02em;
  transition: color 0.2s ease;
}
.navbar-nav .nav-link:hover, .navbar-nav .nav-link.active {
  color: #C5A059;
}
.navbar-nav .nav-link .chevron {
  transition: transform 0.2s ease;
  color: #C5A059;
  flex-shrink: 0;
}
.navbar-nav .nav-item.has_dropdown:hover .nav-link .chevron {
  transform: rotate(180deg);
}

.dropdown_menu {
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 220px;
  background: #111111;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-top: 2px solid #C5A059;
  border-radius: 0 0 6px 6px;
  list-style: none;
  padding: 8px 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: all 0.22s ease;
  pointer-events: none;
  z-index: 999;
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.5);
}
.dropdown_menu li {
  position: relative;
}
.dropdown_menu li:hover > .sub_menu {
  opacity: 1;
  visibility: visible;
  transform: translateX(0);
  pointer-events: auto;
}
.dropdown_menu li:hover > a {
  color: #C5A059;
  background: rgba(197, 160, 89, 0.06);
}
.dropdown_menu > li > a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 18px;
  font-size: 13.5px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.82);
  text-decoration: none;
  letter-spacing: 0.02em;
  transition: all 0.18s ease;
}
.dropdown_menu > li > a .chevron_right {
  color: #C5A059;
  flex-shrink: 0;
}
.dropdown_menu.sub_menu {
  top: -9px;
  left: 100%;
  border-top: 2px solid #C5A059;
  transform: translateX(10px);
  transition: all 0.22s ease;
}

.nav_actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}

.btn_vision {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-radius: 3px;
  padding: 13px 28px;
  cursor: pointer;
  transition: all 0.28s ease;
  text-decoration: none;
  border: 2px solid transparent;
  white-space: nowrap;
  background: #C5A059;
  color: #07070a;
  border-color: #C5A059;
  padding: 8px 16px;
  border-radius: 3px;
}
.btn_vision:hover {
  background: #a8883f;
  border-color: #a8883f;
  color: #ffffff;
}

.btn_phone {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-radius: 3px;
  padding: 13px 28px;
  cursor: pointer;
  transition: all 0.28s ease;
  text-decoration: none;
  border: 2px solid transparent;
  white-space: nowrap;
  background: rgba(255, 255, 255, 0.08);
  color: #ffffff;
  border-color: rgba(255, 255, 255, 0.25);
  padding: 8px 16px;
  border-radius: 3px;
}
.btn_phone:hover {
  background: #ffffff;
  color: #07070a;
  border-color: #ffffff;
}

.offcanvas {
  background: #111111 !important;
  width: 300px !important;
  border-left: 1px solid rgba(255, 255, 255, 0.08) !important;
}
.offcanvas .offcanvas-header {
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  padding: 16px 20px;
}
.offcanvas .offcanvas-header .logo_img {
  height: 44px;
  width: auto;
}
.offcanvas .offcanvas-header .btn-close {
  filter: invert(1);
  opacity: 0.7;
}
.offcanvas .offcanvas-header .btn-close:hover {
  opacity: 1;
}
.offcanvas .offcanvas-body {
  padding: 0;
  overflow-y: auto;
}

.mobile_nav_list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.mobile_nav_list > li {
  border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}
.mobile_nav_list > li > a {
  display: block;
  padding: 15px 20px;
  font-size: 15px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.88);
  text-decoration: none;
  transition: color 0.2s ease;
}
.mobile_nav_list > li > a:hover {
  color: #C5A059;
}

.mobile_toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  background: none;
  border: none;
  border-radius: 0;
  padding: 15px 20px;
  font-size: 15px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.88);
  cursor: pointer;
  text-align: left;
  transition: color 0.2s ease;
}
.mobile_toggle:hover {
  color: #C5A059;
}
.mobile_toggle:focus {
  outline: none;
  box-shadow: none;
}
.mobile_toggle .chevron {
  transition: transform 0.25s ease;
  flex-shrink: 0;
  color: #C5A059;
}
.mobile_toggle.open .chevron {
  transform: rotate(180deg);
}

.mobile_sub_list {
  list-style: none;
  padding: 0;
  margin: 0;
  background: rgba(255, 255, 255, 0.03);
  display: none;
  border-top: 1px solid rgba(255, 255, 255, 0.05);
}
.mobile_sub_list.open {
  display: block;
}
.mobile_sub_list > li {
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}
.mobile_sub_list > li:last-child {
  border-bottom: none;
}
.mobile_sub_list > li > a {
  display: block;
  padding: 12px 20px 12px 36px;
  font-size: 14px;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.7);
  text-decoration: none;
  transition: color 0.2s ease;
}
.mobile_sub_list > li > a:hover {
  color: #C5A059;
}
.mobile_sub_list > li > .mobile_toggle {
  padding: 12px 20px 12px 36px;
  font-size: 14px;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.7);
}
.mobile_sub_list .mobile_sub_list > li > a {
  padding-left: 52px;
  font-size: 13px;
}
.mobile_sub_list .mobile_sub_list > li > .mobile_toggle {
  padding-left: 52px;
  font-size: 13px;
}

.mobile_nav_actions {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 20px;
  flex-wrap: wrap;
  border-top: 1px solid rgba(255, 255, 255, 0.07);
}
.mobile_nav_actions .btn_vision,
.mobile_nav_actions .btn_phone {
  flex: 1;
  justify-content: center;
  min-width: 110px;
}

.banner_sec {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  overflow: hidden;
}

.banner_bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.banner_bg .banner_img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center center;
     object-position: center center;
  display: block;
}
.banner_bg .banner_overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0) 100%);
}

.banner_sec .container {
  position: relative;
  z-index: 1;
}

.banner_content {
  max-width: 680px;
  margin: 0 auto;
  text-align: center;
  padding-top: 72px;
  animation: fadeUp 0.9s ease both;
}

.banner_director {
  font-size: 14px;
  font-weight: 400;
  letter-spacing: 0.12em;
  margin-bottom: 18px;
  text-transform: uppercase;
}

.banner_title {
  font-size: clamp(42px, 6vw, 72px);
  font-weight: 800;
  line-height: 0.9;
  color: #ffffff;
  letter-spacing: -0.01em;
  margin-bottom: 22px;
}
.banner_title .highlight {
  color: #C5A059;
  display: block;
}

.banner_desc {
  font-weight: 400;
  line-height: 1.75;
  margin-bottom: 40px;
}

.banner_actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
}

.btn_primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-radius: 3px;
  padding: 13px 28px;
  cursor: pointer;
  transition: all 0.28s ease;
  text-decoration: none;
  border: 2px solid transparent;
  white-space: nowrap;
  background: #C5A059;
  color: #07070a;
  border-color: #C5A059;
}
.btn_primary:hover {
  background: #a8883f;
  border-color: #a8883f;
  color: #ffffff;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(197, 160, 89, 0.35);
}

.btn_secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-radius: 3px;
  padding: 13px 28px;
  cursor: pointer;
  transition: all 0.28s ease;
  text-decoration: none;
  border: 2px solid transparent;
  white-space: nowrap;
  background: #ffffff;
  color: #07070a;
  border-color: #ffffff;
}
.btn_secondary:hover {
  background: #ffffff;
  color: #07070a;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(255, 255, 255, 0.2);
}

@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.about_sec {
  background: #111111;
  scroll-margin-top: 60px;
}
.about_sec .container {
  display: flex;
}

.about_content {
  flex: 0 0 60%;
  max-width: 60%;
  padding: 50px 30px 0 0;
}

.about_label {
  font-size: 14px;
  font-weight: 500;
  color: #C5A059;
  letter-spacing: 0.04em;
  margin-bottom: 14px;
  display: block;
}

.about_title {
  margin-bottom: 24px;
}

.about_text {
  font-weight: 400;
  line-height: 1.8;
  margin-bottom: 16px;
  color: rgba(255, 255, 255, 0.62);
}
.about_text:last-of-type {
  margin-bottom: 32px;
}

.about_actions {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 44px;
}

.about_stats {
  display: flex;
  align-items: flex-start;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding-top: 32px;
}

.stat_item {
  flex: 1;
  padding-right: 24px;
  position: relative;
  text-align: center;
}
.stat_item:not(:last-child)::after {
  content: "";
  position: absolute;
  right: 0;
  top: 4px;
  height: 100%;
  width: 1px;
  background: #a8883f;
}
.stat_item:not(:first-child) {
  padding-left: 24px;
  padding-right: 24px;
}
.stat_item:last-child {
  padding-right: 0;
}

.stat_number {
  font-size: clamp(32px, 4vw, 60px);
  font-weight: 700;
  color: #C5A059;
  line-height: 1;
  margin-bottom: 8px;
}

.stat_label {
  font-size: 22px;
  font-weight: 600;
  letter-spacing: 0.02em;
}

.about_image_wrap {
  flex: 0 0 40%;
  max-width: 40%;
  position: relative;
}

.about_img {
  width: 100%;
  height: auto;
  display: block;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center top;
     object-position: center top;
}

.reach_sec {
  background: #111111;
}

.reach_card {
  border-radius: 200px;
  background: #07070a;
  padding: 20px 90px;
  display: flex;
  align-items: center;
  gap: 0;
}

.reach_left {
  flex: 0 0 30%;
  max-width: 30%;
}

.reach_title {
  font-size: clamp(22px, 2.5vw, 30px);
  font-weight: 700;
  color: #ffffff;
  margin-bottom: 24px;
}

.reach_regions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.reach_region_btn {
  font-weight: 500;
  color: #ffffff;
  background: transparent;
  border: 1px solid #a8883f;
  border-radius: 0px;
  padding: 10px 14px;
  cursor: pointer;
  text-align: center;
  transition: all 0.22s ease;
  white-space: nowrap;
}
.reach_region_btn:hover, .reach_region_btn.active {
  background: #C5A059;
  border-color: #C5A059;
  color: #07070a;
}

.reach_map {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 32px;
}
.reach_map img {
  width: 100%;
  max-width: 360px;
  height: auto;
  display: block;
}

.reach_right {
  flex: 0 0 30%;
  max-width: 30%;
}

.reach_values_title {
  font-size: clamp(22px, 2.5vw, 30px);
  font-weight: 700;
  color: #ffffff;
  margin-bottom: 24px;
}

.reach_values_list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.reach_value_item {
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.85);
}
.reach_value_item .value_icon {
  flex-shrink: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6px 0 6px 10px;
  border-color: transparent transparent transparent #C5A059;
}

.capabilities_sec {
  background: #07070a;
  text-align: center;
  scroll-margin-top: 30px;
}

.capabilities_label {
  font-size: 14px;
  font-weight: 500;
  color: #C5A059;
  letter-spacing: 0.08em;
  margin-bottom: 12px;
  display: block;
}

.capabilities_title {
  margin-bottom: 56px;
}

.hex_grid {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
}

.hex_row {
  display: flex;
  justify-content: center;
}
.hex_row:nth-child(even) {
  margin-top: -75px;
  margin-bottom: -75px;
  position: relative;
  z-index: 1;
}
.hex_row:nth-child(1) .hex_item:last-child .hex_inner::before {
  background: #07070a;
}
.hex_row:nth-child(2) .hex_item:first-child .hex_inner::before {
  background: #07070a;
}
.hex_row:nth-child(3) .hex_item:last-child .hex_inner::before {
  background: #07070a;
}

.hex_item {
  width: 269px;
  position: relative;
  transition: all 0.4s;
}
.hex_item:hover {
  transform: scale(1.05);
  z-index: 10;
}
.hex_item:hover .hex_inner {
  background: #999999;
}
.hex_item .hex_inner {
  width: 270px;
  height: 300px;
  clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
  background: #a8883f;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 28px 10px;
  transition: background 0.3s ease;
  cursor: default;
}
.hex_item .hex_inner::before {
  content: "";
  position: absolute;
  inset: 1px;
  background: #1a1a1a;
  z-index: -1;
  clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
}
.hex_item.hex_center .hex_inner {
  background: linear-gradient(145deg, #C5A059 0%, rgb(143.9160714286, 111.8383928571, 50.2839285714) 100%);
  cursor: default;
}
.hex_item.hex_center .hex_inner::before {
  background: #C5A059;
}

.hex_icon {
  width: 36px;
  height: 36px;
  margin-bottom: 12px;
  color: #C5A059;
  flex-shrink: 0;
}
.hex_icon svg {
  width: 100%;
  height: 100%;
}

.hex_title {
  font-size: 16px;
  font-weight: 700;
  color: #ffffff;
  line-height: 1.3;
  margin-bottom: 8px;
  text-align: center;
}

.hex_desc {
  font-size: 14px;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.62);
  line-height: 1.6;
  text-align: center;
}

.hex_logo {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
}
.hex_logo img {
  width: 80%;
}

.projects_sec {
  background: #07070a;
  position: relative;
  padding: 40px 0 20px;
  scroll-margin-top: 60px;
}
.projects_sec:before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  height: 100%;
  width: calc(100% - 60px);
  margin: auto;
  background: linear-gradient(180deg, #272727 0%, #07070A 100%);
  border-radius: 100px 100px 0 0;
}
.projects_sec .container {
  z-index: 10;
  position: relative;
  padding: 0 50px;
}

.projects_label {
  font-size: 14px;
  font-weight: 500;
  color: #C5A059;
  letter-spacing: 0.04em;
  margin-bottom: 12px;
  display: block;
}

.projects_title {
  margin-bottom: 16px;
}

.projects_desc {
  font-weight: 400;
  color: rgba(255, 255, 255, 0.62);
  line-height: 1.75;
  max-width: 560px;
  margin-bottom: 28px;
}

.projects_filters {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 36px;
}

.filter_btn {
  font-size: 13px;
  font-weight: 500;
  color: #ffffff;
  background: transparent;
  border: 1px solid #a8883f;
  border-radius: 0;
  padding: 8px 22px;
  cursor: pointer;
  transition: all 0.22s ease;
  letter-spacing: 0.03em;
}
.filter_btn:hover, .filter_btn.active {
  background: #C5A059;
  border-color: #C5A059;
  color: #07070a;
}

.projects_layout {
  display: flex;
  align-items: flex-start;
  gap: 40px;
}

.projects_image_wrap {
  flex: 0 0 28%;
  max-width: 28%;
  position: relative;
  align-self: center;
}

.projects_circle_img {
  width: 100%;
  display: block;
}

.projects_logo_badge {
  position: absolute;
  bottom: 8%;
  right: 4%;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: #07070a;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid rgba(255, 255, 255, 0.1);
}
.projects_logo_badge img {
  width: 54px;
  height: auto;
  filter: brightness(0) invert(1);
}

.projects_list {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-height: 700px;
  overflow-y: auto;
  max-height: 580px;
  /* width */
}
.projects_list::-webkit-scrollbar {
  width: 10px;
}
.projects_list {
  /* Track */
}
.projects_list::-webkit-scrollbar-track {
  background: transparent;
}
.projects_list {
  /* Handle */
}
.projects_list::-webkit-scrollbar-thumb {
  background: #313131;
  border-radius: 25px;
}
.projects_list {
  /* Handle on hover */
}
.projects_list::-webkit-scrollbar-thumb:hover {
  background: #434343;
  cursor: all-scroll;
}

.project_card {
  display: flex;
  align-items: center;
  gap: 20px;
  background: #1a1a1a;
  padding: 16px 20px;
  transition: background 0.22s ease;
}
.project_card:hover {
  background: #07070a;
}

.project_thumb {
  flex-shrink: 0;
  width: 120px;
  height: 140px;
  border-radius: 2px;
  overflow: hidden;
}
.project_thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}

.project_info {
  flex: 1;
  min-width: 0;
}

.project_category {
  font-size: 12px;
  font-weight: 400;
  color: #C5A059;
  letter-spacing: 0.04em;
  margin-bottom: 4px;
}

.project_name {
  font-size: 17px;
  font-weight: 700;
  color: #ffffff;
  line-height: 1.2;
  margin-bottom: 4px;
}

.project_location {
  font-size: 13px;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.5);
  margin-bottom: 10px;
}

.project_btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-radius: 3px;
  padding: 13px 28px;
  cursor: pointer;
  transition: all 0.28s ease;
  text-decoration: none;
  border: 2px solid transparent;
  white-space: nowrap;
  background: #C5A059;
  color: #07070a;
  border-color: #C5A059;
}
.project_btn:hover {
  background: #a8883f;
  border-color: #a8883f;
  color: #ffffff;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(197, 160, 89, 0.35);
}
.project_btn {
  font-size: 11px;
  padding: 7px 16px;
}

.vision_sec {
  background: #07070a;
  scroll-margin-top: 30px;
}

.vision_header {
  text-align: center;
  margin-bottom: 48px;
}

.vision_powered {
  display: block;
  font-size: 13px;
  font-weight: 500;
  color: #C5A059;
  letter-spacing: 0.06em;
  margin-bottom: 10px;
}

.vision_title {
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 800;
  color: #ffffff;
  line-height: 1.15;
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}
.vision_title .ai_text {
  color: #C5A059;
}
.vision_title .sparkle_icon {
  display: inline-flex;
  align-items: center;
}
.vision_title .sparkle_icon svg {
  width: 36px;
  height: 36px;
}

.vision_desc {
  font-size: 15px;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.62);
  line-height: 1.75;
  max-width: 540px;
  margin: 0 auto;
}

.vision_layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  align-items: stretch;
}

.vision_input_panel {
  background: linear-gradient(0deg, #141414 0%, #282828 100%);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.vision_input_label {
  font-size: 15px;
  font-weight: 600;
  color: #ffffff;
}

.vision_textarea {
  width: 100%;
  flex: 1;
  min-height: 200px;
  background: #0f0f0f;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 6px;
  padding: 14px 16px;
  font-family: "Gilroy", sans-serif;
  font-size: 14px;
  color: rgba(255, 255, 255, 0.85);
  resize: vertical;
  outline: none;
  transition: border-color 0.2s ease;
  line-height: 1.6;
}
.vision_textarea::-moz-placeholder {
  color: rgba(255, 255, 255, 0.25);
}
.vision_textarea::placeholder {
  color: rgba(255, 255, 255, 0.25);
}
.vision_textarea:focus {
  border-color: rgba(197, 160, 89, 0.5);
}

.vision_generate_btn {
  width: 100%;
  padding: 14px 20px;
  background: #C5A059;
  color: #07070a;
  border: none;
  font-family: "Gilroy", sans-serif;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.25s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
.vision_generate_btn:hover:not(:disabled) {
  background: #a8883f;
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(197, 160, 89, 0.3);
}
.vision_generate_btn:disabled {
  opacity: 0.65;
  cursor: not-allowed;
  transform: none;
}

.vision_spinner {
  width: 16px;
  height: 16px;
  border: 2px solid rgba(7, 7, 10, 0.3);
  border-top-color: #07070a;
  border-radius: 50%;
  animation: visionSpin 0.7s linear infinite;
  display: none;
  flex-shrink: 0;
}

.vision_generate_btn.loading .vision_spinner {
  display: block;
}

.vision_generate_btn.loading .vision_btn_label {
  opacity: 0.7;
}

@keyframes visionSpin {
  to {
    transform: rotate(360deg);
  }
}
.vision_disclaimer {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.35);
  line-height: 1.5;
}

.vision_output_panel {
  background: #161616;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  padding: 28px;
  display: flex;
  flex-direction: column;
  min-height: 420px;
  overflow: hidden;
}

.vision_empty_state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex: 1;
  text-align: center;
  gap: 10px;
}
.vision_empty_state svg {
  width: 36px;
  height: 36px;
  color: rgba(255, 255, 255, 0.15);
  margin-bottom: 4px;
}

.vision_empty_title {
  font-size: 16px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.4);
}

.vision_empty_desc {
  font-size: 13px;
  color: rgba(255, 255, 255, 0.25);
  max-width: 280px;
  line-height: 1.6;
}

.vision_result {
  display: none;
  flex-direction: column;
  height: 100%;
}
.vision_result.visible {
  display: flex;
}

.vision_result_header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.vision_result_title {
  font-size: 14px;
  font-weight: 600;
  color: #C5A059;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.vision_copy_btn {
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.15);
  color: rgba(255, 255, 255, 0.5);
  font-family: "Gilroy", sans-serif;
  font-size: 11px;
  padding: 5px 12px;
  cursor: pointer;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  gap: 5px;
  border-radius: 3px;
}
.vision_copy_btn:hover {
  border-color: #C5A059;
  color: #C5A059;
}
.vision_copy_btn.copied {
  border-color: #4caf50;
  color: #4caf50;
}

.vision_result_content {
  flex: 1;
  overflow-y: auto;
  font-size: 14px;
  color: rgba(255, 255, 255, 0.82);
  line-height: 1.8;
  scrollbar-width: thin;
  scrollbar-color: rgba(197, 160, 89, 0.3) transparent;
}
.vision_result_content::-webkit-scrollbar {
  width: 4px;
}
.vision_result_content::-webkit-scrollbar-track {
  background: transparent;
}
.vision_result_content::-webkit-scrollbar-thumb {
  background: rgba(197, 160, 89, 0.3);
  border-radius: 2px;
}
.vision_result_content h3 {
  font-size: 14px;
  font-weight: 700;
  color: #C5A059;
  margin: 16px 0 6px;
}
.vision_result_content h3:first-child {
  margin-top: 0;
}
.vision_result_content p {
  margin-bottom: 10px;
}
.vision_result_content ul {
  padding-left: 18px;
  margin-bottom: 10px;
}
.vision_result_content ul li {
  margin-bottom: 4px;
}
.vision_result_content strong {
  color: #ffffff;
}

.vision_cursor {
  display: inline-block;
  width: 2px;
  height: 14px;
  background: #C5A059;
  margin-left: 2px;
  animation: visionBlink 0.8s step-end infinite;
  vertical-align: middle;
}

@keyframes visionBlink {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
}
.vision_error {
  display: none;
  align-items: center;
  justify-content: center;
  flex: 1;
  flex-direction: column;
  gap: 8px;
  text-align: center;
}
.vision_error.visible {
  display: flex;
}

.vision_error_msg {
  font-size: 13px;
  color: #ff6b6b;
}

footer.footer_sec {
  background: #07070a;
  padding: 0 40px 0;
}

/* =============================================
       QUOTE SECTION
       ============================================= */
.quote-section {
  scroll-margin-top: 80px;
}
.quote-section #form-response {
  color: #C5A059;
  margin: 20px 0 0;
}

/* Card shell */
.quote-card {
  position: relative;
  background: linear-gradient(0deg, #141414 0%, #282828 100%);
  border-radius: 10px;
  overflow: hidden;
  padding: 56px 52px 64px;
}
.quote-card:before {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  height: 90px;
  width: 500px;
  background: url(./assets/images/footer_shape.svg) no-repeat;
  background-size: contain;
}
.quote-card:after {
  content: "";
  position: absolute;
  right: 100px;
  height: 200px;
  width: 200px;
  top: 0;
  background: url("./assets/images/dottes.png") no-repeat;
  background-size: contain;
}
.quote-card .row {
  z-index: 10;
  position: relative;
}

/* Dot-grid decoration (top-right) */
.quote-eyebrow {
  color: #C5A059;
  margin: 0 0 10px;
}

.quote-heading {
  font-weight: 800;
  margin: 0 0 25px;
}

/* Contact list */
.contact-list {
  padding: 0;
  margin: 40px 0;
}
.contact-list li {
  margin-bottom: 15px;
  list-style: none;
}
.contact-list li a {
  display: flex;
  align-items: center;
  gap: 14px;
  color: #ffffff;
  text-decoration: none;
}
.contact-list li a:hover span:first-child {
  background: #a8883f;
  border-color: #ffffff;
}
.contact-list li span:first-child {
  height: 35px;
  width: 35px;
  background: #C5A059;
  transition: all 0.4s;
  border: 1px solid #111111;
}
.contact-list li img {
  filter: invert(1);
}

.contact-icon {
  flex-shrink: 0;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--clr-gold), #a07428);
  display: flex;
  align-items: center;
  justify-content: center;
}

.contact-icon svg {
  width: 15px;
  height: 15px;
  fill: #fff;
}

.acn-line {
  font-size: 0.72rem;
  letter-spacing: 0.04em;
}

/* Right column – form */
.quote-form-col {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.quote-form-col .btn_primary {
  width: 50%;
}

/* =============================================
    FOOTER BAR
============================================= */
.footer-bar {
  padding: 28px 80px 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
  z-index: 100;
  position: relative;
}

/* Logo badge */
.footer-copy {
  font-size: 13px;
  color: #ffffff;
  margin: 20px 0 0;
}

.logo-badge {
  text-decoration: none;
  margin: -50px 0 0;
}

.logo-badge .logo-sub {
  font-size: 0.55rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--clr-muted);
  margin-top: 3px;
}

.logo-badge img {
  max-width: 130px;
}

/* Copyright */
.footer-copy {
  letter-spacing: 0.04em;
}

.footer_rt .footer_developedby {
  font-size: 13px;
  margin: 10px 0 0;
}
.footer_rt .footer_developedby a {
  color: #ffffff;
  text-underline-position: under;
}

/* Social icons */
.social-links {
  display: flex;
  gap: 10px;
}

.social-link {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: #C5A059;
  border: 1px solid var(--clr-border);
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  transition: background var(--transition), border-color var(--transition);
}

.social-link:hover {
  background: #a8883f;
  border-color: #a8883f;
}

.social-link img {
  width: 15px;
  height: 15px;
  fill: #07070a;
  transition: fill var(--transition);
}

.social-link:hover svg {
  fill: #1a1a1a;
}

.heading_label {
  font-size: 14px;
  font-weight: 500;
  color: #C5A059;
  letter-spacing: 0.04em;
  margin-bottom: 14px;
  display: block;
}

section.inner_bnr_sec {
  background: url(./assets/images/project_banner.png) no-repeat;
  background-size: cover;
  padding: 100px 0 50px;
  text-align: center;
}

.project_detail_sec {
  background: #07070a;
  padding: 0 0 50px;
}

.project_detail_wrap {
  display: flex;
  align-items: stretch;
  gap: 40px;
}

.project_detail_content {
  flex: 0 0 50%;
  max-width: 50%;
  padding: 70px 0 0;
}

.project_info_title {
  font-size: 28px;
  font-weight: 700;
  margin-bottom: 28px;
  color: #C5A059;
}

.project_info_grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px 40px;
  margin-bottom: 40px;
}

.info_item {
  display: flex;
  flex-direction: column;
}
.info_item .label {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.5);
  margin-bottom: 4px;
}
.info_item .value {
  font-size: 16px;
  font-weight: 600;
  color: #ffffff;
}

.project_desc {
  font-size: 15px;
  color: rgba(255, 255, 255, 0.7);
  line-height: 1.8;
}
.project_desc p {
  margin-bottom: 14px;
  color: #ffffff;
}

.project_detail_image {
  flex: 0 0 45%;
  max-width: 45%;
  position: relative;
}
.project_detail_image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}

.projects_sec_gallery {
  background: #07070a;
  position: relative;
  padding: 40px 0 20px;
  scroll-margin-top: 60px;
}
.projects_sec_gallery:before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  height: 150%;
  width: calc(100% - 60px);
  margin: auto;
  background: linear-gradient(180deg, #272727 0%, #07070A 100%);
  border-radius: 100px 100px 0 0;
}

.projects_grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-top: 30px;
}

.project_grid_item {
  position: relative;
  display: block;
  border-radius: 14px;
  overflow: hidden;
  background: #1a1a1a;
  cursor: pointer;
  transition: all 0.35s ease;
}
.project_grid_item img {
  width: 100%;
  height: 230px;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  transition: transform 0.6s ease;
}
.project_grid_item::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 40%, rgba(0, 0, 0, 0.75) 100%);
  opacity: 0;
  transition: 0.35s;
}
.project_grid_item::after {
  content: "+";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0.6);
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: #C5A059;
  color: #07070a;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  opacity: 0;
  transition: 0.3s;
}
.project_grid_item:hover {
  transform: translateY(-6px);
}
.project_grid_item:hover img {
  transform: scale(1.08);
}
.project_grid_item:hover::before {
  opacity: 1;
}
.project_grid_item:hover::after {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.fancybox__container {
  --fancybox-bg: rgba(7, 7, 10, 0.96);
}

.cta_sec {
  background: #07070a;
  padding: 60px 0;
}

.cta_box {
  background: #07070a;
  border-radius: 100px;
  padding: 25px 70px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  position: relative;
}
.cta_box:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  height: 1px;
  background: #C5A059;
  width: 80%;
}
.cta_box:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  height: 1px;
  background: #C5A059;
  width: 80%;
}

.cta_content h2 {
  font-size: clamp(26px, 3vw, 38px);
  font-weight: 700;
  line-height: 1.2;
  color: #ffffff;
}
.cta_content h2 span {
  color: #C5A059;
  display: block;
  margin-top: 6px;
}

.cta_actions {
  display: flex;
  align-items: center;
  gap: 14px;
}

.cta_phone {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 20px;
  background: #ffffff;
  color: #07070a;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  border-radius: 4px;
  transition: all 0.3s ease;
}
.cta_phone .icon {
  font-size: 14px;
}
.cta_phone:hover {
  background: #C5A059;
  color: #07070a;
}

.related_sec {
  background: #07070a;
  padding: 10px 0 60px;
  text-align: center;
}

.related_title {
  margin-bottom: 40px;
  z-index: 100;
  position: relative;
}

.related_slider {
  position: relative;
}

.related_card {
  display: flex;
  align-items: center;
  gap: 20px;
  background: linear-gradient(90deg, #1a1a1a 0%, #2a2a2a 100%);
  padding: 18px;
  border-radius: 6px;
  text-align: left;
  transition: all 0.3s ease;
}

.related_img {
  width: 130px;
  height: 150px;
  flex-shrink: 0;
  overflow: hidden;
}
.related_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.related_content .category {
  font-size: 14px;
  color: #C5A059;
  display: block;
  margin-bottom: 4px;
}
.related_content h3 {
  font-size: 22px;
  font-weight: 700;
  margin: 10px 0;
}
.related_content p {
  font-size: 13px;
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 10px;
}
.related_content .btn_primary {
  font-size: 12px;
  padding: 6px 14px;
}

.related_nav {
  margin-top: 60px;
  display: flex;
  justify-content: center;
  gap: 20px;
}
.related_nav .swiper-button-prev,
.related_nav .swiper-button-next {
  position: static;
  width: 40px;
  height: 40px;
  border: 1px solid #C5A059;
  color: #C5A059;
  border-radius: 50%;
}
.related_nav .swiper-button-prev::after,
.related_nav .swiper-button-next::after {
  font-size: 14px;
}

.swiper-button-next:after, .swiper-button-prev:after {
  display: none;
}

.related_nav .swiper-button-prev, .related_nav .swiper-button-next {
  border: none;
}
.related_nav .swiper-button-prev:hover svg path, .related_nav .swiper-button-next:hover svg path {
  stroke: #C5A059;
}

@media (min-width: 992px) {
  .navbar-toggler {
    display: none !important;
  }
  .navbar-collapse {
    display: flex !important;
    align-items: center;
    flex: 1;
  }
}
@media (max-width: 1399.98px) {
  .project_thumb {
    width: 90px;
    height: 110px;
  }
  .projects_list {
    min-height: 600px;
  }
}
@media (max-width: 991px) {
  .navbar-toggler {
    display: flex !important;
  }
  .navbar-collapse {
    display: none !important;
  }
  .about_sec .container {
    flex-direction: column;
    gap: 40px;
  }
  .about_content {
    flex: 0 0 100%;
    max-width: 100%;
  }
  .about_image_wrap {
    flex: 0 0 100%;
    max-width: 480px;
    margin: 0 auto;
  }
  .reach_card {
    flex-direction: column;
    gap: 36px;
    border-radius: 32px;
    padding: 36px 32px;
  }
  .reach_left,
  .reach_right {
    flex: 0 0 100%;
    max-width: 100%;
  }
  .reach_map {
    padding: 0;
  }
  .hex_item .hex_inner {
    width: 170px;
    height: 196px;
  }
  .hex_item {
    width: 170px;
  }
  .hex_row:nth-child(even) {
    margin-top: -18px;
    margin-bottom: -18px;
  }
  .hex_desc {
    font-size: 15px;
  }
  .hex_icon {
    width: 28px;
    height: 28px;
    margin-bottom: 8px;
  }
  .projects_layout {
    flex-direction: column;
    gap: 32px;
  }
  .projects_image_wrap {
    flex: 0 0 100%;
    max-width: 360px;
    margin: 0 auto;
  }
  .vision_layout {
    grid-template-columns: 1fr;
  }
  .project_detail_wrap {
    flex-direction: column;
  }
  .project_detail_content,
  .project_detail_image {
    flex: 0 0 100%;
    max-width: 100%;
  }
  .project_detail_image img {
    height: auto;
  }
  .projects_grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .project_grid_item img {
    height: 200px;
  }
  .projects_image_wrap {
    display: none;
  }
  .projects_list {
    max-height: initial;
    min-height: auto;
    width: 100%;
  }
}
@media (max-width: 767px) {
  .section_pad {
    padding: 30px 0;
  }
  .banner_title {
    font-size: 38px;
  }
  .banner_desc br {
    display: none;
  }
  .banner_actions {
    flex-direction: column;
    align-items: stretch;
  }
  .btn_primary,
  .btn_secondary {
    justify-content: center;
  }
  .about_content {
    padding: 30px 0 0;
  }
  .about_actions {
    flex-direction: column;
    align-items: stretch;
  }
  .about_actions .btn_primary,
  .about_actions .btn_secondary {
    justify-content: center;
  }
  .reach_card {
    padding: 30px 0 30px;
    border-radius: 24px;
  }
  .reach_regions {
    grid-template-columns: 1fr 1fr;
  }
  .hex_grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
  }
  .hex_row {
    display: contents;
  }
  .hex_row:nth-child(even) {
    margin: 0;
  }
  .hex_item {
    width: 100%;
  }
  .hex_item .hex_inner {
    width: 100%;
    height: auto;
    clip-path: none;
    border-radius: 8px;
    padding: 24px 20px;
    background: #1a1a1a;
  }
  .hex_item .hex_inner::before {
    display: none;
  }
  .hex_item.hex_center {
    display: none;
  }
  .project_card {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    padding: 0;
    background: transparent;
  }
  .project_card:hover {
    background: transparent;
  }
  .project_thumb {
    width: 100%;
    height: 160px;
  }
  .vision_output_panel {
    min-height: 300px;
  }
  footer.footer_sec {
    padding: 0;
  }
  .quote-card:before {
    display: none;
  }
  .quote-card {
    padding: 25px 20px 25px;
  }
  .logo-badge {
    margin: 0;
  }
  .footer-bar {
    padding: 25px 15px 25px;
  }
  .vision_title {
    font-size: 26px;
  }
  .cta_box {
    flex-direction: column;
    text-align: center;
    border-radius: 30px;
    padding: 30px 20px;
  }
  .cta_actions {
    flex-direction: column;
    width: 100%;
  }
  .cta_actions .btn_primary,
  .cta_actions .btn_secondary {
    width: 100%;
    justify-content: center;
  }
  .related_content h3 {
    font-size: 18px;
  }
  .projects_sec_gallery:before {
    display: none;
  }
  .projects_sec_gallery {
    padding: 0;
  }
  .project_detail_content {
    padding: 40px 0 0;
  }
  .project_detail_wrap {
    gap: 20px;
  }
  .project_detail_sec {
    padding: 0 0 30px;
  }
  .cta_sec {
    padding: 50px 0 40px;
  }
  .related_sec {
    padding: 10px 0 40px;
  }
  section.inner_bnr_sec {
    padding: 90px 0 30px;
  }
}
@media (max-width: 575px) {
  .about_stats {
    flex-wrap: wrap;
    gap: 24px;
    justify-content: center;
  }
  .stat_item {
    flex: 0 0 calc(50% - 12px);
    padding: 0 !important;
  }
  .stat_item::after {
    display: none !important;
  }
  .hex_grid {
    grid-template-columns: 1fr;
  }
  .projects_filters {
    gap: 8px;
  }
  .filter_btn {
    padding: 7px 16px;
    font-size: 12px;
  }
  .projects_sec:before {
    border-radius: 50px 50px 0 0;
    width: calc(100% - 30px);
  }
  .projects_sec .container {
    padding: 0 40px;
  }
  .projects_list {
    gap: 30px;
    width: 100%;
  }
  .project_info_grid {
    grid-template-columns: 1fr;
  }
  .project_grid_item img {
    height: 190px;
  }
}/*# sourceMappingURL=style.css.map */