/* Base */
html {
  overflow-x: hidden; }

body {
  line-height: 1.7;
  color: #666666;
  font-weight: 400;
  font-size: 1rem; }

::-moz-selection {
  background: #000;
  color: #fff; }

::selection {
  background: #000;
  color: #fff; }

a {
  -webkit-transition: .3s all ease;
  -o-transition: .3s all ease;
  transition: .3s all ease; }
  a:hover {
    text-decoration: none; }

h1, h2, h3, h4, h5,
.h1, .h2, .h3, .h4, .h5 {
  font-family: "Stack Sans Headline", sans-serif;
  color: #000; }

.border-2 {
  border-width: 2px; }

.text-black {
  color: #000 !important; }

.bg-black {
  background: #000 !important; }

.color-black-opacity-5 {
  color: rgba(0, 0, 0, 0.5); }

.color-white-opacity-5 {
  color: rgba(255, 255, 255, 0.5); }

body:after {
  -webkit-transition: .3s all ease-in-out;
  -o-transition: .3s all ease-in-out;
  transition: .3s all ease-in-out; }

.offcanvas-menu {
  position: relative; }
  .offcanvas-menu:after {
    position: absolute;
    content: "";
    bottom: 0;
    left: 0;
    top: 0;
    right: 0;
    z-index: 999;
    background: rgba(0, 0, 0, 0.2); }

.btn {
  font-size: 16px;
  border-radius: 30px;
  padding: 10px 30px; }
  .btn:hover, .btn:active, .btn:focus {
    outline: none;
    -webkit-box-shadow: none !important;
    box-shadow: none !important; }
  .btn.btn-primary {
    background: #207561;
    border-color: #207561;
    color: #fff; }
    .btn.btn-primary:hover {
      background: #000;
      border-color: #000;
      color: #fff; }
    .btn.btn-primary.btn-black--hover:hover {
      background: #666666;
      color: #fff; }

.line-height-1 {
  line-height: 1 !important; }

.bg-black {
  background: #000; }

.form-control {
  height: 43px;
  border-radius: 30px;
  font-family: "Stack Sans Headline", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; }
  .form-control:active, .form-control:focus {
    border-color: #207561; }
  .form-control:hover, .form-control:active, .form-control:focus {
    -webkit-box-shadow: none !important;
    box-shadow: none !important; }

.site-section {
  padding: 2.5em 0; }
  @media (min-width: 768px) {
    .site-section {
      padding: 7em 0; } }
  .site-section.site-section-sm {
    padding: 4em 0; }

.site-section-heading {
  padding-bottom: 20px;
  margin-bottom: 0px;
  position: relative;
  font-size: 2.5rem; }
  @media (min-width: 768px) {
    .site-section-heading {
      font-size: 3rem; } }

.site-footer {
  padding: 4em 0;
  background: #333333; }
  @media (min-width: 768px) {
    .site-footer {
      padding: 8em 0; } }
  .site-footer .border-top {
    border-top: 1px solid rgba(255, 255, 255, 0.1) !important; }
  .site-footer p {
    color: #737373; }
  .site-footer h2, .site-footer h3, .site-footer h4, .site-footer h5 {
    color: #fff; }
  .site-footer a {
    color: #999999; }
    .site-footer a:hover {
      color: white; }
  .site-footer ul li {
    margin-bottom: 10px; }
  .site-footer .footer-heading {
    font-size: 16px;
    color: #fff; }

.bg-text-line {
  display: inline;
  background: #000;
  -webkit-box-shadow: 20px 0 0 #000, -20px 0 0 #000;
  box-shadow: 20px 0 0 #000, -20px 0 0 #000; }

.text-white-opacity-05 {
  color: rgba(255, 255, 255, 0.5); }

.text-black-opacity-05 {
  color: rgba(0, 0, 0, 0.5); }

.hover-bg-enlarge {
  overflow: hidden;
  position: relative; }
  @media (max-width: 991.98px) {
    .hover-bg-enlarge {
      height: auto !important; } }
  .hover-bg-enlarge > div {
    -webkit-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
    -webkit-transition: .8s all ease-in-out;
    -o-transition: .8s all ease-in-out;
    transition: .8s all ease-in-out; }
  .hover-bg-enlarge:hover > div, .hover-bg-enlarge:focus > div, .hover-bg-enlarge:active > div {
    -webkit-transform: scale(1.2);
    -ms-transform: scale(1.2);
    transform: scale(1.2); }
  @media (max-width: 991.98px) {
    .hover-bg-enlarge .bg-image-md-height {
      height: 300px !important; } }

.bg-image {
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  background-attachment: fixed; }
  .bg-image.overlay {
    position: relative; }
    .bg-image.overlay:after {
      position: absolute;
      content: "";
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      z-index: 0;
      width: 100%;
      background: rgba(0, 0, 0, 0.7); }
  .bg-image > .container {
    position: relative;
    z-index: 1; }

@media (max-width: 991.98px) {
  .img-md-fluid {
    max-width: 100%; } }

@media (max-width: 991.98px) {
  .display-1, .display-3 {
    font-size: 3rem; } }

.play-single-big {
  width: 90px;
  height: 90px;
  display: inline-block;
  border: 2px solid #fff;
  color: #fff !important;
  border-radius: 50%;
  position: relative;
  -webkit-transition: .3s all ease-in-out;
  -o-transition: .3s all ease-in-out;
  transition: .3s all ease-in-out; }
  .play-single-big > span {
    font-size: 50px;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-40%, -50%);
    -ms-transform: translate(-40%, -50%);
    transform: translate(-40%, -50%); }
  .play-single-big:hover {
    width: 120px;
    height: 120px; }

.overlap-to-top {
  margin-top: -150px; }

.ul-check {
  margin-bottom: 50px; }
  .ul-check li {
    position: relative;
    padding-left: 35px;
    margin-bottom: 15px;
    line-height: 1.5; }
    .ul-check li:before {
      left: 0;
      font-size: 20px;
      top: -.3rem;
      font-family: "icomoon";
      content: "\e5ca";
      position: absolute; }
  .ul-check.white li:before {
    color: #fff; }
  .ul-check.success li:before {
    color: #71bc42; }
  .ul-check.primary li:before {
    color: #207561; }
  .ul-check li.remove {
    text-decoration: line-through;
    color: #dee2e6; }
    .ul-check li.remove:before {
      color: #dee2e6; }

.select-wrap, .wrap-icon {
  position: relative; }
  .select-wrap .icon, .wrap-icon .icon {
    position: absolute;
    right: 10px;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    font-size: 22px; }
  .select-wrap select, .wrap-icon select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 100%; }

/* Navbar */
.site-navbar {
  margin-bottom: 0px;
  z-index: 1999;
  position: absolute;
  top: 0;
  width: 100%;
  border-bottom: rgba(255, 255, 255, 0.7); }
  .site-navbar,
  .site-navbar:hover {
   background: transparent; /* stay transparent at the top */
  }
  .site-navbar .site-logo {
    font-size: 1.5rem; }
    .site-navbar .site-logo a {
      display: inline-block;
      padding: 5px 10px;
      color: #207561 !important; }
  .site-navbar .site-navigation .site-menu {
    margin: 0;
    padding: 0;
    margin-bottom: 0;
    font-family: "Stack Sans Headline", sans-serif; }
  .site-navbar .site-navigation {
    padding-right: 40px;  /* pushes menu a bit away from right edge */
  }

  .site-navbar .site-navigation .site-menu {
  margin-left: auto; /* pushes menu fully to the right */
  margin-right: 0;
  }

    .site-navbar .site-navigation .site-menu a {
      text-decoration: none !important;
      display: inline-block;
      position: relative;
      padding: 5px 20px; }
    .site-navbar .site-navigation .site-menu > li {
      display: inline-block; }
      /*home, serviece ,about  distance*/
      .site-navbar .site-navigation .site-menu > li > a {
        padding: 5px 10px;
        color: #000;
        display: inline-block;
        text-decoration: none !important; }
        .site-navbar .site-navigation .site-menu > li > a:hover {
          color: #207561; }
    .site-navbar .site-navigation .site-menu .has-children {
      position: relative; }
      .site-navbar .site-navigation .site-menu .has-children > a {
        position: relative;
        padding-right: 20px; }
        .site-navbar .site-navigation .site-menu .has-children > a:before {
          position: absolute;
          content: "\e313";
          font-size: 16px;
          top: 50%;
          right: 0;
          -webkit-transform: translateY(-50%);
          -ms-transform: translateY(-50%);
          transform: translateY(-50%);
          font-family: 'icomoon'; }
      .site-navbar .site-navigation .site-menu .has-children .dropdown {
        visibility: hidden;
        opacity: 0;
        top: 100%;
        position: absolute;
        text-align: left;
        border-top: 2px solid #207561;
        -webkit-box-shadow: 0 2px 10px -2px rgba(0, 0, 0, 0.1);
        box-shadow: 0 2px 10px -2px rgba(0, 0, 0, 0.1);
        padding: 0px 0;
        margin-top: 20px;
        margin-left: 0px;
        background: #fff;
        -webkit-transition: 0.2s 0s;
        -o-transition: 0.2s 0s;
        transition: 0.2s 0s; }
        .site-navbar .site-navigation .site-menu .has-children .dropdown.arrow-top {
          position: absolute; }
          .site-navbar .site-navigation .site-menu .has-children .dropdown.arrow-top:before {
            bottom: 100%;
            left: 20%;
            border: solid transparent;
            content: " ";
            height: 0;
            width: 0;
            position: absolute;
            pointer-events: none; }
          .site-navbar .site-navigation .site-menu .has-children .dropdown.arrow-top:before {
            border-color: rgba(136, 183, 213, 0);
            border-bottom-color: #fff;
            border-width: 10px;
            margin-left: -10px; }
        .site-navbar .site-navigation .site-menu .has-children .dropdown a {
          text-transform: none;
          letter-spacing: normal;
          -webkit-transition: 0s all;
          -o-transition: 0s all;
          transition: 0s all;
          color: #000; }
        .site-navbar .site-navigation .site-menu .has-children .dropdown .active {
          color: #207561 !important; }
        .site-navbar .site-navigation .site-menu .has-children .dropdown > li {
          list-style: none;
          padding: 0;
          margin: 0;
          min-width: 210px; }
          .site-navbar .site-navigation .site-menu .has-children .dropdown > li > a {
            padding: 9px 20px;
            display: block; }
            .site-navbar .site-navigation .site-menu .has-children .dropdown > li > a:hover {
              background: #eff1f3;
              color: #000; }
          .site-navbar .site-navigation .site-menu .has-children .dropdown > li.has-children > a:before {
            content: "\e315";
            right: 20px; }
          .site-navbar .site-navigation .site-menu .has-children .dropdown > li.has-children > .dropdown, .site-navbar .site-navigation .site-menu .has-children .dropdown > li.has-children > ul {
            left: 100%;
            top: 0; }
      .site-navbar .site-navigation .site-menu .has-children:hover > a, .site-navbar .site-navigation .site-menu .has-children:focus > a, .site-navbar .site-navigation .site-menu .has-children:active > a {
        color: #207561; }
      .site-navbar .site-navigation .site-menu .has-children:hover, .site-navbar .site-navigation .site-menu .has-children:focus, .site-navbar .site-navigation .site-menu .has-children:active {
        cursor: pointer; }
        .site-navbar .site-navigation .site-menu .has-children:hover > .dropdown, .site-navbar .site-navigation .site-menu .has-children:focus > .dropdown, .site-navbar .site-navigation .site-menu .has-children:active > .dropdown {
          -webkit-transition-delay: 0s;
          -o-transition-delay: 0s;
          transition-delay: 0s;
          margin-top: 0px;
          visibility: visible;
          opacity: 1; }
         /* Navbar link font customization */
      .site-navbar .site-navigation .site-menu > li > a {
        font-family: 'Stack Sans Headline', sans-serif;  /* modern clean font */
        font-weight: 500;                                /* medium thickness */
        font-size: 1rem;                                 /* adjust size if needed */
        letter-spacing: 0.5px;                           /* subtle spacing */
        text-transform: none;                            /* keep normal case */
        color: #000;                                     /* default color */
        transition: color 0.3s ease, transform 0.3s ease;
      }     

.site-navbar .site-navigation .site-menu > li > a:hover {
  color: #5cb7b9;                                  /* highlight color */
  transform: translateY(-2px);                     /* slight lift effect */
}
 

.site-mobile-menu {
  width: 300px;
  position: fixed;
  right: 0;
  z-index: 2000;
  padding-top: 20px;
  background: #fff;
  height: calc(100vh);
  -webkit-transform: translateX(110%);
  -ms-transform: translateX(110%);
  transform: translateX(110%);
  -webkit-box-shadow: -10px 0 20px -10px rgba(0, 0, 0, 0.1);
  box-shadow: -10px 0 20px -10px rgba(0, 0, 0, 0.1);
  -webkit-transition: .3s all ease-in-out;
  -o-transition: .3s all ease-in-out;
  transition: .3s all ease-in-out; }
  .offcanvas-menu .site-mobile-menu {
    -webkit-transform: translateX(0%);
    -ms-transform: translateX(0%);
    transform: translateX(0%); }
  .site-mobile-menu .site-mobile-menu-header {
    width: 100%;
    float: left;
    padding-left: 20px;
    padding-right: 20px; }
    .site-mobile-menu .site-mobile-menu-header .site-mobile-menu-close {
      float: right;
      margin-top: 8px; }
      .site-mobile-menu .site-mobile-menu-header .site-mobile-menu-close span {
        font-size: 30px;
        display: inline-block;
        padding-left: 10px;
        padding-right: 0px;
        line-height: 1;
        cursor: pointer;
        -webkit-transition: .3s all ease;
        -o-transition: .3s all ease;
        transition: .3s all ease; }
    .site-mobile-menu .site-mobile-menu-header .site-mobile-menu-logo {
      float: left;
      margin-top: 10px;
      margin-left: 0px; }
      .site-mobile-menu .site-mobile-menu-header .site-mobile-menu-logo a {
        display: inline-block;
        text-transform: uppercase; }
        .site-mobile-menu .site-mobile-menu-header .site-mobile-menu-logo a img {
          max-width: 70px; }
        .site-mobile-menu .site-mobile-menu-header .site-mobile-menu-logo a:hover {
          text-decoration: none; }
  .site-mobile-menu .site-mobile-menu-body {
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;
    position: relative;
    padding: 0 20px 20px 20px;
    height: calc(100vh - 52px);
    padding-bottom: 150px; }
  .site-mobile-menu .site-nav-wrap {
    padding: 0;
    margin: 0;
    list-style: none;
    position: relative; }
    .site-mobile-menu .site-nav-wrap a {
      padding: 10px 20px;
      display: block;
      position: relative;
      color: #212529; }
      .site-mobile-menu .site-nav-wrap a:hover {
        color: #207561; }
    .site-mobile-menu .site-nav-wrap li {
      position: relative;
      display: block; }
      .site-mobile-menu .site-nav-wrap li .active {
        color: #207561; }
    .site-mobile-menu .site-nav-wrap .arrow-collapse {
      position: absolute;
      right: 0px;
      top: 10px;
      z-index: 20;
      width: 36px;
      height: 36px;
      text-align: center;
      cursor: pointer;
      border-radius: 50%; }
      .site-mobile-menu .site-nav-wrap .arrow-collapse:hover {
        background: #f8f9fa; }
      .site-mobile-menu .site-nav-wrap .arrow-collapse:before {
        font-size: 12px;
        z-index: 20;
        font-family: "icomoon";
        content: "\f078";
        position: absolute;
        top: 50%;
        left: 50%;
        -webkit-transform: translate(-50%, -50%) rotate(-180deg);
        -ms-transform: translate(-50%, -50%) rotate(-180deg);
        transform: translate(-50%, -50%) rotate(-180deg);
        -webkit-transition: .3s all ease;
        -o-transition: .3s all ease;
        transition: .3s all ease; }
      .site-mobile-menu .site-nav-wrap .arrow-collapse.collapsed:before {
        -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%); }
    .site-mobile-menu .site-nav-wrap > li {
      display: block;
      position: relative;
      float: left;
      width: 100%; }
      .site-mobile-menu .site-nav-wrap > li > a {
        padding-left: 20px;
        font-size: 20px; }
      .site-mobile-menu .site-nav-wrap > li > ul {
        padding: 0;
        margin: 0;
        list-style: none; }
        .site-mobile-menu .site-nav-wrap > li > ul > li {
          display: block; }
          .site-mobile-menu .site-nav-wrap > li > ul > li > a {
            padding-left: 40px;
            font-size: 16px; }
          .site-mobile-menu .site-nav-wrap > li > ul > li > ul {
            padding: 0;
            margin: 0; }
            .site-mobile-menu .site-nav-wrap > li > ul > li > ul > li {
              display: block; }
              .site-mobile-menu .site-nav-wrap > li > ul > li > ul > li > a {
                font-size: 16px;
                padding-left: 60px; }
    .site-mobile-menu .site-nav-wrap[data-class="social"] {
      float: left;
      width: 100%;
      margin-top: 30px;
      padding-bottom: 5em; }
      .site-mobile-menu .site-nav-wrap[data-class="social"] > li {
        width: auto; }
        .site-mobile-menu .site-nav-wrap[data-class="social"] > li:first-child a {
          padding-left: 15px !important; }

.sticky-wrapper {
  position: absolute;
  z-index: 100;
  width: 100%; }
  .sticky-wrapper .site-navbar {
    -webkit-transition: .3s all ease;
    -o-transition: .3s all ease;
    transition: .3s all ease; }
  .sticky-wrapper .site-navbar .site-menu-toggle {
    color: #000; }
  .sticky-wrapper .site-navbar .site-logo a {
    color: #000; }
  .sticky-wrapper .site-navbar .site-menu > li > a {
    color: rgba(0, 0, 0, 0.7) !important; }
    .sticky-wrapper .site-navbar .site-menu > li > a:hover, .sticky-wrapper .site-navbar .site-menu > li > a.active {
      color: #207561 !important; }
  .sticky-wrapper.is-sticky .site-navbar {
    background: rgba(255, 255, 255, 0.28);        /* slightly denser frost */
    -webkit-backdrop-filter: saturate(160%) blur(14px);
    backdrop-filter: saturate(100%) blur(18px);    /* smooth blur */
    border-bottom: 1px solid rgba(255, 255, 255, 0.25);
    /*box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);    /* subtle matte shadow */
    transition: background 0.25s ease, backdrop-filter 0.25s ease;      
  }
    .sticky-wrapper.is-sticky .site-navbar .site-menu-toggle {
      color: #000; }
    .sticky-wrapper.is-sticky .site-navbar .site-logo a {
      color: #000; }
    .sticky-wrapper.is-sticky .site-navbar .site-menu > li > a {
      color: #000 !important; }
      .sticky-wrapper.is-sticky .site-navbar .site-menu > li > a:hover, .sticky-wrapper.is-sticky .site-navbar .site-menu > li > a.active {
        color: #5cb7b9 !important; }
  .sticky-wrapper .shrink {
    padding-top: 10px !important;
    padding-bottom: 10px !important; }

/* Blocks */
.site-blocks-cover {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: top;
  background-position: center center;
  overflow: hidden;
  position: relative; }
  .site-blocks-cover .lead {
    font-family: "Stack Sans Headline", sans-serif;;
    font-size: 1.3rem;
    color: #1a1a1a; }
  .site-blocks-cover.overlay {
    position: relative; }
    .site-blocks-cover.overlay:before {
      position: absolute;
      content: "";
      left: 0;
      bottom: 0;
      right: 0;
      top: 0;
      z-index: 2;
      background: rgba(255, 255, 255, 0); }
      @media (max-width: 991.98px) {
        .site-blocks-cover.overlay:before {
          background: rgba(255, 255, 255, 0.5); } }
  .site-blocks-cover, .site-blocks-cover > .container, .site-blocks-cover > .container > .row {
    min-height: 600px;
    height: 100vh; }
  .site-blocks-cover .text-intro {
    position: relative;
    z-index: 2; }
  .site-blocks-cover h1 {
    font-size: 3rem;
    font-family: "Stack Sans Headline", sans-serif; }


.section-title {
  position: relative;
  padding-bottom: 20px; }
  /* .section-title:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    height: 2px;
    background: #207561;
    width: 50px; } */
  .section-title.text-center:after {
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%); }
  .section-title.text-center:after {
    background: #fff; }

  /* Remove decorative line under "About Design By AK" */
  #about-section .section-title::after,
  #about-section .section-title.text-center::after {
  content: none !important;
  background: none !important;
  height: 0 !important;
}
  

.position-relative {
  position: relative; }

.service {
  padding: 30px;
  background: #fff;
  -webkit-box-shadow: 0 1px 2px 0px rgba(0, 0, 0, 0.1);
  box-shadow: 0 1px 2px 0px rgba(0, 0, 0, 0.1);
  -webkit-transition: .3s all ease-in-out;
  -o-transition: .3s all ease-in-out;
  transition: .3s all ease-in-out;
  top: 0;
  position: relative; }
  .service:hover {
    -webkit-box-shadow: 0 8px 50px -5px rgba(0, 0, 0, 0.1);
    box-shadow: 0 8px 50px -5px rgba(0, 0, 0, 0.1);
    top: -2px; }
  .service .service-number {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 60px;
    flex: 0 0 60px; }
    .service .service-number span {
      position: relative;
      width: 50px;
      height: 50px;
      line-height: 50px;
      border-radius: 50%;
      background: #207561;
      display: inline-block;
      color: #fff;
      text-align: center; }
  .service .service-about *:last-child {
    margin-bottom: 0; }
  .service .service-about h3 {
    font-size: 1.2rem;
    margin-bottom: 10px; }

.gal-item {
  margin-bottom: 30px; }

.filters .btn {
  border-color: transparent;
  font-size: .8rem;
  margin: 5px;
  letter-spacing: .2rem;
  background: rgba(52, 58, 64, 0.05);
  color: #343a40;
  padding: 5px 20px;
  border-radius: 30px !important;
  border: none !important;
  text-transform: uppercase; }
  .filters .btn:hover, .filters .btn:focus, .filters .btn:active {
    border-color: transparent !important;
    background: rgba(52, 58, 64, 0.3) !important;
    color: #000; }
  .filters .btn.active {
    background: #000 !important;
    color: #fff;
    border-color: #000 !important; }

/* Isotope Transitions
------------------------------- */
.isotope,
.isotope .item {
  -webkit-transition-duration: 0.8s;
  -moz-transition-duration: 0.8s;
  -ms-transition-duration: 0.8s;
  -o-transition-duration: 0.8s;
  transition-duration: 0.8s; }

.isotope {
  -webkit-transition-property: height, width;
  -moz-transition-property: height, width;
  -ms-transition-property: height, width;
  -o-transition-property: height, width;
  transition-property: height, width; }

.isotope .item {
  -webkit-transition-property: -webkit-transform, opacity;
  -moz-transition-property: -moz-transform, opacity;
  -ms-transition-property: -ms-transform, opacity;
  -o-transition-property: top, left, opacity;
  -webkit-transition-property: opacity, -webkit-transform;
  transition-property: opacity, -webkit-transform;
  -o-transition-property: transform, opacity;
  transition-property: transform, opacity;
  transition-property: transform, opacity, -webkit-transform; }

/* responsive media queries */
/* --- Portfolio Item (Equal Height + Smaller Font) --- */
.item {
  border: none;
  margin-bottom: 30px;
  border-radius: 10px;
  display: flex;
  flex-direction: column;
  height: 100%;
}

/* Image */
.item a {
  display: block;
  overflow: hidden;
  position: relative;
  border-radius: 10px 10px 0 0;
  flex-shrink: 0;
}
.item a img {
  width: 100%;
  height: 220px; /* adjust if you want taller/shorter cards */
  object-fit: cover;
  transition: 0.3s all ease-in-out;
}

/* Content area inside the box */
.item .item-wrap {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  background: #fff;
  border-radius: 0 0 10px 10px;
  padding: 16px 18px 18px;
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.06);
}

/* Title */
.item .item-wrap h3,
.item .item-wrap .item-title {
  font-size: 1rem; /* smaller title */
  line-height: 1.3;
  font-weight: 600;
  color: #111;
  margin-bottom: 10px;
}

/* Description */
.item .item-wrap p {
  font-size: 0.88rem; /* smaller body text */
  line-height: 1.5;
  color: #555;
  margin-bottom: 15px;
  flex-grow: 1;
}

/* Tag Chips */
.item .item-wrap .tag,
.item .item-wrap .tags a,
.item .item-wrap .tags span {
  display: inline-block;
  font-size: 0.75rem; /* smaller tags */
  background: #f5f5f5;
  color: #333;
  border-radius: 16px;
  padding: 5px 10px;
  margin-right: 6px;
  margin-bottom: 6px;
  text-transform: none;
}

/* Hover zoom effect */
.item:hover a img {
  transform: scale(1.05);
  transition: 0.3s all ease-in-out;
}


.slide-one-item .slide {
  text-align: center; }
  .slide-one-item .slide blockquote {
    position: relative;
    max-width: 700px;
    font-size: 1.2rem;
    color: #000;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
    font-style: italic;
    color: #fff; }
  .slide-one-item .slide cite {
    margin-top: 50px;
    font-size: 1rem;
    color: rgba(255, 255, 255, 0.5); }

.slide-one-item .owl-dots {
  text-align: center; }
  .slide-one-item .owl-dots .owl-dot {
    display: inline-block; }
    .slide-one-item .owl-dots .owl-dot > span {
      margin: 7px;
      background: rgba(255, 255, 255, 0.3);
      display: inline-block;
      width: 7px;
      height: 7px;
      border-radius: 50%; }
    .slide-one-item .owl-dots .owl-dot:hover > span {
      background: rgba(255, 255, 255, 0.5); }
    .slide-one-item .owl-dots .owl-dot.active > span {
      background: #fff; }

.blog_entry img {
  border-top-left-radius: 4px;
  border-top-right-radius: 4px; }

.blog_entry > div {
  border: 1px solid #eee;
  border-top: none; }

.blog_entry h3 {
  font-size: 1.3rem; }
  .blog_entry h3 a {
    color: #000; }

.blog_entry .date {
  color: #999999;
  display: block;
  font-size: .9rem;
  margin-bottom: 15px; }

.blog_entry .more a {
  position: relative;
  color: #000;
  padding-bottom: 10px; }
  .blog_entry .more a:before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: #000;
    -webkit-transition: .3s all ease;
    -o-transition: .3s all ease;
    transition: .3s all ease; }
  .blog_entry .more a:hover:before {
    background: #207561; }

.form .form-control {
  border: none;
  border-radius: 0px;
  border-bottom: 1px solid #eee; }
  .form .form-control:active, .form .form-control:focus {
    border-color: #000; }

.footer {
  font-size: .9rem; }
  .footer .footer-title {
    font-size: 1.1rem;
    margin-bottom: 30px; }
  .footer ul li {
    margin-bottom: 10px; }
  .footer a {
    color: #888888; }
    .footer a:hover {
      color: #000; }
.site-logo img {
  height: 30px;
  width: auto;
}
/* Hero text refinement */
.text-intro h1:first-child {
   font-family: 'Stack Sans Headline', sans-serif;
  font-weight: 400;
  font-size: 2.5rem;
  margin-bottom: 0.3em;
  color: #555;           /* subtle grey for contrast */
}

.text-intro h1:nth-child(2) {
  font-family: 'Stack Sans Headline', sans-serif;
  font-weight: 700;
  font-size: 3.5rem;
  color: #207561;  /* or your chosen highlight color */          /* highlight color (or use #5cb7b9 if you prefer) */
}

.text-intro .lead {
  font-family: 'Open Sans', 'Stack Sans Headline', sans-serif;
  font-weight: 400;
  font-size: 1.05rem;
  line-height: 1.7;
  letter-spacing: 0.3px;
  color: #444;              /* slightly darker grey for readability */
  max-width: 540px;
  margin-top: 1.2em;
}
/* Smooth header transitions */
.site-navbar {
  transition: background 0.25s ease, backdrop-filter 0.25s ease;
}

/* Animated fading text — no initial triple flash */
.changing-text {
  position: relative;
  display: block;
  width: 100%;
  line-height: 1.1;
  height: 1.3em;
  overflow: hidden;
}

.changing-text span {
  position: absolute;
  top: 0;
  left: 0;
  white-space: nowrap;
  opacity: 0;                        /* baseline: hidden */
  font-family: 'Stack Sans Headline', sans-serif;
  font-weight: 700;
  color: #207561;
  animation: fadeCycle 12s infinite;
  animation-fill-mode: forwards;     /* no backwards fill during delay */
  will-change: opacity;
}

/* Show order: 0–3s, 3–6s, 6–9s */
.changing-text span:nth-child(1) { opacity: 1; animation-delay: 0s; }  /* visible immediately */
.changing-text span:nth-child(2) { animation-delay: 4s; }
.changing-text span:nth-child(3) { animation-delay: 8s; }

/* Smooth fade in & out */
@keyframes fadeCycle {
  0%   { opacity: 0; transform: translateY(2px); }     /* start below & invisible */
  8%   { opacity: 1; transform: translateY(0); }       /* fade in softly */
  25%  { opacity: 1; transform: translateY(0); }       /* hold fully visible */
  33%  { opacity: 0; transform: translateY(-2px); }    /* fade out gently upward */
  100% { opacity: 0; transform: translateY(-2px); }    /* stay hidden until next */
}

.changing-text span {
  position: absolute;
  top: 0;
  left: 0;
  white-space: nowrap;
  opacity: 0;
  font-family: 'Stack Sans Headline', sans-serif;
  font-weight: 700;
  color: #207561;
  animation: fadeCycle 12s infinite ease-in-out;  /* smooth easing */
  animation-fill-mode: forwards;
  will-change: opacity, transform;
}
/* Minimal sleek line below header */
.site-navbar::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: rgba(0, 0, 0, 0.12); /* consistent subtle divider */
  z-index: 10;
}

/* Remove any space under header */
.site-navbar {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

.sticky-wrapper {
  margin-bottom: 0 !important;
}

/* Pull hero section up to meet the header line */
.site-blocks-cover {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* Clean 1px divider line under the header */
.site-navbar::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: rgba(0, 0, 0, 0.12); /* clean subtle line */
  z-index: 10;
}

/* Prevent hidden borders or extra background layers */
.sticky-wrapper,
.site-navbar-target {
  background: transparent !important;
  border: none !important;
}
/* === Start header already in its shrunken state === */
.site-navbar {
  padding-top: 10px !important;
  padding-bottom: 10px !important;
}

/* Keep same height after scroll (so no change happens) */
.sticky-wrapper.is-sticky .site-navbar {
  padding-top: 10px !important;
  padding-bottom: 10px !important;
}

/* Optional: slightly adjust logo alignment if needed */
.site-logo img {
  height: 26px; /* adjust logo scale to fit new compact header */
  width: auto;
}
/* Reduce gap between "Hi, I am" and "AnandaKrishnan N" */
.text-intro h1:first-child {
  margin-bottom: 0.1em !important;   /* was ~0.3em before */
}


/* Circular hero image aligned beside text */
.img-face {
  width: 500px;
  height: 500px;
  border-radius: 50%;
  object-fit: cover;
  border: 4px solid rgba(255, 255, 255, 0.6);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
  display: block;
  margin: auto;
  position: relative;
  top: -10px;   /* move image up slightly (adjust if needed) */
}

/* Responsive fix */
@media (max-width: 991.98px) {
  .hero-flex {
    flex-direction: column-reverse;
    text-align: center;
  }
  .img-face {
    width: 250px;
    height: 250px;
    margin-top: 30px;
  }
}
.hero-flex .img-face {
  transform: translateY(-40px); /* Adjust this value up or down */
}
/* === ABOUT SECTION CUSTOM STYLE === */

#about-section .section-title .accent { color: #5cb7b9; }

/* paragraph blocks */
#about-section .about-lead {
  color: #6b6b6b;
  line-height: 1.8;
  margin-bottom: 1rem;
  max-width: 680px;
}

/* bullet list */
#about-section .about-list {
  margin-top: 1rem;
  padding-left: 1.25rem;
  list-style: disc;
  color: #444;
  line-height: 1.7;
}
#about-section .about-list li { margin-bottom: 0.75rem; }

/* stats grid */
.about-stats-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
}

/* each card */
.stat-card {
  background: #fff;
  border-radius: 10px;
  padding: 26px 20px;
  text-align: center;
  border: 1px solid rgba(0,0,0,0.06);
  box-shadow: 0 6px 22px rgba(34,34,34,0.03);
  min-height: 130px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

/* icon block */ /*about blocks*/


/* SVG inside stat icon: size control */
#about-section .stat-icon svg {
  width: 30px;
  height: 30px;
  display: block;
  stroke: currentColor;
  fill: none;                /* keep stroke icons; head (target center) uses fill where needed */
}

/* hover / focus state for the card */
#about-section .stat-card:hover .stat-icon,
#about-section .stat-card:focus-within .stat-icon {
  transform: translateY(-4px) scale(1.02);
  color: #207561;           /* accent color on hover */
  border-color: #207561;
}

/* stat number + label visual */
#about-section .stat-number {
  font-weight: 700;
  font-size: 1.25rem;
  color: #111;
  margin-bottom: 4px;
}
#about-section .stat-label {
  font-size: 0.875rem;
  color: #666;
}

/* number + label */
.stat-number {
  font-weight: 700;
  font-size: 22px;
  color: #222;
  margin-bottom: 6px;
}
.stat-label {
  font-size: 0.85rem;
  color: #6b6b6b;
}

/* responsive */
@media (max-width: 991.98px) {
  .about-stats-grid { grid-template-columns: 1fr 1fr; gap: 1rem; margin-top: 1.2rem; }
  #about-section .col-lg-7, #about-section .col-lg-5 { width: 100%; max-width: 100%; flex: 0 0 100%; }
  #about-section { padding-top: 3rem; padding-bottom: 3rem; }
}
@media (max-width: 576px) {
  .about-stats-grid { grid-template-columns: 1fr; }
  .stat-card { min-height: 110px; padding: 18px; }
  #about-section .about-lead { max-width: 100%; }
}

/* === ABOUT SECTION CUSTOM FONT & STYLE (Stack Sans Headline) === */

/* --- Heading --- */
#about-section .section-title {
  font-weight: 700;
  font-size: 2.4rem;
  color: #111;
  margin-bottom: 1.2rem;
  letter-spacing: 0.2px;
}
#about-section .section-title .accent {
  color: #207561;
  font-weight: 700;
}

/* --- Paragraph text --- */
#about-section .about-lead {
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.9;
  color: #444;
  margin-bottom: 1.2rem;
  max-width: 700px;
}

/* --- Subheading --- */
#about-section h4 {
  font-weight: 600;
  color: #000;
  font-size: 1.2rem;
  margin-top: 1.5rem;
}

/* --- Bullet list --- */
#about-section .about-list {
  list-style: disc;
  margin-top: 1rem;
  padding-left: 1.3rem;
}
#about-section .about-list li {
  margin-bottom: 0.7rem;
  font-size: 0.95rem;
  color: #333;
  font-weight: 400;
  line-height: 1.7;
}

/* --- Stats cards layout --- */
.about-stats-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
}

.stat-card {
  background: #fff;
  border-radius: 12px;
  padding: 28px 20px;
  text-align: center;
  border: 1px solid rgba(0,0,0,0.06);
  box-shadow: 0 4px 18px rgba(0,0,0,0.04);
  transition: all 0.3s ease;
}
.stat-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 6px 20px rgba(0,0,0,0.07);
}

/* --- Icons and text inside cards --- */
.stat-icon {
  font-size: 30px;
  color: #207561;
  margin-bottom: 10px;
}

.stat-number {
  font-weight: 700;
  font-size: 1.4rem;
  color: #000;
  letter-spacing: 0.3px;
}

.stat-label {
  font-size: 0.85rem;
  color: #666;
  font-weight: 400;
  margin-top: 3px;
}

/* --- Responsive adjustments --- */
@media (max-width: 991.98px) {
  .about-stats-grid {
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin-top: 1.5rem;
  }
}
@media (max-width: 576px) {
  .about-stats-grid {
    grid-template-columns: 1fr;
  }
  .stat-card {
    min-height: 110px;
    padding: 18px;
  }
}
/* === About section — force Stack Sans Headline and sensible weights === */
#about-section,
#about-section * {
  font-family: 'Stack Sans Headline', sans-serif !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* make body text regular weight so it doesn't appear too bold */
#about-section,
#about-section p,
#about-section .about-lead,
#about-section .about-list,
#about-section .about-list li,
#about-section .stat-label {
  font-weight: 400 !important;
  color: #444 !important;
}

/* headings: tuned weights and sizes */
#about-section .section-title,
#about-section h2,
#about-section h1 {
  font-family: 'Stack Sans Headline', sans-serif !important;
  font-weight: 700 !important;    /* strong for main section title */
  font-size: 2.4rem !important;
  letter-spacing: 0.2px !important;
  color: #000000 !important;
}

/* subheading (My Design Philosophy) */
#about-section h4,
#about-section .subheading {
  font-family: 'Stack Sans Headline', sans-serif !important;
  font-weight: 400 !important;
  font-size: 1.1rem !important;
  margin-top: 1.2rem !important;
  color: #111 !important;
}

/* bullets and small text keep normal weight */
#about-section .about-list li {
  font-weight: 400 !important;
  color: #333 !important;
  line-height: 1.7 !important;
}

/* stats card numbers slightly bolder but not heavy */
.stat-number {
  font-weight: 600 !important;
}

/* if some global rule still forces Arbutus Slab on h-tags, override it explicitly */
#about-section h1,
#about-section h2,
#about-section h3,
#about-section h4,
#about-section h5,
#about-section h6 {
  font-family: 'Stack Sans Headline', sans-serif !important;
}

/* Responsive tweak (smaller heading sizes on mobile) */
@media (max-width: 991.98px) {
  #about-section .section-title {
    font-size: 1.8rem !important;
  }
}

/* Base */
html {
  overflow-x: hidden; }

body {
  line-height: 1.7;
  color: #666666;
  font-weight: 400;
  font-size: 1rem; }

::-moz-selection {
  background: #000;
  color: #fff; }

::selection {
  background: #000;
  color: #fff; }

a {
  -webkit-transition: .3s all ease;
  -o-transition: .3s all ease;
  transition: .3s all ease; }
  a:hover {
    text-decoration: none; }

h1, h2, h3, h4, h5,
.h1, .h2, .h3, .h4, .h5 {
  font-family: "Stack Sans Headline", sans-serif;;
  color: #000; }

.border-2 {
  border-width: 2px; }

.text-black {
  color: #000 !important; }

.bg-black {
  background: #000 !important; }

.color-black-opacity-5 {
  color: rgba(0, 0, 0, 0.5); }

.color-white-opacity-5 {
  color: rgba(255, 255, 255, 0.5); }

body:after {
  -webkit-transition: .3s all ease-in-out;
  -o-transition: .3s all ease-in-out;
  transition: .3s all ease-in-out; }

.offcanvas-menu {
  position: relative; }
  .offcanvas-menu:after {
    position: absolute;
    content: "";
    bottom: 0;
    left: 0;
    top: 0;
    right: 0;
    z-index: 999;
    background: rgba(0, 0, 0, 0.2); }

.btn {
  font-size: 16px;
  border-radius: 30px;
  padding: 10px 30px; }
  .btn:hover, .btn:active, .btn:focus {
    outline: none;
    -webkit-box-shadow: none !important;
    box-shadow: none !important; }
  .btn.btn-primary {
    background: #207561;
    border-color: #207561;
    color: #fff; }
    .btn.btn-primary:hover {
      background: #000;
      border-color: #000;
      color: #fff; }
    .btn.btn-primary.btn-black--hover:hover {
      background: #666666;
      color: #fff; }

.line-height-1 {
  line-height: 1 !important; }

.bg-black {
  background: #000; }

.form-control {
  height: 43px;
  border-radius: 30px;
  font-family: "Stack Sans Headline", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; }
  .form-control:active, .form-control:focus {
    border-color: #207561; }
  .form-control:hover, .form-control:active, .form-control:focus {
    -webkit-box-shadow: none !important;
    box-shadow: none !important; }

.site-section {
  padding: 2.5em 0; }
  @media (min-width: 768px) {
    .site-section {
      padding: 7em 0; } }
  .site-section.site-section-sm {
    padding: 4em 0; }

.site-section-heading {
  padding-bottom: 20px;
  margin-bottom: 0px;
  position: relative;
  font-size: 2.5rem; }
  @media (min-width: 768px) {
    .site-section-heading {
      font-size: 3rem; } }

.site-footer {
  padding: 4em 0;
  background: #333333; }
  @media (min-width: 768px) {
    .site-footer {
      padding: 8em 0; } }
  .site-footer .border-top {
    border-top: 1px solid rgba(255, 255, 255, 0.1) !important; }
  .site-footer p {
    color: #737373; }
  .site-footer h2, .site-footer h3, .site-footer h4, .site-footer h5 {
    color: #fff; }
  .site-footer a {
    color: #999999; }
    .site-footer a:hover {
      color: white; }
  .site-footer ul li {
    margin-bottom: 10px; }
  .site-footer .footer-heading {
    font-size: 16px;
    color: #fff; }

.bg-text-line {
  display: inline;
  background: #000;
  -webkit-box-shadow: 20px 0 0 #000, -20px 0 0 #000;
  box-shadow: 20px 0 0 #000, -20px 0 0 #000; }

.text-white-opacity-05 {
  color: rgba(255, 255, 255, 0.5); }

.text-black-opacity-05 {
  color: rgba(0, 0, 0, 0.5); }

.hover-bg-enlarge {
  overflow: hidden;
  position: relative; }
  @media (max-width: 991.98px) {
    .hover-bg-enlarge {
      height: auto !important; } }
  .hover-bg-enlarge > div {
    -webkit-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
    -webkit-transition: .8s all ease-in-out;
    -o-transition: .8s all ease-in-out;
    transition: .8s all ease-in-out; }
  .hover-bg-enlarge:hover > div, .hover-bg-enlarge:focus > div, .hover-bg-enlarge:active > div {
    -webkit-transform: scale(1.2);
    -ms-transform: scale(1.2);
    transform: scale(1.2); }
  @media (max-width: 991.98px) {
    .hover-bg-enlarge .bg-image-md-height {
      height: 300px !important; } }

.bg-image {
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  background-attachment: fixed; }
  .bg-image.overlay {
    position: relative; }
    .bg-image.overlay:after {
      position: absolute;
      content: "";
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      z-index: 0;
      width: 100%;
      background: rgba(0, 0, 0, 0.7); }
  .bg-image > .container {
    position: relative;
    z-index: 1; }

@media (max-width: 991.98px) {
  .img-md-fluid {
    max-width: 100%; } }

@media (max-width: 991.98px) {
  .display-1, .display-3 {
    font-size: 3rem; } }

.play-single-big {
  width: 90px;
  height: 90px;
  display: inline-block;
  border: 2px solid #fff;
  color: #fff !important;
  border-radius: 50%;
  position: relative;
  -webkit-transition: .3s all ease-in-out;
  -o-transition: .3s all ease-in-out;
  transition: .3s all ease-in-out; }
  .play-single-big > span {
    font-size: 50px;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-40%, -50%);
    -ms-transform: translate(-40%, -50%);
    transform: translate(-40%, -50%); }
  .play-single-big:hover {
    width: 120px;
    height: 120px; }

.overlap-to-top {
  margin-top: -150px; }

.ul-check {
  margin-bottom: 50px; }
  .ul-check li {
    position: relative;
    padding-left: 35px;
    margin-bottom: 15px;
    line-height: 1.5; }
    .ul-check li:before {
      left: 0;
      font-size: 20px;
      top: -.3rem;
      font-family: "icomoon";
      content: "\e5ca";
      position: absolute; }
  .ul-check.white li:before {
    color: #fff; }
  .ul-check.success li:before {
    color: #71bc42; }
  .ul-check.primary li:before {
    color: #207561; }
  .ul-check li.remove {
    text-decoration: line-through;
    color: #dee2e6; }
    .ul-check li.remove:before {
      color: #dee2e6; }

.select-wrap, .wrap-icon {
  position: relative; }
  .select-wrap .icon, .wrap-icon .icon {
    position: absolute;
    right: 10px;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    font-size: 22px; }
  .select-wrap select, .wrap-icon select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 100%; }

/* Navbar */
.site-navbar {
  margin-bottom: 0px;
  z-index: 1999;
  position: absolute;
  top: 0;
  width: 100%;
  border-bottom: rgba(255, 255, 255, 0.7); }
  .site-navbar,
  .site-navbar:hover {
   background: transparent; /* stay transparent at the top */
  }
  .site-navbar .site-logo {
    font-size: 1.5rem; }
    .site-navbar .site-logo a {
      display: inline-block;
      padding: 5px 10px;
      color: #207561 !important; }
  .site-navbar .site-navigation .site-menu {
    margin: 0;
    padding: 0;
    margin-bottom: 0;
    font-family: "Stack Sans Headline", sans-serif; }
  .site-navbar .site-navigation {
    padding-right: 40px;  /* pushes menu a bit away from right edge */
  }

  .site-navbar .site-navigation .site-menu {
  margin-left: auto; /* pushes menu fully to the right */
  margin-right: 0;
  }

    .site-navbar .site-navigation .site-menu a {
      text-decoration: none !important;
      display: inline-block;
      position: relative;
      padding: 5px 20px; }
    .site-navbar .site-navigation .site-menu > li {
      display: inline-block; }
      /*home, serviece ,about  distance*/
      .site-navbar .site-navigation .site-menu > li > a {
        padding: 5px 10px;
        color: #000;
        display: inline-block;
        text-decoration: none !important; }
        .site-navbar .site-navigation .site-menu > li > a:hover {
          color: #207561; }
    .site-navbar .site-navigation .site-menu .has-children {
      position: relative; }
      .site-navbar .site-navigation .site-menu .has-children > a {
        position: relative;
        padding-right: 20px; }
        .site-navbar .site-navigation .site-menu .has-children > a:before {
          position: absolute;
          content: "\e313";
          font-size: 16px;
          top: 50%;
          right: 0;
          -webkit-transform: translateY(-50%);
          -ms-transform: translateY(-50%);
          transform: translateY(-50%);
          font-family: 'icomoon'; }
      .site-navbar .site-navigation .site-menu .has-children .dropdown {
        visibility: hidden;
        opacity: 0;
        top: 100%;
        position: absolute;
        text-align: left;
        border-top: 2px solid #207561;
        -webkit-box-shadow: 0 2px 10px -2px rgba(0, 0, 0, 0.1);
        box-shadow: 0 2px 10px -2px rgba(0, 0, 0, 0.1);
        padding: 0px 0;
        margin-top: 20px;
        margin-left: 0px;
        background: #fff;
        -webkit-transition: 0.2s 0s;
        -o-transition: 0.2s 0s;
        transition: 0.2s 0s; }
        .site-navbar .site-navigation .site-menu .has-children .dropdown.arrow-top {
          position: absolute; }
          .site-navbar .site-navigation .site-menu .has-children .dropdown.arrow-top:before {
            bottom: 100%;
            left: 20%;
            border: solid transparent;
            content: " ";
            height: 0;
            width: 0;
            position: absolute;
            pointer-events: none; }
          .site-navbar .site-navigation .site-menu .has-children .dropdown.arrow-top:before {
            border-color: rgba(136, 183, 213, 0);
            border-bottom-color: #fff;
            border-width: 10px;
            margin-left: -10px; }
        .site-navbar .site-navigation .site-menu .has-children .dropdown a {
          text-transform: none;
          letter-spacing: normal;
          -webkit-transition: 0s all;
          -o-transition: 0s all;
          transition: 0s all;
          color: #000; }
        .site-navbar .site-navigation .site-menu .has-children .dropdown .active {
          color: #207561 !important; }
        .site-navbar .site-navigation .site-menu .has-children .dropdown > li {
          list-style: none;
          padding: 0;
          margin: 0;
          min-width: 210px; }
          .site-navbar .site-navigation .site-menu .has-children .dropdown > li > a {
            padding: 9px 20px;
            display: block; }
            .site-navbar .site-navigation .site-menu .has-children .dropdown > li > a:hover {
              background: #eff1f3;
              color: #000; }
          .site-navbar .site-navigation .site-menu .has-children .dropdown > li.has-children > a:before {
            content: "\e315";
            right: 20px; }
          .site-navbar .site-navigation .site-menu .has-children .dropdown > li.has-children > .dropdown, .site-navbar .site-navigation .site-menu .has-children .dropdown > li.has-children > ul {
            left: 100%;
            top: 0; }
      .site-navbar .site-navigation .site-menu .has-children:hover > a, .site-navbar .site-navigation .site-menu .has-children:focus > a, .site-navbar .site-navigation .site-menu .has-children:active > a {
        color: #207561; }
      .site-navbar .site-navigation .site-menu .has-children:hover, .site-navbar .site-navigation .site-menu .has-children:focus, .site-navbar .site-navigation .site-menu .has-children:active {
        cursor: pointer; }
        .site-navbar .site-navigation .site-menu .has-children:hover > .dropdown, .site-navbar .site-navigation .site-menu .has-children:focus > .dropdown, .site-navbar .site-navigation .site-menu .has-children:active > .dropdown {
          -webkit-transition-delay: 0s;
          -o-transition-delay: 0s;
          transition-delay: 0s;
          margin-top: 0px;
          visibility: visible;
          opacity: 1; }
         /* Navbar link font customization */
      .site-navbar .site-navigation .site-menu > li > a {
        font-family: 'Stack Sans Headline', sans-serif;  /* modern clean font */
        font-weight: 500;                                /* medium thickness */
        font-size: 1rem;                                 /* adjust size if needed */
        letter-spacing: 0.5px;                           /* subtle spacing */
        text-transform: none;                            /* keep normal case */
        color: #000;                                     /* default color */
        transition: color 0.3s ease, transform 0.3s ease;
      }     

.site-navbar .site-navigation .site-menu > li > a:hover {
  color: #5cb7b9;                                  /* highlight color */
  transform: translateY(-2px);                     /* slight lift effect */
}
 

.site-mobile-menu {
  width: 300px;
  position: fixed;
  right: 0;
  z-index: 2000;
  padding-top: 20px;
  background: #fff;
  height: calc(100vh);
  -webkit-transform: translateX(110%);
  -ms-transform: translateX(110%);
  transform: translateX(110%);
  -webkit-box-shadow: -10px 0 20px -10px rgba(0, 0, 0, 0.1);
  box-shadow: -10px 0 20px -10px rgba(0, 0, 0, 0.1);
  -webkit-transition: .3s all ease-in-out;
  -o-transition: .3s all ease-in-out;
  transition: .3s all ease-in-out; }
  .offcanvas-menu .site-mobile-menu {
    -webkit-transform: translateX(0%);
    -ms-transform: translateX(0%);
    transform: translateX(0%); }
  .site-mobile-menu .site-mobile-menu-header {
    width: 100%;
    float: left;
    padding-left: 20px;
    padding-right: 20px; }
    .site-mobile-menu .site-mobile-menu-header .site-mobile-menu-close {
      float: right;
      margin-top: 8px; }
      .site-mobile-menu .site-mobile-menu-header .site-mobile-menu-close span {
        font-size: 30px;
        display: inline-block;
        padding-left: 10px;
        padding-right: 0px;
        line-height: 1;
        cursor: pointer;
        -webkit-transition: .3s all ease;
        -o-transition: .3s all ease;
        transition: .3s all ease; }
    .site-mobile-menu .site-mobile-menu-header .site-mobile-menu-logo {
      float: left;
      margin-top: 10px;
      margin-left: 0px; }
      .site-mobile-menu .site-mobile-menu-header .site-mobile-menu-logo a {
        display: inline-block;
        text-transform: uppercase; }
        .site-mobile-menu .site-mobile-menu-header .site-mobile-menu-logo a img {
          max-width: 70px; }
        .site-mobile-menu .site-mobile-menu-header .site-mobile-menu-logo a:hover {
          text-decoration: none; }
  .site-mobile-menu .site-mobile-menu-body {
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;
    position: relative;
    padding: 0 20px 20px 20px;
    height: calc(100vh - 52px);
    padding-bottom: 150px; }
  .site-mobile-menu .site-nav-wrap {
    padding: 0;
    margin: 0;
    list-style: none;
    position: relative; }
    .site-mobile-menu .site-nav-wrap a {
      padding: 10px 20px;
      display: block;
      position: relative;
      color: #212529; }
      .site-mobile-menu .site-nav-wrap a:hover {
        color: #207561; }
    .site-mobile-menu .site-nav-wrap li {
      position: relative;
      display: block; }
      .site-mobile-menu .site-nav-wrap li .active {
        color: #207561; }
    .site-mobile-menu .site-nav-wrap .arrow-collapse {
      position: absolute;
      right: 0px;
      top: 10px;
      z-index: 20;
      width: 36px;
      height: 36px;
      text-align: center;
      cursor: pointer;
      border-radius: 50%; }
      .site-mobile-menu .site-nav-wrap .arrow-collapse:hover {
        background: #f8f9fa; }
      .site-mobile-menu .site-nav-wrap .arrow-collapse:before {
        font-size: 12px;
        z-index: 20;
        font-family: "icomoon";
        content: "\f078";
        position: absolute;
        top: 50%;
        left: 50%;
        -webkit-transform: translate(-50%, -50%) rotate(-180deg);
        -ms-transform: translate(-50%, -50%) rotate(-180deg);
        transform: translate(-50%, -50%) rotate(-180deg);
        -webkit-transition: .3s all ease;
        -o-transition: .3s all ease;
        transition: .3s all ease; }
      .site-mobile-menu .site-nav-wrap .arrow-collapse.collapsed:before {
        -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%); }
    .site-mobile-menu .site-nav-wrap > li {
      display: block;
      position: relative;
      float: left;
      width: 100%; }
      .site-mobile-menu .site-nav-wrap > li > a {
        padding-left: 20px;
        font-size: 20px; }
      .site-mobile-menu .site-nav-wrap > li > ul {
        padding: 0;
        margin: 0;
        list-style: none; }
        .site-mobile-menu .site-nav-wrap > li > ul > li {
          display: block; }
          .site-mobile-menu .site-nav-wrap > li > ul > li > a {
            padding-left: 40px;
            font-size: 16px; }
          .site-mobile-menu .site-nav-wrap > li > ul > li > ul {
            padding: 0;
            margin: 0; }
            .site-mobile-menu .site-nav-wrap > li > ul > li > ul > li {
              display: block; }
              .site-mobile-menu .site-nav-wrap > li > ul > li > ul > li > a {
                font-size: 16px;
                padding-left: 60px; }
    .site-mobile-menu .site-nav-wrap[data-class="social"] {
      float: left;
      width: 100%;
      margin-top: 30px;
      padding-bottom: 5em; }
      .site-mobile-menu .site-nav-wrap[data-class="social"] > li {
        width: auto; }
        .site-mobile-menu .site-nav-wrap[data-class="social"] > li:first-child a {
          padding-left: 15px !important; }

.sticky-wrapper {
  position: absolute;
  z-index: 100;
  width: 100%; }
  .sticky-wrapper .site-navbar {
    -webkit-transition: .3s all ease;
    -o-transition: .3s all ease;
    transition: .3s all ease; }
  .sticky-wrapper .site-navbar .site-menu-toggle {
    color: #000; }
  .sticky-wrapper .site-navbar .site-logo a {
    color: #000; }
  .sticky-wrapper .site-navbar .site-menu > li > a {
    color: rgba(0, 0, 0, 0.7) !important; }
    .sticky-wrapper .site-navbar .site-menu > li > a:hover, .sticky-wrapper .site-navbar .site-menu > li > a.active {
      color: #207561 !important; }
  .sticky-wrapper.is-sticky .site-navbar {
    background: rgba(255, 255, 255, 0.28);        /* slightly denser frost */
    -webkit-backdrop-filter: saturate(160%) blur(14px);
    backdrop-filter: saturate(100%) blur(18px);    /* smooth blur */
    border-bottom: 1px solid rgba(255, 255, 255, 0.25);
    /*box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);    /* subtle matte shadow */
    transition: background 0.25s ease, backdrop-filter 0.25s ease;      
  }
    .sticky-wrapper.is-sticky .site-navbar .site-menu-toggle {
      color: #000; }
    .sticky-wrapper.is-sticky .site-navbar .site-logo a {
      color: #000; }
    .sticky-wrapper.is-sticky .site-navbar .site-menu > li > a {
      color: #000 !important; }
      .sticky-wrapper.is-sticky .site-navbar .site-menu > li > a:hover, .sticky-wrapper.is-sticky .site-navbar .site-menu > li > a.active {
        color: #5cb7b9 !important; }
  .sticky-wrapper .shrink {
    padding-top: 10px !important;
    padding-bottom: 10px !important; }

/* Blocks */
.site-blocks-cover {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: top;
  background-position: center center;
  overflow: hidden;
  position: relative; }
  .site-blocks-cover .lead {
    font-family: "Stack Sans Headline", sans-serif;
    font-size: 1.3rem;
    color: #1a1a1a; }
  .site-blocks-cover.overlay {
    position: relative; }
    .site-blocks-cover.overlay:before {
      position: absolute;
      content: "";
      left: 0;
      bottom: 0;
      right: 0;
      top: 0;
      z-index: 2;
      background: rgba(255, 255, 255, 0); }
      @media (max-width: 991.98px) {
        .site-blocks-cover.overlay:before {
          background: rgba(255, 255, 255, 0.5); } }
  .site-blocks-cover, .site-blocks-cover > .container, .site-blocks-cover > .container > .row {
    min-height: 600px;
    height: 100vh; }
  .site-blocks-cover .text-intro {
    position: relative;
    z-index: 2; }
  .site-blocks-cover h1 {
    font-size: 3rem;
    font-family: "Stack Sans Headline", sans-serif;}
  .site-blocks-cover .img-face {
    position: absolute;
    right: -5%;
    bottom: 0;
    z-index: 1;
    max-width: 950px; }
    @media (max-width: 991.98px) {
      .site-blocks-cover .img-face {
        right: -25%; } }

.section-title {
  position: relative;
  padding-bottom: 20px; }
  /* .section-title:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    height: 2px;
    background: #207561;
    width: 50px; } */
  .section-title.text-center:after {
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%); }
  .section-title.text-center:after {
    background: #fff; }

.position-relative {
  position: relative; }

.service {
  padding: 30px;
  background: #fff;
  -webkit-box-shadow: 0 1px 2px 0px rgba(0, 0, 0, 0.1);
  box-shadow: 0 1px 2px 0px rgba(0, 0, 0, 0.1);
  -webkit-transition: .3s all ease-in-out;
  -o-transition: .3s all ease-in-out;
  transition: .3s all ease-in-out;
  top: 0;
  position: relative; }
  .service:hover {
    -webkit-box-shadow: 0 8px 50px -5px rgba(0, 0, 0, 0.1);
    box-shadow: 0 8px 50px -5px rgba(0, 0, 0, 0.1);
    top: -2px; }
  .service .service-number {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 60px;
    flex: 0 0 60px; }
    .service .service-number span {
      position: relative;
      width: 50px;
      height: 50px;
      line-height: 50px;
      border-radius: 50%;
      background: #207561;
      display: inline-block;
      color: #fff;
      text-align: center; }
  .service .service-about *:last-child {
    margin-bottom: 0; }
  .service .service-about h3 {
    font-size: 1.2rem;
    margin-bottom: 10px; }

.gal-item {
  margin-bottom: 30px; }

.filters .btn {
  border-color: transparent;
  font-size: .8rem;
  margin: 5px;
  letter-spacing: .2rem;
  background: rgba(52, 58, 64, 0.05);
  color: #343a40;
  padding: 5px 20px;
  border-radius: 30px !important;
  border: none !important;
  text-transform: uppercase; }
  .filters .btn:hover, .filters .btn:focus, .filters .btn:active {
    border-color: transparent !important;
    background: rgba(52, 58, 64, 0.3) !important;
    color: #000; }
  .filters .btn.active {
    background: #000 !important;
    color: #fff;
    border-color: #000 !important; }

/* Isotope Transitions
------------------------------- */
.isotope,
.isotope .item {
  -webkit-transition-duration: 0.8s;
  -moz-transition-duration: 0.8s;
  -ms-transition-duration: 0.8s;
  -o-transition-duration: 0.8s;
  transition-duration: 0.8s; }

.isotope {
  -webkit-transition-property: height, width;
  -moz-transition-property: height, width;
  -ms-transition-property: height, width;
  -o-transition-property: height, width;
  transition-property: height, width; }

.isotope .item {
  -webkit-transition-property: -webkit-transform, opacity;
  -moz-transition-property: -moz-transform, opacity;
  -ms-transition-property: -ms-transform, opacity;
  -o-transition-property: top, left, opacity;
  -webkit-transition-property: opacity, -webkit-transform;
  transition-property: opacity, -webkit-transform;
  -o-transition-property: transform, opacity;
  transition-property: transform, opacity;
  transition-property: transform, opacity, -webkit-transform; }

/* responsive media queries */
.item {
  border: none;
  margin-bottom: 30px;
  border-radius: 4px; }
  .item a {
    display: block;
    overflow: hidden;
    position: relative;
    border-radius: 4px; }
    .item a img {
      position: relative;
      -webkit-transform: scale(1);
      -ms-transform: scale(1);
      transform: scale(1);
      -webkit-transition: .3s all ease-in-out;
      -o-transition: .3s all ease-in-out;
      transition: .3s all ease-in-out; }
  .item .item-wrap {
    display: block;
    position: relative; }
    .item .item-wrap:after {
      z-index: 2;
      position: absolute;
      content: "";
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.4);
      visibility: hidden;
      opacity: 0;
      -webkit-transition: .3s all ease-in-out;
      -o-transition: .3s all ease-in-out;
      transition: .3s all ease-in-out; }
    .item .item-wrap > span {
      position: absolute;
      top: 50%;
      left: 50%;
      z-index: 3;
      -webkit-transform: translate(-50%, -50%) scale(0);
      -ms-transform: translate(-50%, -50%) scale(0);
      transform: translate(-50%, -50%) scale(0);
      color: #fff;
      font-size: 1.7rem;
      opacity: 0;
      visibility: hidden;
      -webkit-transition: .3s all ease;
      -o-transition: .3s all ease;
      transition: .3s all ease; }
    .item .item-wrap:hover:after {
      opacity: 1;
      visibility: visible; }
    .item .item-wrap:hover span {
      margin-top: 0px;
      opacity: 1;
      visibility: visible;
      -webkit-transform: translate(-50%, -50%) scale(1);
      -ms-transform: translate(-50%, -50%) scale(1);
      transform: translate(-50%, -50%) scale(1); }
  .item:hover a img {
    -webkit-transform: scale(1.05);
    -ms-transform: scale(1.05);
    transform: scale(1.05);
    -webkit-transition: .3s all ease-in-out;
    -o-transition: .3s all ease-in-out;
    transition: .3s all ease-in-out; }

.slide-one-item .slide {
  text-align: center; }
  .slide-one-item .slide blockquote {
    position: relative;
    max-width: 700px;
    font-size: 1.2rem;
    color: #000;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
    font-style: italic;
    color: #fff; }
  .slide-one-item .slide cite {
    margin-top: 50px;
    font-size: 1rem;
    color: rgba(255, 255, 255, 0.5); }

.slide-one-item .owl-dots {
  text-align: center; }
  .slide-one-item .owl-dots .owl-dot {
    display: inline-block; }
    .slide-one-item .owl-dots .owl-dot > span {
      margin: 7px;
      background: rgba(255, 255, 255, 0.3);
      display: inline-block;
      width: 7px;
      height: 7px;
      border-radius: 50%; }
    .slide-one-item .owl-dots .owl-dot:hover > span {
      background: rgba(255, 255, 255, 0.5); }
    .slide-one-item .owl-dots .owl-dot.active > span {
      background: #fff; }

.blog_entry img {
  border-top-left-radius: 4px;
  border-top-right-radius: 4px; }

.blog_entry > div {
  border: 1px solid #eee;
  border-top: none; }

.blog_entry h3 {
  font-size: 1.3rem; }
  .blog_entry h3 a {
    color: #000; }

.blog_entry .date {
  color: #999999;
  display: block;
  font-size: .9rem;
  margin-bottom: 15px; }

.blog_entry .more a {
  position: relative;
  color: #000;
  padding-bottom: 10px; }
  .blog_entry .more a:before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: #000;
    -webkit-transition: .3s all ease;
    -o-transition: .3s all ease;
    transition: .3s all ease; }
  .blog_entry .more a:hover:before {
    background: #207561; }

.form .form-control {
  border: none;
  border-radius: 0px;
  border-bottom: 1px solid #eee; }
  .form .form-control:active, .form .form-control:focus {
    border-color: #000; }

.footer {
  font-size: .9rem; }
  .footer .footer-title {
    font-size: 1.1rem;
    margin-bottom: 30px; }
  .footer ul li {
    margin-bottom: 10px; }
  .footer a {
    color: #888888; }
    .footer a:hover {
      color: #000; }
.site-logo img {
  height: 30px;
  width: auto;
}
/* Hero text refinement */
.text-intro h1:first-child {
   font-family: 'Stack Sans Headline', sans-serif;
  font-weight: 400;
  font-size: 2.5rem;
  margin-bottom: 0.3em;
  color: #555;           /* subtle grey for contrast */
}

.text-intro h1:nth-child(2) {
  font-family: 'Stack Sans Headline', sans-serif;
  font-weight: 700;
  font-size: 3.5rem;
  color: #207561;  /* or your chosen highlight color */          /* highlight color (or use #5cb7b9 if you prefer) */
}

.text-intro .lead {
  font-family: 'Open Sans', 'Stack Sans Headline', sans-serif;
  font-weight: 400;
  font-size: 1.05rem;
  line-height: 1.7;
  letter-spacing: 0.3px;
  color: #444;              /* slightly darker grey for readability */
  max-width: 540px;
  margin-top: 1.2em;
}
/* Smooth header transitions */
.site-navbar {
  transition: background 0.25s ease, backdrop-filter 0.25s ease;
}

/* Animated fading text — no initial triple flash */
.changing-text {
  position: relative;
  display: block;
  width: 100%;
  line-height: 1.1;
  height: 1.3em;
  overflow: hidden;
}

.changing-text span {
  position: absolute;
  top: 0;
  left: 0;
  white-space: nowrap;
  opacity: 0;                        /* baseline: hidden */
  font-family: 'Stack Sans Headline', sans-serif;
  font-weight: 700;
  color: #207561;
  animation: fadeCycle 12s infinite;
  animation-fill-mode: forwards;     /* no backwards fill during delay */
  will-change: opacity;
}

/* Show order: 0–3s, 3–6s, 6–9s */
.changing-text span:nth-child(1) { opacity: 1; animation-delay: 0s; }  /* visible immediately */
.changing-text span:nth-child(2) { animation-delay: 4s; }
.changing-text span:nth-child(3) { animation-delay: 8s; }

/* Fade in → hold → fade out */
@keyframes fadeCycle {
  0%   { opacity: 1; }
  20%  { opacity: 1; }   /* hold visible */
  33%  { opacity: 0; }   /* fade out */
  100% { opacity: 0; }
}
/* Smooth fade in & out */
@keyframes fadeCycle {
  0%   { opacity: 0; transform: translateY(2px); }     /* start below & invisible */
  8%   { opacity: 1; transform: translateY(0); }       /* fade in softly */
  25%  { opacity: 1; transform: translateY(0); }       /* hold fully visible */
  33%  { opacity: 0; transform: translateY(-2px); }    /* fade out gently upward */
  100% { opacity: 0; transform: translateY(-2px); }    /* stay hidden until next */
}

.changing-text span {
  position: absolute;
  top: 0;
  left: 0;
  white-space: nowrap;
  opacity: 0;
  font-family: 'Stack Sans Headline', sans-serif;
  font-weight: 700;
  color: #207561;
  animation: fadeCycle 12s infinite ease-in-out;  /* smooth easing */
  animation-fill-mode: forwards;
  will-change: opacity, transform;
}
/* Minimal sleek line below header */
.site-navbar::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: rgba(0, 0, 0, 0.12); /* consistent subtle divider */
  z-index: 10;
}

/* Remove any space under header */
.site-navbar {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

.sticky-wrapper {
  margin-bottom: 0 !important;
}

/* Pull hero section up to meet the header line */
.site-blocks-cover {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* Clean 1px divider line under the header */
.site-navbar::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: rgba(0, 0, 0, 0.12); /* clean subtle line */
  z-index: 10;
}

/* Prevent hidden borders or extra background layers */
.sticky-wrapper,
.site-navbar-target {
  background: transparent !important;
  border: none !important;
}
/* === Start header already in its shrunken state === */
.site-navbar {
  padding-top: 10px !important;
  padding-bottom: 10px !important;
}

/* Keep same height after scroll (so no change happens) */
.sticky-wrapper.is-sticky .site-navbar {
  padding-top: 10px !important;
  padding-bottom: 10px !important;
}

/* Optional: slightly adjust logo alignment if needed */
.site-logo img {
  height: 26px; /* adjust logo scale to fit new compact header */
  width: auto;
}
/* Reduce gap between "Hi, I am" and "AnandaKrishnan N" */
.text-intro h1:first-child {
  margin-bottom: 0.1em !important;   /* was ~0.3em before */
}


/* Circular hero image aligned beside text */
.img-face {
  width: 500px;
  height: 500px;
  border-radius: 50%;
  object-fit: cover;
  border: 4px solid rgba(255, 255, 255, 0.6);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
  display: block;
  margin: auto;
  position: relative;
  top: -10px;   /* move image up slightly (adjust if needed) */
}

/* Flex alignment tweak for hero section */
/* Responsive fix */
@media (max-width: 991.98px) {
  .hero-flex {
    flex-direction: column-reverse;
    text-align: center;
  }
  .img-face {
    width: 250px;
    height: 250px;
    margin-top: 30px;
  }
}
.hero-flex .img-face {
  transform: translateY(-40px); /* Adjust this value up or down */
}
/* === ABOUT SECTION CUSTOM STYLE === */

#about-section { padding-top: 4.5rem; padding-bottom: 4.5rem; }

#about-section .section-title {
  font-size: 2.25rem;
  margin-bottom: 1.25rem;
  display: block;
}
#about-section .section-title .accent { color: #5cb7b9; }

/* paragraph blocks */
#about-section .about-lead {
  color: #6b6b6b;
  line-height: 1.8;
  margin-bottom: 1rem;
  max-width: 680px;
}

/* bullet list */
#about-section .about-list {
  margin-top: 1rem;
  padding-left: 1.25rem;
  list-style: disc;
  color: #444;
  line-height: 1.7;
}
#about-section .about-list li { margin-bottom: 0.75rem; }

/* stats grid */
.about-stats-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
}

/* each card */ /*about me blocks */
.stat-card {
  background: #fff;
  border-radius: 10px;
  padding: 26px 20px;
  text-align: center;
  border: 1px solid rgba(0,0,0,0.06);
  box-shadow: 0 6px 22px rgba(34,34,34,0.03);
  min-height: 130px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

/* icon block */
.stat-icon {
  font-size: 28px;
  color: #333;
  margin-bottom: 10px;
  display: inline-block;
  width: 42px;
  height: 42px;
  line-height: 42px;
  border-radius: 50%;
  background: rgba(0,0,0,0.02);
}

/* number + label */
.stat-number {
  font-weight: 700;
  font-size: 22px;
  color: #222;
  margin-bottom: 6px;
}
.stat-label {
  font-size: 0.85rem;
  color: #6b6b6b;
}

/* responsive */
@media (max-width: 991.98px) {
  .about-stats-grid { grid-template-columns: 1fr 1fr; gap: 1rem; margin-top: 1.2rem; }
  #about-section .col-lg-7, #about-section .col-lg-5 { width: 100%; max-width: 100%; flex: 0 0 100%; }
  #about-section { padding-top: 3rem; padding-bottom: 3rem; }
}
@media (max-width: 576px) {
  .about-stats-grid { grid-template-columns: 1fr; }
  .stat-card { min-height: 110px; padding: 18px; }
  #about-section .about-lead { max-width: 100%; }
}

/* === ABOUT SECTION CUSTOM FONT & STYLE (Stack Sans Headline) === */

#about-section {
  font-family: 'Stack Sans Headline', sans-serif !important;
  background-color: #f9f9f9; /* light grey background for clean section contrast */
  padding-top: 5rem;
  padding-bottom: 5rem;
  color: #222;
}

/* --- Heading --- */
#about-section .section-title {
  font-weight: 700;
  font-size: 2.4rem;
  color: #111;
  margin-bottom: 1.2rem;
  letter-spacing: 0.2px;
}
#about-section .section-title .accent {
  color: #207561;
  font-weight: 700;
}

/* --- Paragraph text --- */
#about-section .about-lead {
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.9;
  color: #444;
  margin-bottom: 1.2rem;
  max-width: 700px;
}

/* --- Subheading --- */
#about-section h4 {
  font-weight: 600;
  color: #000;
  font-size: 1.2rem;
  margin-top: 1.5rem;
}

/* --- Bullet list --- */
#about-section .about-list {
  list-style: disc;
  margin-top: 1rem;
  padding-left: 1.3rem;
}
#about-section .about-list li {
  margin-bottom: 0.7rem;
  font-size: 0.95rem;
  color: #333;
  font-weight: 400;
  line-height: 1.7;
}

/* --- Stats cards layout --- */
.about-stats-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
}

.stat-card {
  background: #fff;
  border-radius: 12px;
  padding: 28px 20px;
  text-align: center;
  border: 1px solid rgba(0,0,0,0.06);
  box-shadow: 0 4px 18px rgba(0,0,0,0.04);
  transition: all 0.3s ease;
}
.stat-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 6px 20px rgba(0,0,0,0.07);
}

/* --- Icons and text inside cards --- */
.stat-icon {
  font-size: 30px;
  color: #207561;
  margin-bottom: 10px;
}

.stat-number {
  font-weight: 700;
  font-size: 1.4rem;
  color: #000;
  letter-spacing: 0.3px;
}

.stat-label {
  font-size: 0.85rem;
  color: #666;
  font-weight: 400;
  margin-top: 3px;
}

/* --- Responsive adjustments --- */
@media (max-width: 991.98px) {
  .about-stats-grid {
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin-top: 1.5rem;
  }
}
@media (max-width: 576px) {
  .about-stats-grid {
    grid-template-columns: 1fr;
  }
  .stat-card {
    min-height: 110px;
    padding: 18px;
  }
}
/* === About section — force Stack Sans Headline and sensible weights === */
#about-section,
#about-section * {
  font-family: 'Stack Sans Headline', sans-serif !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* make body text regular weight so it doesn't appear too bold */
#about-section,
#about-section p,
#about-section .about-lead,
#about-section .about-list,
#about-section .about-list li,
#about-section .stat-label {
  font-weight: 400 !important;
  color: #444 !important;
}

/* headings: tuned weights and sizes, 'About design By' */
#about-section .section-title,
#about-section h2,
#about-section h1 {
  font-family: 'Stack Sans Headline', sans-serif !important;
  font-weight: 550 !important;    /* strong for main section title */
  font-size: 2.4rem !important;
  letter-spacing: 0.2px !important;
  color: #000000 !important;
}

/* subheading (My Design Philosophy) */
#about-section h4,
#about-section .subheading {
  font-family: 'Stack Sans Headline', sans-serif !important;
  font-weight: 400 !important;
  font-size: 1.1rem !important;
  margin-top: 1.2rem !important;
  color: #111 !important;
}

/* bullets and small text keep normal weight */
#about-section .about-list li {
  font-weight: 400 !important;
  color: #333 !important;
  line-height: 1.7 !important;
}

/* stats card numbers slightly bolder but not heavy */
.stat-number {
  font-weight: 600 !important;
}

/* if some global rule still forces Arbutus Slab on h-tags, override it explicitly */
#about-section h1,
#about-section h2,
#about-section h3,
#about-section h4,
#about-section h5,
#about-section h6 {
  font-family: 'Stack Sans Headline', sans-serif !important;
}

/* Responsive tweak (smaller heading sizes on mobile) */
@media (max-width: 991.98px) {
  #about-section .section-title {
    font-size: 1.8rem !important;
  }
}

/* ===== About-section exact look =====
   Paste at the bottom of css/style.css
   Requires the Stack Sans Headline font link in <head>
*/

#about-section {
  background: transparent;
  padding-top: 6rem;    /* spacing from header */
  padding-bottom: 6rem;
  font-family: 'Stack Sans Headline', sans-serif;
  color: #333;
}

/* grid: left text + right stats column */
#about-section .about-grid {
  display: grid;
  grid-template-columns: 1fr 420px;    /* left flexible / right fixed */
  gap: 48px;
  align-items: start;
  max-width: 1180px;
  margin: 0 auto;
}

/* Left column (copy, subheading, bullets) */
#about-section .about-left {
  max-width: 580px;   /* reduced text width for better readability */
  margin-left: 0;     /* remove extra left margin */
  padding-left: 0;    /* move text closer to the left */
}

/* Title style */
#about-section .section-title {
  font-size: 36px;
  line-height: 1.05;
  margin: 0 0 22px 0;
  font-weight: 700;
  color: #000000;
}

/* accent for the small AK color */
#about-section .section-title .accent {
  color: #28b0a9;  /* teal accent */
}

/* paragraphs */
#about-section .about-lead {
  font-size: 15px;
  line-height: 1.8;
  color: #6b6b6b;
  margin-bottom: 18px;
  font-weight: 400;
}

/* subheading My Design Philosophy */
#about-section .subheading {
  font-size: 18px;
  margin-top: 26px;
  margin-bottom: 14px;
  color: #111;
  font-weight: 600;
}

/* bullet list */
#about-section .about-list {
  list-style: disc;
  padding-left: 22px;
  margin: 0;
  color: #555;
}
#about-section .about-list li {
  margin-bottom: 12px;
  font-size: 14px;
  line-height: 1.6;
  font-weight: 400;
}

/* === Right column: stats cards (2 x 2) === */
#about-section .about-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-auto-rows: 150px;
  gap: 20px;
}

/* card look */
#about-section .stat-card {
  background: #fff;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,0.06);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 18px;
  box-shadow: 0 8px 18px rgba(0,0,0,0.03);
}

/* icon area (use your icon fonts or images) */
#about-section .stat-card .stat-icon {
  font-size: 42px;              /* increase icon size */
  color: #0b1b17;               /* icon color */
  margin-bottom: 12px;          /* spacing below icon */
  opacity: 0.9;                 /* subtle tone */
  transition: transform 0.3s ease, color 0.3s ease; /* smooth hover effect */
}

#about-section .stat-card:hover .stat-icon {
  transform: scale(1.1);        /* slight zoom on hover */
  color: #207561;               /* accent color on hover */
}

/* big number */
#about-section .stat-card .stat-number {
  font-size: 20px;
  font-weight: 700;
  color: #000000;
  margin-bottom: 6px;
}

/* small label */
#about-section .stat-card .stat-label {
  font-size: 13px;
  color: #7a7a7a;
  line-height: 1.2;
}

/* subtle rounded corners matching screenshot */
#about-section .stat-card {
  border-radius: 12px;
}

/* remove any heavy default heading serif in this section */
#about-section h1, #about-section h2, #about-section h3, #about-section h4, 
#about-section h5, #about-section h6, #about-section p, 
#about-section ul, #about-section li {
  font-family: 'Stack Sans Headline', sans-serif !important;
}

/* responsive: collapse to single column on small screens */
@media (max-width: 992px) {
  #about-section .about-grid {
    grid-template-columns: 1fr;
    gap: 30px;
    padding-top: 3.5rem;
    padding-bottom: 3.5rem;
  }
  #about-section .about-stats {
    grid-template-columns: 1fr 1fr;
    grid-auto-rows: auto;
  }
  #about-section .stat-card { padding: 16px; min-height: 110px; }
  #about-section .section-title { font-size: 28px; }
  #about-section .about-lead { font-size: 15px; }
}

/* extra polish: exact spacing under page edge like screenshot */
#about-section { background-color: #fbfcfc; } /* very light subtle background */

/* === Match About section font to hero ("Hi, I am AnandaKrishnan N") === */

/* === ABOUT SECTION: remove underline, control boxes position & size === */


/* 2) Placement: move the stats grid up / down about me blocks 
   - Positive margin-top moves boxes DOWN.
   - Negative margin-top moves boxes UP (closer to the heading).
   Change the value below to tune vertical placement. */
#about-section .about-stats {
  margin-top: 75px; /* hight adjust*/
  margin-left: -50px;            /* <-- tweak this (e.g. -24px to raise more, 20px to lower) */
  display: grid;
  grid-template-columns: repeat(2, 260px); /* two columns, each fixed width */
  gap: 20px;
  justify-content: center;      /* center the two-column grid inside the right column */
  align-items: start;
}

/* 3) Size control for each box */
#about-section .stat-card {
  width: 250px;                 /* <-- change width as needed (e.g. 240px, 200px) */
  height: 140px;                /* <-- change height as needed (e.g. 150px, 120px) */
  padding: 18px;
  box-shadow: 0 8px 18px rgba(0,0,0,0.03);
  border: 1px solid rgba(0,0,0,0.06);
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
}

/* keep contents responsive inside the boxes (icon / number / label) */
#about-section .stat-card .stat-icon { font-size: 24px; margin-bottom: 8px; }
#about-section .stat-card .stat-number { font-size: 20px; font-weight: 700; }
#about-section .stat-card .stat-label { font-size: 13px; color: #7a7a7a; }

/* 4) Responsive fallback — stack boxes for narrow screens */
@media (max-width: 992px) {
  #about-section .about-stats {
    grid-template-columns: 1fr 1fr; /* let them use available space on smaller screens */
    margin-top: 12px;               /* tweak mobile spacing separately if needed */
    gap: 14px;
  }
  #about-section .stat-card {
    width: auto;
    height: auto;
    min-height: 110px;
    padding: 16px;
  }
}

/* === About Section: Darken bullets and "My Design Philosophy" subheading === */

/* Darker, more visible subheading */
#about-section .subheading {
  color: #0a0a0a !important;   /* almost black */
  font-weight: 700 !important; /* make bolder */
}

/* Darker bullet points and text */
#about-section .about-list li {
  color: #222 !important;      /* dark gray / near black */
  font-weight: 500 !important; /* slightly stronger weight */
  letter-spacing: 0.2px;       /* subtle polish */
}

/* Optional: make bullet icons themselves darker (not just text) */
#about-section .about-list {
  color: #111 !important;      /* darken the bullet color */
}
#about-section .about-list li::marker {
  font-size: 1.2em;                /* increase bullet size (1em = normal) */ 
}

/* Move About section text toward the left */
#about-section .about-left {
  margin-left: 0 !important;   /* remove any existing margin */
  padding-left: 0 !important;  /* remove internal padding */
}

/* Optional: fine control */
#about-section .about-left {
  transform: translateX(-20px); /* move 20px more to the left (adjust as needed) */
}

/* ---------- Portfolio grid (custom) ---------- */
#portfolio-section .section-subhead {
  color: #7a7a7a;
  max-width: 820px;
  margin: 0 auto 24px;
  font-size: 0.95rem;
  line-height: 1.6;
}

.filters {
  display: inline-flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}
.filters .filter-btn {
  border-radius: 30px;
  padding: 8px 16px;
  border: 1px solid rgba(0,0,0,0.08);
  background: #fff;
  color: #222;
  font-weight: 500;
  box-shadow: none;
}
.filters .filter-btn.active,
.filters .filter-btn:hover {
  background: #000;
  color: #fff;
  border-color: #000;
  transform: translateY(-2px);
}

/* Portfolio card */
.portfolio-card {
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,0.06);
  -webkit-box-shadow: 0 8px 28px rgba(0,0,0,0.04);
  box-shadow: 0 8px 28px rgba(0,0,0,0.04);
  display: flex;
  flex-direction: column;
  height: 100%;
}

/* image */
.portfolio-thumb {
  display: block;
  overflow: hidden;
  width: 100%;
  border-bottom: 1px solid rgba(0,0,0,0.03);
}
.portfolio-thumb img {
  width: 100%;
  height: 210px;
  object-fit: cover;
  display: block;
  transition: transform .45s ease;
}
.portfolio-card:hover .portfolio-thumb img {
  transform: scale(1.03);
}

/* body */
.portfolio-body {
  padding: 18px 18px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1 1 auto;
}
.portfolio-title {
  font-size: 1.05rem;
  margin: 0 0 6px;
  color: #111;
  font-weight: 700;
}
.portfolio-excerpt {
  font-size: 0.9rem;
  color: #6b6b6b;
  margin: 0 0 10px;
  flex: 1 1 auto;
}

/* tags */
.portfolio-tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.tag {
  display: inline-block;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(0,0,0,0.04);
  color: #333;
  font-size: 0.8rem;
  border: 1px solid rgba(0,0,0,0.03);
}

/* view more */
.btn-view-more {
  border-radius: 30px;
  padding: 10px 24px;
  border: 1px solid rgba(0,0,0,0.07);
  background: #fff;
  color: #222;
  font-weight: 600;
}
.btn-view-more:hover { background: #000; color: #fff; border-color: #000; }

/* responsive */
@media (max-width: 991.98px) {
  .portfolio-thumb img { height: 180px; }
}
@media (max-width: 576px) {
  .portfolio-thumb img { height: 160px; }
  .portfolio-title { font-size: 1rem; }
}

/* keep consistent gap for grid rows */
.portfolio-grid > .col-lg-4 { display: flex; align-items: stretch; }

/*contact*/
/* ===== CONTACT SECTION — replace previous contact styles with this block ===== */

#contact-section { padding: 2rem 0; font-family: 'Stack Sans Headline', sans-serif; color: #222; background: #fff; 
scroll-margin-top: 84px;
}


#contact-section .section-title {
  font-size: 2.2rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
  text-align: center;
}

#contact-section .lead {
  text-align: center;
  max-width: 720px;
  margin: 0.5rem auto 2.5rem;
  color: #777;
  font-size: 0.85rem;
}

/* Left card */
#contact-section .contact-card {
  background: #fff;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,0.04);
  box-shadow: 0 6px 28px rgba(20,20,20,0.03);
  padding: 28px;
}

/* Form controls inside contact */
#contact-section .contact-form .form-control {
  height: 30px;
  border-radius: 8px;
  border: 1px solid rgba(0,0,0,0.08);
  padding: 10px 12px;
  font-size: 0.95rem;
  background: #fbfbfb;
}
#contact-section .contact-form select.form-control { height: 44px; }

#contact-section .contact-form textarea.form-control {
  min-height: 120px;
  resize: vertical;
  padding-top: 10px;
}

/* button */
#contact-section .contact-form .btn {
  border-radius: 8px;
  padding: 12px 18px;
  font-weight: 600;
  font-size: 0.95rem;
}

/* Right column: contact info */
#contact-section .contact-info { padding-left: 30px; }
#contact-section .contact-info h4 { font-size: 1.1rem; margin-bottom: 8px; }
#contact-section .contact-info .muted { color: #7a7a7a; font-size: 0.95rem; }

/* each contact row */
#contact-section .contact-item {
  display: flex;
  gap: 12px;
  align-items: center;
  margin-top: 18px;
}
#contact-section .contact-item .ci-icon {
  min-width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(0,0,0,0.04);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
}
#contact-section .contact-item .ci-text .ci-label {
  font-size: 0.85rem;
  color: #666;
}
#contact-section .contact-item .ci-text .ci-value {
  font-size: 0.98rem;
  color: #111;
}

/* social icons row */
#contact-section .social-icons a.social-circle {
  display: inline-block;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(0,0,0,0.04);
  margin-right: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* availability box */
#contact-section .availability-box {
  margin-top: 22px;
  border-radius: 10px;
  background: rgba(0,0,0,0.03);
  padding: 14px;
}
#contact-section .availability-box h6 {
  margin: 0 0 6px 0; font-weight: 700;
}
#contact-section .availability-box p { margin: 0; color: #666; font-size: 0.92rem; }

/* responsive */
@media (max-width: 991.98px) {
  #contact-section .contact-info { padding-left: 0; margin-top: 30px; }
  #contact-section .contact-card { padding: 20px; }
}

/* ===== Minimal Footer (replace old footer styles) ===== */
.footer-minimal {
  background: #f9f9f9;
  border-top: 1px solid rgba(0,0,0,0.05);
  padding-top: 2.5rem;
  padding-bottom: 2rem;
  font-family: 'Roboto', sans-serif;
  font-size: 0.92rem;
  color: #444;
}

.footer-minimal .footer-logo-img {
  height: 28px;
  width: auto;
}

.footer-minimal .footer-logo-text {
  font-weight: 600;
  font-size: 1rem;
  color: #222;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.footer-minimal .footer-logo-text span {
  color: #1ba37a; /* accent color for AK */
}

.footer-minimal .footer-description {
  color: #666;
  font-size: 0.9rem;
  margin-top: 0.25rem;
}

/* Center Navigation */
.footer-nav a {
  color: #444;
  font-weight: 500;
  text-decoration: none;
  margin: 0 10px;
  transition: color 0.2s ease;
}
.footer-nav a:hover {
  color: #1ba37a;
}
.footer-top-link {
  font-size: 0.88rem;
  color: #333;
  text-decoration: none;
}
.footer-top-link:hover {
  color: #1ba37a;
}

/* Right credit area */
.footer-credit {
  font-size: 0.88rem;
  color: #777;
  margin-bottom: 0.25rem;
}
.footer-credit strong {
  color: #1ba37a;
}

/* Responsive */
@media (max-width: 991px) {
  .footer-minimal {
    text-align: center;
  }
  .footer-nav {
    margin-bottom: 8px;
  }
}

/* Reduce space between "About Design By AK" and paragraph */
#about-section .section-title {
  margin-bottom: 6px; /* try 5–10px until you like the distance */
}

#about-section .about-lead:first-of-type {
  margin-top: 0;
}

/* FORCE override for About section typography (place at EOF of style.css) */
#about-section .section-title,
#about-section h2.section-title {
  font-size: 30px !important;
  font-weight: 600 !important;
  line-height: 1.15 !important;
  margin-bottom: 8px !important;
}

#about-section .about-lead,
#about-section p.about-lead {
  font-size: 14px !important;
  font-weight: 275 !important;
  color: #555 !important;
  line-height: 1.6 !important;
  margin-top: 0 !important;
  margin-bottom: 1rem !important;
}
/* bullet list */
#about-section .about-list {
  margin-top: 1rem;
  padding-left: 1.25rem;
  list-style: disc;
  color: #555;
  font-size: 14px;
  font-weight: 275;
  line-height: 1.5;
}
#about-section .about-list li {
  margin-bottom: 0.4rem;  /* reduced spacing between bullets */
  line-height: 1.5;       /* cleaner spacing */
}
/* === SMALL, LIGHT PORTFOLIO TAG BOXES === */

.portfolio-item .tags {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;             /* small space between boxes */
  margin-top: 6px;      /* small space above tag group */
}

.portfolio-item .tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;

  /* size */
  font-size: 10.5px;    /* smaller text */
  line-height: 1.2;
  padding: 2px 8px;     /* smaller pill box */
  border-radius: 14px;

  /* color + feel */
  background: #f4f4f4;  /* light grey box */
  color: #444;          /* soft dark text */
  font-weight: 400;     /* lighter text */
}
.portfolio-item {
  height: 380px; /* or whatever fits your layout */
}
/* --- Fix image height inside portfolio cards --- */
.portfolio-item {
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* Always keep image height fixed */
.portfolio-item img {
  width: 100%;
  height: 200px;       /* fixed height */
  object-fit: cover;   /* crop nicely without distortion */
  flex-shrink: 0;      /* prevent it from shrinking */
  display: block;
}

/* Make content fill remaining space */
.portfolio-item .portfolio-body {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 16px 18px 18px;
  background: #fff;
  border-radius: 0 0 10px 10px;
}






/* ====== Mobile / Responsive fixes (added) ====== */

/* Ensure header logo isn't absolutely placed on small screens */
.site-logo-wrap {
  position: absolute;
  left: 16%;
  top: 45%;
  transform: translateY(-50%);
}
@media (max-width: 991.98px) {
  .site-logo-wrap {
    position: static !important;
    left: auto !important;
    top: auto !important;
    transform: none !important;
    text-align: center;
    padding: 8px 0;
    margin: 0 auto;
  }

  /* Remove the big right padding that caused overflow on small screens */
  .nav-wrap {
    padding-right: 0 !important;
  }

  /* Show a compact mobile menu toggle (left or right) */
  .site-menu-toggle {
    display: inline-block;
    font-size: 22px;
    cursor: pointer;
    color: #000;
    position: absolute;
    right: 16px;
    top: 12px;
    z-index: 2200;
  }

  /* Make sure the desktop menu is hidden and mobile menu can be used */
  .site-navbar .site-navigation .site-menu.d-none.d-lg-block {
    display: none !important;
  }

  /* Let mobile menu occupy full height and keep it off-canvas until toggled by JS (existing scripts) */
  .site-mobile-menu {
    width: 80%;
    max-width: 320px;
    transform: translateX(110%);
  }

  /* Reduce hero height on small screens so content doesn't get pushed off */
  .site-blocks-cover, .site-blocks-cover > .container, .site-blocks-cover > .container > .row {
    min-height: 420px;
    height: auto;
    padding-top: 2.5rem;
    padding-bottom: 2.5rem;
  }

  /* Improve hero text sizing */
  .text-intro h1:first-child { font-size: 1.1rem; }
  .text-intro h1:nth-child(2) { font-size: 1.6rem; }
  .text-intro .lead { font-size: 0.95rem; max-width: 100%; margin: 1rem auto; }

  /* Scale face image down (already present, but reinforce) */
  .img-face { width: 200px; height: 200px; transform: none; margin-top: 18px; }

  /* Fix portfolio card image heights so they don't overflow on narrow screens */
  .item a img, .portfolio-thumb img, .portfolio-card img {
    height: 180px !important;
    object-fit: cover !important;
  }

  /* Make the header padding consistent and avoid overlaps */
  .site-navbar { padding-top: 10px !important; padding-bottom: 10px !important; position: relative; }

  /* Stack the hero columns */
  .hero-flex { flex-direction: column-reverse !important; align-items: center; text-align: center; }

  /* Make the mobile menu body scrollable and avoid double-scrollbars */
  .site-mobile-menu .site-mobile-menu-body { -webkit-overflow-scrolling: touch; overflow-y: auto; }

  /* Reduce large gaps in About section */
  #about-section { padding-top: 2.2rem; padding-bottom: 2.2rem; }

  /* Make portfolio filters wrap better */
  .filters { flex-wrap: wrap; gap: 8px; justify-content: center; }
}

/* Small tweak: prevent horizontal overflow from generous fixed paddings */
body, html { max-width: 100%; overflow-x: hidden !important; }




/* ====== Mobile fixes: header, profile circle, about spacing ====== */
/* Placed at EOF to override previous rules */
@media (max-width: 991.98px) {

  /* Logo left, hamburger right */
  .site-logo-wrap {
    position: absolute !important;
    left: 16px !important;
    top: 10px !important;
    transform: none !important;
    z-index: 2300 !important;
    display: flex !important;
    align-items: center !important;
  }
  .site-logo-wrap .site-logo a, .site-logo img, .logo-img {
    display: inline-block;
    height: 30px !important;
    width: auto !important;
  }

  .site-menu-toggle {
    position: absolute !important;
    right: 12px !important;
    top: 8px !important;
    z-index: 2300 !important;
    display: inline-block !important;
  }

  /* Add breathing room under header so content doesn't overlap the logo or hamburger */
  .site-blocks-cover {
    padding-top: 78px !important; /* adjust to match header height */
  }

  /* Make hero stay in row when there's enough width; otherwise stack neatly */
  .hero-flex {
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    text-align: left !important;
  }

  /* Ensure profile image is a perfect circle and not cropped */
  .img-face {
    width: 120px !important;
    height: 120px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
    aspect-ratio: 1 / 1 !important;
    transform: none !important;
    margin: 0 !important;
    box-shadow: 0 6px 20px rgba(0,0,0,0.08) !important;
    border: 4px solid #ffffff !important;
    display: block !important;
  }

  /* Make sure the right column aligns the circle to the right, not centered or cropped */
  .hero-flex > .col-lg-6.d-flex.justify-content-center {
    justify-content: flex-end !important;
    padding-right: 12px !important;
  }

  /* Remove the translateY that previously shifted the image up (causing it to be cut) */
  .hero-flex .img-face {
    transform: none !important;
    top: auto !important;
  }

  /* About section: tighten and left-align text for mobile */
  #about-section {
    padding-top: 2.8rem !important;
    padding-bottom: 2.8rem !important;
  }
  #about-section .about-left {
    padding-left: 14px !important;
    padding-right: 14px !important;
    margin-left: 0 !important;
    transform: none !important;
  }
  #about-section .section-title {
    font-size: 1.6rem !important;
    margin-bottom: 0.6rem !important;
  }
  #about-section .about-lead {
    max-width: 100% !important;
    font-size: 0.95rem !important;
  }
}

/* Very small screens: stack vertically but keep circle visible and centered */
@media (max-width: 420px) {
  .hero-flex {
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
  }
  .site-logo-wrap { left: 12px !important; top: 8px !important; }
  .site-menu-toggle { right: 10px !important; top: 8px !important; }

  .img-face { width: 110px !important; height: 110px !important; margin-top: 12px !important; }
  .text-intro h1.changing-text { font-size: 1.9rem !important; line-height: 1.05 !important; }
  .text-intro .lead { font-size: 0.95rem !important; padding: 0 12px !important; }
}
/* ===== FINAL MOBILE ALIGNMENT PATCH =====
   Append this block at the end of your style.css (or replace previous mobile patches).
*/

/* Keep header fixed and ensure logo/menu sit correctly */
@media (max-width: 991.98px) {
  .site-navbar {
    position: fixed !important;
    top: 0;
    left: 0;
    right: 0;
    z-index: 4000 !important;
    background: #ffffff !important;
    border-bottom: 1px solid rgba(0,0,0,0.06) !important;
    padding-top: 8px !important;
    padding-bottom: 8px !important;
  }

  /* Logo left */
  .site-logo-wrap {
    position: fixed !important;
    left: 14px !important;
    top: 8px !important;
    transform: none !important;
    z-index: 4100 !important;
    display: flex !important;
    align-items: center !important;
  }
  .site-logo-wrap .site-logo a img,
  .site-logo img,
  .logo-img {
    height: 30px !important;
    width: auto !important;
    display: inline-block !important;
  }

  /* Hamburger right */
  .site-menu-toggle {
    position: fixed !important;
    right: 12px !important;
    top: 8px !important;
    z-index: 4100 !important;
    display: inline-block !important;
  }

  /* Reserve space for fixed header so content doesn't jump under it */
  body { padding-top: 64px !important; }

  /* Hero area: allow overflow so circular image can sit partially outside */
  .site-blocks-cover { padding-top: 12px !important; overflow: visible !important; }
  .site-blocks-cover .container { overflow: visible !important; }

  /* Use a two-column flex for hero on mobile widths with text left and image right */
  .hero-flex {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    text-align: left !important;
  }

  /* Text column: take the remaining width */
  .hero-flex .text-intro {
    flex: 1 1 58% !important;
    padding-right: 12px !important;
    min-width: 0 !important; /* prevents overflow from long lines */
  }
  .text-intro h1:first-child { margin-bottom: 0.15rem !important; font-size: 1.02rem !important; }
  .text-intro h1.changing-text { font-size: 2.2rem !important; line-height: 1.02 !important; color: #207561 !important; font-weight:700 !important; }
  .text-intro .lead { font-size: 0.95rem !important; color: #555 !important; margin-top: 0.9rem !important; }

  /* Image column: align right, keep image visible (not cropped) */
  .hero-flex > .col-lg-6.d-flex.justify-content-center {
    flex: 0 0 34% !important;
    display: flex !important;
    justify-content: flex-end !important;
    align-items: center !important;
    padding-right: 12px !important;
    overflow: visible !important;
  }

  /* Perfect circular image and visible */
  .img-face {
    border: 4px solid #fff !important;
    visibility: visible !important;
    opacity: 1 !important;
  }
  @media (max-width: 991.98px) {
    .img-face {
      width: 300px !important;
      height: 300px !important;
      border-radius: 50% !important;
      object-fit: cover !important;
      aspect-ratio: 1 / 1 !important;
      display: block !important;
      margin: 0 !important;
      transform: none !important;
      position: relative !important;
      right: -40px !important; /* move image 20px to the left */
      box-shadow: 0 8px 26px rgba(0,0,0,0.12) !important;
      border: 5px solid #fff !important;
      visibility: visible !important;
      opacity: 1 !important;
    }
  /* Ensure the img-face vertically centers within its column */
  .hero-flex .col-lg-6.d-flex.justify-content-center .img-face {
    align-self: center !important;
  }

  /* Portfolio button smaller on mobile */
  .btn.btn-primary { padding: 8px 18px !important; border-radius: 22px !important; font-size: 0.95rem !important; }

  /* About section spacing & alignment */
  #about-section {
    padding-top: 2.6rem !important;
    padding-bottom: 2.6rem !important;
    background-color: #f7f8f9 !important;
  }
  #about-section .about-left {
    padding-left: 14px !important;
  }
  }
  /* ===== Make mobile menu smaller and less transparent ===== */
/* ===== Make mobile menu smaller + adjustable transparency ===== */
@media (max-width: 991.98px) {

  /* Limit overall menu height */
  .site-mobile-menu {
    width: 40% !important; 
    max-height: 40vh !important;   /* makes it shorter — adjust value as needed */
    /* overflow-y: auto !important;   /*allow scrolling if content overflows */
    border-radius: 0 12px 12px 0 !important;
  }

  /* Ensure inner body also respects height */
  .site-mobile-menu .site-mobile-menu-body {
    max-height: 75vh !important;
    overflow-y: auto !important;
    padding-bottom: 1rem !important;
  }

  /* Make menu items more compact */
  .site-mobile-menu-body ul li a {
    line-height: 1.5 !important;
    padding: 0.4rem 0 !important;
  }
}

/* For very small screens, slightly reduce further */
@media (max-width: 420px) {
  .site-mobile-menu { max-height: 70vh !important; }
  .site-mobile-menu .site-mobile-menu-body { max-height: 65vh !important; }
}

  /* Apply variable (make sure .site-mobile-menu has class .custom-opacity or change selector) */
  .site-mobile-menu,
  .site-mobile-menu.custom-opacity {
    background: rgba(255,255,255,var(--menu-opacity)) !important;
    /* other visual tweaks */
    backdrop-filter: blur(12px) !important;
    box-shadow: 0 0 25px rgba(0,0,0,0.15) !important;
    transition: background 0.2s ease-in-out !important;
  }



  .site-mobile-menu-body ul li {
    margin-bottom: 0.4rem !important;
  }

  .site-mobile-menu-body ul li a {
    font-size: 0.95rem !important;
    line-height: 1.6 !important;
    color: #222 !important;
  }

  /* Adjust close button position */
  .site-mobile-menu-close {
    top: 6px !important;
    right: 12px !important;
    font-size: 22px !important;
    color: #222 !important;
  }

  /* Prevent menu overlay from covering the whole screen unnecessarily */
  .site-mobile-menu .site-mobile-menu-body {
    max-height: 90vh !important;
    overflow-y: auto !important;
  }
}

/* You can easily tweak transparency dynamically like this:
   Example: 
   .site-mobile-menu { background: rgba(255, 255, 255, 0.85); }  -> more transparent
   .site-mobile-menu { background: rgba(255, 255, 255, 0.95); }  -> less transparent*/



/* ===== Fix: remove top line and vertically center logo + hamburger ===== */
@media (max-width: 991.98px) {
  /* hide any decorative top/bottom pseudo lines */
  .site-navbar::before,
  .site-navbar::after,
  .sticky-wrapper::before,
  .sticky-wrapper::after {
    display: none !important;
    content: none !important;
  }

  /* enforce header height and stacking */
  .site-navbar {
    position: fixed !important;
    top: 0;
    left: 0;
    right: 0;
    height: 64px !important;
    z-index: 9999 !important;
    background: #ffffff !important;
    border-top: none !important;
    border-bottom: 1px solid rgba(0,0,0,0.06) !important;
    display: flex !important;
    align-items: center !important;
    padding: 0 12px !important;
    box-shadow: none !important;
  }

  /* center logo vertically inside header */
  .site-logo-wrap {
    position: absolute !important;
    left: 14px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    z-index: 10000 !important;
  }

  .site-logo-wrap .site-logo a img,
  .site-logo img,
  .logo-img {
    height: 30px !important;
    width: auto !important;
    display: inline-block !important;
  }

  /* center hamburger vertically inside header on the right */
  .site-menu-toggle {
    position: absolute !important;
    right: 12px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    z-index: 10000 !important;
  }

  /* ensure page content is pushed below fixed header */
  body { padding-top: 64px !important; }

  /* ensure nothing clips hero/image */
  .site-wrap, .site-blocks-cover, .hero-flex { overflow: visible !important; }
}

/* ===== Force narrower stat boxes when container uses .about-stats ===== */
@media (max-width: 991.98px) {
  /* make the container a wrapping flex so we control card widths */
  .about-stats {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 14px !important;
   
    padding-left: 60px !important;  /* adds space from left side */
    padding-right: 20px !important; /* keeps balance on both sides */
    box-sizing: border-box !important;
  }

  /* If .about-stats is a grid, neutralize column behaviour on mobile */
  .about-stats [class*="col-"] {
    width: auto !important;
    max-width: none !important;
    flex: none !important;
  }

  /* make each stat card narrower (about 48% width -> two per row with gap) */
  .about-stats .stat-card {
    flex: 0 0 calc(48% - 14px) !important;
    width: calc(48% - 14px) !important;
    max-width: calc(48% - 14px) !important;
    min-width: 120px !important;
    box-sizing: border-box !important;
    padding: 10px !important;
  }
}

/* extra-small phones: slightly narrower boxes */
@media (max-width: 420px) {
  .about-stats .stat-card {
    flex: 0 0 calc(46% - 10px) !important;
    width: calc(46% - 10px) !important;
    min-width: 110px !important;
  }
}
/* ===== Prevent menu overlapping logo (desktop only) ===== */
@media (min-width: 992px) {


  /* Reserve left space equal to logo + gap so menu won't slide under it.
     Adjust 140px to match your logo width + desired left gap. */
  .site-navbar {
    padding-left: 970px !important;
    box-sizing: border-box !important;
  }

  /* Put the nav container into a centered flex area that respects the padding */
  .nav-wrap {
    margin-left: 0 !important;
    width: calc(100% - 140px) !important; /* leave space for logo */
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    box-sizing: border-box !important;
  }

  /* Keep the UL centered inside the nav-wrap */
  .site-navbar .site-navigation .site-menu {
    margin: 0 auto !important;
    display: inline-flex !important;
    gap: 18px !important;
  }
}
/* REMOVE HEADER BOTTOM LINE */
.site-navbar::after {
  height: 0 !important;
  background: transparent !important;
}