/*------------------------------------------------
*
*
* Table of Contents:
* 1.  Backgrounds
* 2.  Base
* 3.  Form
* 4.  Images
* 5.  Lists
* 6.  Typography
* 7.  Accordion
* 8.  Box
* 9.  Buttons
* 10. Circle Text
* 11. Clients
* 12. Gadgets
* 13. Lightbox
* 14. Link hovers
* 15. Maps
* 16. Process box
* 17. Progress bars
* 18. Sliders
* 19. Team
* 20. Testimonial
* 21. Text Highlights
* 22. Title fade
* 23. Border Grid
* 24. Fullscreen Menu
* 25. Header
* 26. Portfolio
* 27. Preloader
* 28. Utilities
*
-------------------------------------------------*/
@import url("https://fonts.googleapis.com/css2?family=Open+Sans:wght@300;400;500;600;700&family=Outfit:wght@200;300;400;500;600;700;800&family=Lora:wght@400;500;600;700&family=Poppins:ital,wght@0,200;0,300;0,400;0,500;0,600;0,700;0,800;1,200;1,300;1,400;1,500;1,600;1,700;1,800&display=swap");
/*------------------------------------------------
  1. Background
-------------------------------------------------*/
.bg-image {
  position: relative;
  background-position: center center;
  background-attachment: scroll;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  background-size: cover;
  background-repeat: no-repeat;
}

/* Mobile optimization for background images */
@media (max-width: 991.98px) {
  .bg-image {
    background-size: cover;
    background-attachment: scroll;
    /* Force better quality rendering on mobile */
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
    /* Ensure proper scaling */
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
  
  /* Specific fix for Ready to Upgrade section */
  .bg-image.parallax[data-bg-src*="iphone-17.jpg"] {
    background-size: cover !important;
    background-position: center center !important;
    min-height: 400px;
    /* Better quality rendering */
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    -webkit-perspective: 1000;
    perspective: 1000;
  }
}

/* High DPI mobile optimization - moved outside to avoid nesting */
@media (max-width: 991.98px) and (-webkit-min-device-pixel-ratio: 2), 
       (max-width: 991.98px) and (min-resolution: 192dpi) {
  .bg-image {
    /* Improve image quality on retina displays */
    image-rendering: -webkit-optimize-contrast;
    image-rendering: optimize-contrast;
    image-rendering: crisp-edges;
  }
}

.bg-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}

.bg-video video {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.bg-pattern-diagonal {
  position: relative;
  overflow: hidden;
}

.bg-pattern-diagonal:before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: transparent;
  opacity: 0.08;
  background-size: 10px 10px;
  background-image: repeating-linear-gradient(45deg, #1c1d24 0, #1c1d24 1px, transparent 0, transparent 50%);
}

.bg-pattern-polka {
  position: relative;
  overflow: hidden;
}

.bg-pattern-polka:before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: transparent;
  opacity: 0.6;
  background-image: radial-gradient(#1c1d24 0.5px, transparent 0.5px), radial-gradient(#1c1d24 0.5px, transparent 0.5px);
  background-size: 20px 20px;
  background-position: 0 0,10px 10px;
}

/*------------------------------------------------
  2. Base
-------------------------------------------------*/
html, body {
  width: 100%;
  height: 100%;
}

body {
  overflow-x: hidden;
  position: relative;
  background: white;
  color: #787a7c;
}

main {
  position: relative;
  min-height: 100%;
}

.container,
.container-fluid {
  position: relative;
  padding: 0 30px;
}

.theme-light, body, [class*='bg-white'], [class*='bg-black'] [class*='bg-white'],
[class*='bg-dark'] [class*='bg-white'],
[class*='bg-gradient'] [class*='bg-white'] {
  color: #787a7c;
}

.theme-light h1, body h1, [class*='bg-white'] h1, [class*='bg-black'] [class*='bg-white'] h1,
[class*='bg-dark'] [class*='bg-white'] h1,
[class*='bg-gradient'] [class*='bg-white'] h1, .theme-light h2, body h2, [class*='bg-white'] h2, [class*='bg-black'] [class*='bg-white'] h2,
[class*='bg-dark'] [class*='bg-white'] h2,
[class*='bg-gradient'] [class*='bg-white'] h2, .theme-light h3, body h3, [class*='bg-white'] h3, [class*='bg-black'] [class*='bg-white'] h3,
[class*='bg-dark'] [class*='bg-white'] h3,
[class*='bg-gradient'] [class*='bg-white'] h3, .theme-light h4, body h4, [class*='bg-white'] h4, [class*='bg-black'] [class*='bg-white'] h4,
[class*='bg-dark'] [class*='bg-white'] h4,
[class*='bg-gradient'] [class*='bg-white'] h4, .theme-light h5, body h5, [class*='bg-white'] h5, [class*='bg-black'] [class*='bg-white'] h5,
[class*='bg-dark'] [class*='bg-white'] h5,
[class*='bg-gradient'] [class*='bg-white'] h5, .theme-light h6, body h6, [class*='bg-white'] h6, [class*='bg-black'] [class*='bg-white'] h6,
[class*='bg-dark'] [class*='bg-white'] h6,
[class*='bg-gradient'] [class*='bg-white'] h6, .theme-light i, body i, [class*='bg-white'] i, [class*='bg-black'] [class*='bg-white'] i,
[class*='bg-dark'] [class*='bg-white'] i,
[class*='bg-gradient'] [class*='bg-white'] i,
.theme-light .h1, body .h1, [class*='bg-white'] .h1, .theme-light .h2, body .h2, [class*='bg-white'] .h2, .theme-light .h3, body .h3, [class*='bg-white'] .h3, .theme-light .h4, body .h4, [class*='bg-white'] .h4, .theme-light .h5, body .h5, [class*='bg-white'] .h5, .theme-light .h6, body .h6, [class*='bg-white'] .h6 {
  color: #1c1d24;
}

.theme-light a:not([class^='button']):not([class^='link-hover']), body a:not([class^='button']):not([class^='link-hover']), [class*='bg-white'] a:not([class^='button']):not([class^='link-hover']) {
  color: #1c1d24;
}

.theme-light a:not([class^='button']):not([class^='link-hover']):hover, body a:not([class^='button']):not([class^='link-hover']):hover, [class*='bg-white'] a:not([class^='button']):not([class^='link-hover']):hover, .theme-light a:not([class^='button']):not([class^='link-hover']):focus, body a:not([class^='button']):not([class^='link-hover']):focus, [class*='bg-white'] a:not([class^='button']):not([class^='link-hover']):focus {
  color: rgba(28, 29, 36, 0.8);
}

.theme-dark, [class*='bg-white'] [class*='bg-black'],
[class*='bg-white'] [class*='bg-dark'],
[class*='bg-white'] [class*='bg-gradient'], [class*='bg-black'],
[class*='bg-dark'],
[class*='bg-gradient'], .interactive-box .interactive-overlay {
  color: rgba(255, 255, 255, 0.8);
}

.theme-dark h1, [class*='bg-white'] [class*='bg-black'] h1,
[class*='bg-white'] [class*='bg-dark'] h1,
[class*='bg-white'] [class*='bg-gradient'] h1, [class*='bg-black'] h1,
[class*='bg-dark'] h1,
[class*='bg-gradient'] h1, .interactive-box .interactive-overlay h1, .theme-dark h2, [class*='bg-white'] [class*='bg-black'] h2,
[class*='bg-white'] [class*='bg-dark'] h2,
[class*='bg-white'] [class*='bg-gradient'] h2, [class*='bg-black'] h2,
[class*='bg-dark'] h2,
[class*='bg-gradient'] h2, .interactive-box .interactive-overlay h2, .theme-dark h3, [class*='bg-white'] [class*='bg-black'] h3,
[class*='bg-white'] [class*='bg-dark'] h3,
[class*='bg-white'] [class*='bg-gradient'] h3, [class*='bg-black'] h3,
[class*='bg-dark'] h3,
[class*='bg-gradient'] h3, .interactive-box .interactive-overlay h3, .theme-dark h4, [class*='bg-white'] [class*='bg-black'] h4,
[class*='bg-white'] [class*='bg-dark'] h4,
[class*='bg-white'] [class*='bg-gradient'] h4, [class*='bg-black'] h4,
[class*='bg-dark'] h4,
[class*='bg-gradient'] h4, .interactive-box .interactive-overlay h4, .theme-dark h5, [class*='bg-white'] [class*='bg-black'] h5,
[class*='bg-white'] [class*='bg-dark'] h5,
[class*='bg-white'] [class*='bg-gradient'] h5, [class*='bg-black'] h5,
[class*='bg-dark'] h5,
[class*='bg-gradient'] h5, .interactive-box .interactive-overlay h5, .theme-dark h6, [class*='bg-white'] [class*='bg-black'] h6,
[class*='bg-white'] [class*='bg-dark'] h6,
[class*='bg-white'] [class*='bg-gradient'] h6, [class*='bg-black'] h6,
[class*='bg-dark'] h6,
[class*='bg-gradient'] h6, .interactive-box .interactive-overlay h6, .theme-dark i, [class*='bg-white'] [class*='bg-black'] i,
[class*='bg-white'] [class*='bg-dark'] i,
[class*='bg-white'] [class*='bg-gradient'] i, [class*='bg-black'] i,
[class*='bg-dark'] i,
[class*='bg-gradient'] i, .interactive-box .interactive-overlay i,
.theme-dark .h1, [class*='bg-black'] .h1,
[class*='bg-dark'] .h1,
[class*='bg-gradient'] .h1, .interactive-box .interactive-overlay .h1, .theme-dark .h2, [class*='bg-black'] .h2,
[class*='bg-dark'] .h2,
[class*='bg-gradient'] .h2, .interactive-box .interactive-overlay .h2, .theme-dark .h3, [class*='bg-black'] .h3,
[class*='bg-dark'] .h3,
[class*='bg-gradient'] .h3, .interactive-box .interactive-overlay .h3, .theme-dark .h4, [class*='bg-black'] .h4,
[class*='bg-dark'] .h4,
[class*='bg-gradient'] .h4, .interactive-box .interactive-overlay .h4, .theme-dark .h5, [class*='bg-black'] .h5,
[class*='bg-dark'] .h5,
[class*='bg-gradient'] .h5, .interactive-box .interactive-overlay .h5, .theme-dark .h6, [class*='bg-black'] .h6,
[class*='bg-dark'] .h6,
[class*='bg-gradient'] .h6, .interactive-box .interactive-overlay .h6 {
  color: white;
}

.theme-dark a:not([class^='button']):not([class^='link-hover']), [class*='bg-black'] a:not([class^='button']):not([class^='link-hover']),
[class*='bg-dark'] a:not([class^='button']):not([class^='link-hover']),
[class*='bg-gradient'] a:not([class^='button']):not([class^='link-hover']), .interactive-box .interactive-overlay a:not([class^='button']):not([class^='link-hover']) {
  color: white;
}

.theme-dark a:not([class^='button']):not([class^='link-hover']) i, [class*='bg-black'] a:not([class^='button']):not([class^='link-hover']) i,
[class*='bg-dark'] a:not([class^='button']):not([class^='link-hover']) i,
[class*='bg-gradient'] a:not([class^='button']):not([class^='link-hover']) i, .interactive-box .interactive-overlay a:not([class^='button']):not([class^='link-hover']) i {
  color: white;
}

.theme-dark a:not([class^='button']):not([class^='link-hover']):hover, [class*='bg-black'] a:not([class^='button']):not([class^='link-hover']):hover,
[class*='bg-dark'] a:not([class^='button']):not([class^='link-hover']):hover,
[class*='bg-gradient'] a:not([class^='button']):not([class^='link-hover']):hover, .interactive-box .interactive-overlay a:not([class^='button']):not([class^='link-hover']):hover, .theme-dark a:not([class^='button']):not([class^='link-hover']):focus, [class*='bg-black'] a:not([class^='button']):not([class^='link-hover']):focus,
[class*='bg-dark'] a:not([class^='button']):not([class^='link-hover']):focus,
[class*='bg-gradient'] a:not([class^='button']):not([class^='link-hover']):focus, .interactive-box .interactive-overlay a:not([class^='button']):not([class^='link-hover']):focus {
  color: rgba(255, 255, 255, 0.8);
}

.theme-dark a:not([class^='button']):not([class^='link-hover']):hover i, [class*='bg-black'] a:not([class^='button']):not([class^='link-hover']):hover i,
[class*='bg-dark'] a:not([class^='button']):not([class^='link-hover']):hover i,
[class*='bg-gradient'] a:not([class^='button']):not([class^='link-hover']):hover i, .interactive-box .interactive-overlay a:not([class^='button']):not([class^='link-hover']):hover i, .theme-dark a:not([class^='button']):not([class^='link-hover']):focus i, [class*='bg-black'] a:not([class^='button']):not([class^='link-hover']):focus i,
[class*='bg-dark'] a:not([class^='button']):not([class^='link-hover']):focus i,
[class*='bg-gradient'] a:not([class^='button']):not([class^='link-hover']):focus i, .interactive-box .interactive-overlay a:not([class^='button']):not([class^='link-hover']):focus i {
  color: rgba(255, 255, 255, 0.8);
}

:root {
  --bs-dark-rgb: 28, 29, 36;
  --bs-border-color: rgba(28, 29, 36, 0.1);
}

.section-fullscreen,
[class*='section-spacing'] {
  position: relative;
}

.section-fullscreen {
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.section-spacing-xl {
  padding: 140px 0;
}

.section-spacing-lg {
  padding: 60px 0;
}

.section-spacing {
  padding: 100px 0;
}

.section-spacing-sm {
  padding: 80px 0;
}

.section-spacing-xs {
  padding: 65px 0;
}

@media (max-width: 991.98px) {
  .section-spacing-xl {
    padding: 120px 0;
  }
  .section-spacing-lg {
    padding: 60px 0;
  }
  .section-spacing {
    padding: 80px 0;
  }
  .section-spacing-sm {
    padding: 60px 0;
  }
  .section-spacing-xs {
    padding: 50px 0;
  }
}

.custom-row {
  margin: -30px;
}

.custom-row .custom-col {
  padding: 30px;
}

.custom-row-lg {
  margin: -35px;
}

.custom-row-lg .custom-col {
  padding: 35px;
}

@media (max-width: 1199.98px) {
  .custom-row,
  .custom-row-lg {
    margin: -25px;
  }
  .custom-row .custom-col,
  .custom-row-lg .custom-col {
    padding: 25px;
  }
}

@media (max-width: 991.98px) {
  .custom-row,
  .custom-row-lg {
    margin: -20px;
  }
  .custom-row .custom-col,
  .custom-row-lg .custom-col {
    padding: 20px;
  }
}

@media (max-width: 767.98px) {
  .custom-row,
  .custom-row-lg {
    margin: -15px;
  }
  .custom-row .custom-col,
  .custom-row-lg .custom-col {
    padding: 15px;
  }
}

hr.hr-diagonal {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 8px;
  border: 0;
  margin: 0;
}

hr.hr-diagonal:before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: transparent;
  opacity: 0.5;
  background-size: 5px 5px;
  background-image: repeating-linear-gradient(45deg, #1c1d24 0, #1c1d24 1px, transparent 0, transparent 50%);
}

[class*='bg-black'] hr.hr-diagonal:before,
[class*='bg-dark'] hr.hr-diagonal:before,
[class*='bg-gradient'] hr.hr-diagonal:before {
  opacity: 0.8;
  background-image: repeating-linear-gradient(45deg, white 0, white 1px, transparent 0, transparent 50%);
}

/*------------------------------------------------
  3. Forms
-------------------------------------------------*/
input,
textarea {
  background: #f1f2fa;
  width: 100%;
  border: 0;
  margin-bottom: 1rem;
  padding: 15px 20px;
  border-radius: 0;
  box-shadow: none;
  font: 400 16px "Helvetica Neue", Helvetica, Arial, sans-serif;
  -webkit-transition: ease-out 0.16s;
  transition: ease-out 0.16s;
}

input:focus, input:active,
textarea:focus,
textarea:active {
  outline: 0;
  box-shadow: none;
}

textarea {
  height: 80px;
}

input, textarea {
  color: #787a7c;
}

input::-webkit-input-placeholder, textarea::-webkit-input-placeholder {
  color: #aaabac;
}

input::-moz-placeholder, textarea::-moz-placeholder {
  color: #aaabac;
}

input:-ms-placeholder, textarea:-ms-placeholder {
  color: #aaabac;
}

input::-ms-placeholder, textarea::-ms-placeholder {
  color: #aaabac;
}

input::placeholder, textarea::placeholder {
  color: #aaabac;
}

label {
  font-size: 15px;
}

.form-border-radius input, .form-border-radius textarea {
  border-radius: 0.5em;
}

.form-style-2 input, .form-style-2 textarea {
  background: transparent;
  margin-bottom: 24px;
  padding: 0 0 14px;
  border-top-width: 0;
  border-right-width: 0;
  border-bottom: 1px solid rgba(28, 29, 36, 0.2);
  border-left-width: 0;
}

.form-style-2 input:focus, .form-style-2 input:active, .form-style-2 textarea:focus, .form-style-2 textarea:active {
  border-bottom-color: #1c1d24;
}

.bg-gray input,
.bg-gray textarea,
.bg-iceblue input,
.bg-iceblue textarea {
  background: white;
}

[class*='bg-black'] input, [class*='bg-black'] textarea,
[class*='bg-dark'] input,
[class*='bg-dark'] textarea,
[class*='bg-gradient'] input,
[class*='bg-gradient'] textarea {
  color: rgba(255, 255, 255, 0.8);
}

[class*='bg-black'] input::-webkit-input-placeholder, [class*='bg-black'] textarea::-webkit-input-placeholder,
[class*='bg-dark'] input::-webkit-input-placeholder,
[class*='bg-dark'] textarea::-webkit-input-placeholder,
[class*='bg-gradient'] input::-webkit-input-placeholder,
[class*='bg-gradient'] textarea::-webkit-input-placeholder {
  color: rgba(255, 255, 255, 0.4);
}

[class*='bg-black'] input::-moz-placeholder, [class*='bg-black'] textarea::-moz-placeholder,
[class*='bg-dark'] input::-moz-placeholder,
[class*='bg-dark'] textarea::-moz-placeholder,
[class*='bg-gradient'] input::-moz-placeholder,
[class*='bg-gradient'] textarea::-moz-placeholder {
  color: rgba(255, 255, 255, 0.4);
}

[class*='bg-black'] input:-ms-placeholder, [class*='bg-black'] textarea:-ms-placeholder,
[class*='bg-dark'] input:-ms-placeholder,
[class*='bg-dark'] textarea:-ms-placeholder,
[class*='bg-gradient'] input:-ms-placeholder,
[class*='bg-gradient'] textarea:-ms-placeholder {
  color: rgba(255, 255, 255, 0.4);
}

[class*='bg-black'] input::-ms-placeholder, [class*='bg-black'] textarea::-ms-placeholder,
[class*='bg-dark'] input::-ms-placeholder,
[class*='bg-dark'] textarea::-ms-placeholder,
[class*='bg-gradient'] input::-ms-placeholder,
[class*='bg-gradient'] textarea::-ms-placeholder {
  color: rgba(255, 255, 255, 0.4);
}

[class*='bg-black'] input::placeholder, [class*='bg-black'] textarea::placeholder,
[class*='bg-dark'] input::placeholder,
[class*='bg-dark'] textarea::placeholder,
[class*='bg-gradient'] input::placeholder,
[class*='bg-gradient'] textarea::placeholder {
  color: rgba(255, 255, 255, 0.4);
}

.submit-result span {
  display: none;
  -webkit-transition: ease-out 0.2s;
  transition: ease-out 0.2s;
}

.submit-result span.show-result {
  margin-top: 24px;
  display: block;
}

.submit-result span#success {
  color: #32CD32;
}

.submit-result span#error {
  color: #E32227;
}

.submit-result span .error-color {
  background: rgba(255, 0, 0, 0.1);
}

/*------------------------------------------------
  4. Images
-------------------------------------------------*/
img {
  width: auto;
  max-width: 100%;
  height: auto;
}

.img-mask-1 {
  border-top-left-radius: 4em;
  border-bottom-right-radius: 4em;
}

.img-mask-2 {
  border-top-right-radius: 4em;
  border-bottom-left-radius: 4em;
}

.img-avatar-200 {
  width: 200px;
  height: 200px;
  border-radius: 50%;
}

.img-avatar-180 {
  width: 180px;
  height: 180px;
  border-radius: 50%;
}

.img-avatar-160 {
  width: 160px;
  height: 160px;
  border-radius: 50%;
}

.img-avatar-80 {
  width: 80px;
  height: 80px;
  border-radius: 50%;
}

.img-avatar-70 {
  width: 70px;
  height: 70px;
  border-radius: 50%;
}

.img-avatar-60 {
  width: 60px;
  height: 60px;
  border-radius: 50%;
}

.avatar-group {
  display: block;
  padding: 0;
}

.avatar-group li {
  list-style-type: none;
  display: inline-block;
  margin-left: -12px;
  padding: 0;
}

.avatar-group li:first-child {
  margin-left: 0;
}

.avatar-group li img {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  -webkit-box-shadow: 0 3px 16px 0 rgba(0, 0, 0, 0.13);
  box-shadow: 0 3px 16px 0 rgba(0, 0, 0, 0.13);
  border: 3px solid white;
}

.img-overlap {
  z-index: 1;
  position: relative;
}

.img-overlap .img-1 {
  padding-top: 60px;
  max-width: 55%;
}

.img-overlap .img-2 {
  z-index: -1;
  position: absolute;
  top: 0;
  right: 0;
  max-width: 60%;
}

.img-overlap img {
  -webkit-box-shadow: 0 8px 34px 0 rgba(22, 24, 26, 0.1);
  box-shadow: 0 8px 34px 0 rgba(22, 24, 26, 0.1);
}

.img-link-box {
  position: relative;
  overflow: hidden;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

.img-link-box a {
  display: block;
}

.img-link-box img {
  -webkit-transform: scale(1);
  transform: scale(1);
  width: 100%;
  -webkit-transition: transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.img-link-box:hover img {
  -webkit-transform: scale(1.04);
  transform: scale(1.04);
}

/*------------------------------------------------
  5. Lists
-------------------------------------------------*/
ul {
  margin: 0;
}

ul li a {
  -webkit-transition: linear 0.1s;
  transition: linear 0.1s;
}

ul[class*=' list-'], ul[class^='list-'] {
  padding: 0;
}

ul.list-unstyled li {
  list-style-type: none;
  margin-bottom: 6px;
}

ul.list-unstyled li:last-child {
  margin-bottom: 0;
}

ul.list-dash li {
  list-style-type: none;
  margin-bottom: 6px;
}

ul.list-dash li:before {
  content: '-';
  padding-right: 7px;
}

ul.list-dash li:last-child {
  margin-bottom: 0;
}

ul.list-border-dashed li {
  list-style-type: none;
  padding: 12px 0;
  border-bottom: 1px dashed rgba(28, 29, 36, 0.2);
}

ul.list-border-dashed li:last-child {
  border-bottom: 0;
}

ul[class*=' list-inline'] li, ul[class^='list-inline'] li {
  display: inline-block;
}

ul.list-inline-dash li {
  padding-right: 5px;
}

ul.list-inline-dash li:before {
  content: '-';
  padding-right: 8px;
}

ul.list-inline-dash li:first-child:before {
  display: none;
}

ul.list-inline-dash li:last-child {
  padding-right: 0;
}

ul.list-inline li {
  padding-right: 4px;
}

ul.list-inline li:last-child {
  padding-right: 0;
}

ul.list-inline-lg li {
  padding-right: 8px;
}

ul.list-inline-lg li:last-child {
  padding-right: 0;
}

ul.list-inline-xl li {
  padding-right: 13px;
}

ul.list-inline-xl li:last-child {
  padding-right: 0;
}

ul.list-inline-2xl li {
  padding-right: 17px;
}

ul.list-inline-2xl li:last-child {
  padding-right: 0;
}

ul.list-inline-dot li {
  position: relative;
  padding: 0 4px 0 14px;
}

ul.list-inline-dot li:before {
  content: '';
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background: rgba(0, 0, 0, 0.8);
  width: 5px;
  height: 5px;
  border-radius: 50%;
}

ul.list-inline-dot li:first-child {
  padding-left: 0;
}

ul.list-inline-dot li:first-child:before {
  display: none;
}

[class*='bg-black'] ul.list-border-dashed li,
[class*='bg-dark'] ul.list-border-dashed li,
[class*='bg-gradient'] ul.list-border-dashed li {
  border-color: rgba(255, 255, 255, 0.3);
}

[class*='bg-black'] ul.list-inline-dot li:before,
[class*='bg-dark'] ul.list-inline-dot li:before,
[class*='bg-gradient'] ul.list-inline-dot li:before {
  background: rgba(255, 255, 255, 0.8);
}

/*------------------------------------------------
  6. Typography
-------------------------------------------------*/
body {
  color: #787a7c;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 1rem;
  font-weight: 400;
  letter-spacing: 0;
}

@media (max-width: 991.98px) {
  body {
    font-size: 0.938rem;
  }
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  color: black;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 500;
}

@media (max-width: 991.98px) {
  h1, h2, h3, h4, h5, h6,
  .h1, .h2, .h3, .h4, .h5, .h6 {
    margin-bottom: 6px;
  }
}

@media (min-width: 1200px) {
  .display-lg {
    font-size: 6rem;
  }
  .display-xl {
    font-size: 7rem;
  }
}

p {
  margin: 0;
  line-height: 1.74;
}

.uppercase {
  letter-spacing: 1px;
  text-transform: uppercase;
}

.font-small {
  font-size: 0.9em;
  line-height: 1.7;
}

@media (max-width: 991.98px) {
  .font-small {
    font-size: 0.9em;
    line-height: 1.7;
  }
}

.font-large {
  font-size: 1.063em;
  line-height: 1.6;
}

@media (max-width: 991.98px) {
  .font-large {
    font-size: 1.063em;
  }
}

.sm-heading {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 500;
  font-size: 0.9em;
  text-transform: uppercase;
  letter-spacing: 1px;
}

i {
  display: inline-block;
}

i.icon-4xl {
  font-size: 2.4em;
}

i.icon-3xl {
  font-size: 2.13em;
}

i.icon-2xl {
  font-size: 1.86em;
}

i.icon-xl {
  font-size: 1.6em;
}

i.icon-lg {
  font-size: 1.33em;
}

i.icon-sm {
  font-size: 0.9em;
}

.icon-4xl i {
  font-size: 2.4em;
}

.icon-3xl i {
  font-size: 2.13em;
}

.icon-2xl i {
  font-size: 1.86em;
}

.icon-xl i {
  font-size: 1.6em;
}

.icon-lg i {
  font-size: 1.33em;
}

.icon-sm i {
  font-size: 0.9em;
}

/*------------------------------------------------
  7. Accordion
-------------------------------------------------*/
.accordion {
  list-style-type: none;
  padding: 0;
}

.accordion li {
  border: 1px dashed rgba(28, 29, 36, 0.2);
  margin-bottom: 12px;
  padding: 20px 30px;
  -webkit-transition: linear 0.1s;
  transition: linear 0.1s;
}

.accordion li:last-child {
  margin-bottom: 0;
}

.accordion li .accordion-title {
  z-index: 1;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  -webkit-transition: linear 0.1s;
  transition: linear 0.1s;
}

.accordion li .accordion-title .accordion-toggle {
  position: absolute;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

.accordion li .accordion-title .accordion-toggle span {
  position: relative;
  display: inline-block;
  width: 11px;
  height: 11px;
}

.accordion li .accordion-title .accordion-toggle span:before, .accordion li .accordion-title .accordion-toggle span:after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  background: black;
  width: 11px;
  height: 1px;
}

.accordion li .accordion-title .accordion-toggle span:after {
  -webkit-transform: translate(-50%, -50%) rotate(90deg);
  transform: translate(-50%, -50%) rotate(90deg);
  -webkit-transition: linear 0.1s;
  transition: linear 0.1s;
}

.accordion li .accordion-title * {
  margin: 0;
  -webkit-transition: linear 0.1s;
  transition: linear 0.1s;
}

.accordion li .accordion-content {
  overflow: hidden;
  max-height: 0;
  -webkit-transition: ease-out 0.2s;
  transition: ease-out 0.2s;
}

.accordion li .accordion-content:before {
  content: '';
  display: block;
  width: 100%;
  height: 12px;
}

.accordion li .accordion-content ul li, .accordion li .accordion-content ol li {
  border: 0;
  padding: 0;
}

.accordion li .accordion-content ul li:last-child, .accordion li .accordion-content ol li:last-child {
  border: 0;
}

.accordion li .accordion-content ul {
  list-style-type: disc;
}

.accordion li .accordion-content ul ul {
  list-style-type: circle;
}

.accordion li .accordion-content ol.list-ordered li {
  margin-bottom: 8px;
  padding-left: 34px;
}

.accordion li .accordion-content ol.list-ordered li:last-child {
  margin: 0;
}

.accordion li .accordion-content .nav {
  list-style-type: none;
}

.accordion li.active {
  border-color: #1c1d24;
}

.accordion li.active .accordion-title .accordion-toggle span:after {
  opacity: 0;
  -webkit-transform: translate(-50%, -50%) rotate(0);
  transform: translate(-50%, -50%) rotate(0);
}

.accordion.style-2 li {
  margin-bottom: 0;
  padding: 20px 0;
  border-top: 0;
  border-right: 0;
  border-left: 0;
  border-bottom: 1px dashed rgba(28, 29, 36, 0.2);
}

.accordion.style-2 li:last-child {
  border-bottom: 0;
}

[class*='bg-black'] .accordion li,
[class*='bg-dark'] .accordion li {
  border-color: rgba(255, 255, 255, 0.2);
}

[class*='bg-black'] .accordion li .accordion-title .accordion-toggle span:before, [class*='bg-black'] .accordion li .accordion-title .accordion-toggle span:after,
[class*='bg-dark'] .accordion li .accordion-title .accordion-toggle span:before,
[class*='bg-dark'] .accordion li .accordion-title .accordion-toggle span:after {
  background: white;
}

[class*='bg-black'] .accordion li.active,
[class*='bg-dark'] .accordion li.active {
  border-color: white;
}

/*------------------------------------------------
  8. Box
-------------------------------------------------*/
.box-shadow {
  -webkit-box-shadow: 0 8px 34px 0 rgba(22, 24, 26, 0.1);
  box-shadow: 0 8px 34px 0 rgba(22, 24, 26, 0.1);
  -webkit-transition: ease-out 0.16s;
  transition: ease-out 0.16s;
}

.box-shadow:hover {
  -webkit-box-shadow: 0 8px 38px 0 rgba(22, 24, 26, 0.13);
  box-shadow: 0 8px 38px 0 rgba(22, 24, 26, 0.13);
}

img.box-shadow {
  -webkit-box-shadow: 0 8px 34px 0 rgba(22, 24, 26, 0.12);
  box-shadow: 0 8px 34px 0 rgba(22, 24, 26, 0.12);
}

img.box-shadow:hover {
  -webkit-box-shadow: 0 8px 38px 0 rgba(22, 24, 26, 0.15);
  box-shadow: 0 8px 38px 0 rgba(22, 24, 26, 0.15);
}

.hover-float {
  -webkit-transition: ease-out 0.16s;
  transition: ease-out 0.16s;
}

.hover-float:hover {
  -webkit-transform: translateY(-4px);
  transform: translateY(-4px);
}

.border-radius {
  border-radius: 0.5em;
  overflow: hidden;
}

.border-radius-1 {
  border-radius: 1em;
  overflow: hidden;
}

.border-radius-2 {
  border-radius: 2em 2em 2em 2em;
  overflow: hidden;
}

.icon-box-square,
.icon-box-circle {
  display: inline-block;
  width: 60px;
  height: 60px;
  line-height: 60px;
  text-align: center;
}

.icon-box-square-lg {
  width: 70px;
  height: 70px;
  line-height: 70px;
}

.icon-box-square-sm {
  width: 50px;
  height: 50px;
  line-height: 50px;
}

.icon-box-circle {
  border-radius: 50%;
}

.icon-box-circle.icon-box-circle-lg {
  width: 70px;
  height: 70px;
  line-height: 70px;
}

.icon-box-circle.icon-box-circle-sm {
  width: 50px;
  height: 50px;
  line-height: 50px;
}

.interactive-box {
  position: relative;
  overflow: hidden;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

.interactive-box img {
  -webkit-transform: scale(1);
  transform: scale(1);
  width: 100%;
  -webkit-transition: transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.interactive-box .interactive-overlay {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), transparent);
  -webkit-transition: linear 0.1s;
  transition: linear 0.1s;
}

.interactive-box .interactive-overlay .interactive-inner {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  -webkit-transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.interactive-box .interactive-overlay .interactive-hover {
  visibility: hidden;
  opacity: 0;
  position: absolute;
  bottom: 0;
  left: 0;
  -webkit-transform: translateY(8px);
  transform: translateY(8px);
  width: 100%;
  -webkit-transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.interactive-box:hover .interactive-overlay .interactive-inner {
  visibility: hidden;
  opacity: 0;
  -webkit-transform: translateY(-8px);
  transform: translateY(-8px);
}

.interactive-box:hover .interactive-overlay .interactive-hover {
  visibility: visible;
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0);
}

.interactive-box:hover img {
  -webkit-transform: scale(1.04);
  transform: scale(1.04);
}

.float-card img {
  z-index: -1;
}

.float-card .float-card-text {
  position: relative;
  margin-top: -2em;
  margin-right: 1em;
  margin-left: 1em;
  padding: 30px;
}

.hover-border {
  border: 1px solid transparent;
  -webkit-transition: linear 0.1s;
  transition: linear 0.1s;
}

.hover-border:hover, .hover-border.hover-border-active {
  border-color: #1c1d24;
}

.hover-border-wrapper:hover .hover-border {
  border-color: transparent;
}

.hover-border-wrapper:hover .hover-border:hover {
  border-color: #1c1d24;
}

[class*='bg-black'] .hover-border:hover, [class*='bg-black'] .hover-border.hover-border-active,
[class*='bg-dark'] .hover-border:hover,
[class*='bg-dark'] .hover-border.hover-border-active,
[class*='bg-gradient'] .hover-border:hover,
[class*='bg-gradient'] .hover-border.hover-border-active {
  border-color: white;
}

[class*='bg-black'] .hover-border-wrapper:hover .hover-border,
[class*='bg-dark'] .hover-border-wrapper:hover .hover-border,
[class*='bg-gradient'] .hover-border-wrapper:hover .hover-border {
  border-color: transparent;
}

[class*='bg-black'] .hover-border-wrapper:hover .hover-border:hover,
[class*='bg-dark'] .hover-border-wrapper:hover .hover-border:hover,
[class*='bg-gradient'] .hover-border-wrapper:hover .hover-border:hover {
  border-color: white;
}

/*------------------------------------------------
  9. Buttons
-------------------------------------------------*/
button {
  background: transparent;
  box-shadow: none;
  border: 0;
  padding: 0;
  cursor: pointer;
}

a, button {
  text-decoration: none;
  -webkit-transition: linear 0.1s;
  transition: linear 0.1s;
}

a:focus, a:active, button:focus, button:active {
  box-shadow: none;
  outline: 0;
}

.button {
  position: relative;
  display: inline-block;
  background: #ecedf5;
  color: #1c1d24;
  padding: 13px 30px;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
}

.button-xs {
  padding: 7px 15px;
}

.button-sm {
  padding: 11px 23px;
}

.button-lg {
  padding: 15px 34px;
}

.button-fullwidth {
  width: 100%;
  text-align: center;
}

.button-radius {
  border-radius: 0.5em;
}

.button-rounded {
  border-radius: 30px;
}

.button-hover-slide {
  overflow: hidden;
  vertical-align: middle;
}

.button-hover-slide span {
  display: inline-block;
  position: relative;
  color: transparent;
}

.button-hover-slide span:before, .button-hover-slide span:after {
  content: attr(data-text);
  position: absolute;
  left: 0;
  color: white;
  -webkit-transition: ease-out 0.16s;
  transition: ease-out 0.16s;
}

.button-hover-slide span:before {
  top: 0;
}

.button-hover-slide span:after {
  visibility: hidden;
  opacity: 0;
  top: 50%;
}

.button-hover-slide:hover:before {
  opacity: 0.4;
  -webkit-transform: translateY(-50%) scale(2.7);
  transform: translateY(-50%) scale(2.7);
}

.button-hover-slide:hover span:before {
  visibility: hidden;
  opacity: 0;
  top: -50%;
}

.button-hover-slide:hover span:after {
  visibility: visible;
  opacity: 1;
  top: 0;
}

.button-hover-float:hover {
  -webkit-transform: translateY(-4px);
  transform: translateY(-4px);
}

.button-dark {
  background: #1c1d24;
  color: white;
}

.button-dark:hover {
  background: rgba(28, 29, 36, 0.85);
}

.button-white {
  background: white;
  color: #1c1d24;
}

.button-white.button-hover-slide span:before, .button-white.button-hover-slide span:after {
  color: #1c1d24;
}

.button-white-2 {
  background: rgba(255, 255, 255, 0.15);
  color: white;
}

.button-white-2:hover {
  background: rgba(255, 255, 255, 0.2);
}

.button-outline,
.button-outline-dashed {
  background: transparent;
  color: #1c1d24;
}

.button-outline.button-hover-slide span:before, .button-outline.button-hover-slide span:after,
.button-outline-dashed.button-hover-slide span:before,
.button-outline-dashed.button-hover-slide span:after {
  color: #1c1d24;
}

.button-outline {
  border: 1px solid #1c1d24;
}

.button-outline:hover {
  border-color: rgba(28, 29, 36, 0.6);
}

.button-outline-dashed {
  border: 1px dashed #1c1d24;
}

.button-outline-dashed:hover {
  border-color: rgba(28, 29, 36, 0.6);
}

[class*='bg-black'] .button-outline,
[class*='bg-black'] .button-outline-dashed,
[class*='bg-dark'] .button-outline,
[class*='bg-dark'] .button-outline-dashed,
[class*='bg-gradient'] .button-outline,
[class*='bg-gradient'] .button-outline-dashed,
.header-dark:not(.transparent-dark) .button-outline,
.header-dark:not(.transparent-dark) .button-outline-dashed,
.header.transparent-light .button-outline,
.header.transparent-light .button-outline-dashed {
  background: transparent;
  border-color: white;
  color: white;
}

[class*='bg-black'] .button-outline:hover,
[class*='bg-black'] .button-outline-dashed:hover,
[class*='bg-dark'] .button-outline:hover,
[class*='bg-dark'] .button-outline-dashed:hover,
[class*='bg-gradient'] .button-outline:hover,
[class*='bg-gradient'] .button-outline-dashed:hover,
.header-dark:not(.transparent-dark) .button-outline:hover,
.header-dark:not(.transparent-dark) .button-outline-dashed:hover,
.header.transparent-light .button-outline:hover,
.header.transparent-light .button-outline-dashed:hover {
  background: transparent;
}

[class*='bg-black'] .button-outline.button-hover-slide span:before, [class*='bg-black'] .button-outline.button-hover-slide span:after,
[class*='bg-black'] .button-outline-dashed.button-hover-slide span:before,
[class*='bg-black'] .button-outline-dashed.button-hover-slide span:after,
[class*='bg-dark'] .button-outline.button-hover-slide span:before,
[class*='bg-dark'] .button-outline.button-hover-slide span:after,
[class*='bg-dark'] .button-outline-dashed.button-hover-slide span:before,
[class*='bg-dark'] .button-outline-dashed.button-hover-slide span:after,
[class*='bg-gradient'] .button-outline.button-hover-slide span:before,
[class*='bg-gradient'] .button-outline.button-hover-slide span:after,
[class*='bg-gradient'] .button-outline-dashed.button-hover-slide span:before,
[class*='bg-gradient'] .button-outline-dashed.button-hover-slide span:after,
.header-dark:not(.transparent-dark) .button-outline.button-hover-slide span:before,
.header-dark:not(.transparent-dark) .button-outline.button-hover-slide span:after,
.header-dark:not(.transparent-dark) .button-outline-dashed.button-hover-slide span:before,
.header-dark:not(.transparent-dark) .button-outline-dashed.button-hover-slide span:after,
.header.transparent-light .button-outline.button-hover-slide span:before,
.header.transparent-light .button-outline.button-hover-slide span:after,
.header.transparent-light .button-outline-dashed.button-hover-slide span:before,
.header.transparent-light .button-outline-dashed.button-hover-slide span:after {
  color: white;
}

[class*='bg-black'] .button-outline:hover,
[class*='bg-dark'] .button-outline:hover,
[class*='bg-gradient'] .button-outline:hover,
.header-dark:not(.transparent-dark) .button-outline:hover,
.header.transparent-light .button-outline:hover {
  border-color: rgba(255, 255, 255, 0.7);
}

[class*='bg-black'] .button-outline-dashed:hover,
[class*='bg-dark'] .button-outline-dashed:hover,
[class*='bg-gradient'] .button-outline-dashed:hover,
.header-dark:not(.transparent-dark) .button-outline-dashed:hover,
.header.transparent-light .button-outline-dashed:hover {
  border-color: rgba(255, 255, 255, 0.6);
}

[class*='button-fancy'] {
  position: relative;
  display: inline-block;
  padding-left: 30px;
  height: 50px;
  line-height: 50px;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  -webkit-transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

[class*='button-fancy']:before {
  content: '';
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  -webkit-transform-origin: center left;
  transform-origin: center left;
  width: 50px;
  height: 50px;
  border-radius: 30px;
  -webkit-transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

[class*='button-fancy']:hover {
  padding-left: 22px;
  padding-right: 8px;
}

[class*='button-fancy']:hover:before {
  -webkit-transform: translateY(-50%) scale(0.25);
  transform: translateY(-50%) scale(0.25);
}

[class*='button-fancy'].button-fancy-right {
  padding-left: 0;
  padding-right: 30px;
}

[class*='button-fancy'].button-fancy-right:before {
  left: auto;
  right: 0;
  -webkit-transform-origin: center right;
  transform-origin: center right;
}

[class*='button-fancy'].button-fancy-right:hover {
  padding-left: 8px;
  padding-right: 22px;
}

.button-fancy {
  color: #1c1d24;
}

.button-fancy:before {
  background: rgba(28, 29, 36, 0.05);
}

.button-fancy:hover:before {
  background: #1c1d24;
}

[class*='button-fancy-gradient']:before {
  opacity: 0.1;
}

[class*='button-fancy-gradient']:hover:before {
  opacity: 1;
}

.button-fancy-gradient-1 {
  background-image: linear-gradient(45deg, #ff5988, #500c7f);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.button-fancy-gradient-1:before {
  background-image: linear-gradient(45deg, #ff5988, #500c7f);
}

.button-fancy-gradient-2 {
  background-image: linear-gradient(45deg, #2fbdff, #0f2f40);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.button-fancy-gradient-2:before {
  background-image: linear-gradient(45deg, #2fbdff, #0f2f40);
}

.button-fancy-gradient-3 {
  background-image: linear-gradient(45deg, #ff2f78, #ff7582);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.button-fancy-gradient-3:before {
  background-image: linear-gradient(45deg, #ff2f78, #ff7582);
}

.button-fancy-gradient-4 {
  background-image: linear-gradient(45deg, #00DBDE, #FC00FF);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.button-fancy-gradient-4:before {
  background-image: linear-gradient(45deg, #00DBDE, #FC00FF);
}

.button-fancy-gradient-5 {
  background-image: linear-gradient(45deg, #007990, #6CE5C0);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.button-fancy-gradient-5:before {
  background-image: linear-gradient(45deg, #007990, #6CE5C0);
}

[class*='bg-black'] .button-fancy,
[class*='bg-dark'] .button-fancy,
[class*='bg-gradient'] .button-fancy {
  color: white;
}

[class*='bg-black'] .button-fancy:before,
[class*='bg-dark'] .button-fancy:before,
[class*='bg-gradient'] .button-fancy:before {
  background: rgba(255, 255, 255, 0.15);
}

[class*='bg-black'] .button-fancy:hover:before,
[class*='bg-dark'] .button-fancy:hover:before,
[class*='bg-gradient'] .button-fancy:hover:before {
  background: white;
}

[class*='bg-black'] [class*='button-fancy-gradient']:hover:before,
[class*='bg-dark'] [class*='button-fancy-gradient']:hover:before,
[class*='bg-gradient'] [class*='button-fancy-gradient']:hover:before {
  opacity: 1;
}

.button-circle {
  position: relative;
  background: #ecedf5;
  display: inline-block;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  color: #1c1d24;
  line-height: 50px;
  text-align: center;
}

.button-circle-sm {
  width: 44px;
  height: 44px;
  line-height: 44px;
}

.button-circle-lg {
  width: 56px;
  height: 56px;
  line-height: 56px;
}

.button-circle-dark {
  background: #1c1d24;
  color: white;
}

.button-circle-dark i {
  color: white;
}

.button-circle-dark:hover {
  background: rgba(28, 29, 36, 0.85);
}

.button-circle-white {
  background: white;
  color: #1c1d24;
}

.button-circle-white-2 {
  background: rgba(255, 255, 255, 0.15);
  color: white;
}

.button-circle-white-2 i {
  color: white;
}

.button-circle-white-2:hover {
  background: rgba(255, 255, 255, 0.2);
}

.button-circle-outline,
.button-circle-outline-dashed {
  background: transparent;
  color: #1c1d24;
}

.button-circle-outline i,
.button-circle-outline-dashed i {
  color: #1c1d24;
}

.button-circle-outline {
  border: 1px solid #1c1d24;
}

.button-circle-outline:hover {
  border-color: rgba(28, 29, 36, 0.6);
}

.button-circle-outline-dashed {
  border: 1px dashed #1c1d24;
}

.button-circle-outline-dashed:hover {
  border-color: rgba(28, 29, 36, 0.6);
}

.button-gradient-1 {
  background-image: linear-gradient(to right, #ff5988, #500c7f, #ff5988);
}

.button-gradient-2 {
  background-image: linear-gradient(to right, #2fbdff, #0f2f40, #2fbdff);
}

.button-gradient-3 {
  background-image: linear-gradient(to right, #ff2f78, #ff7582, #ff2f78);
}

.button-gradient-4 {
  background-image: linear-gradient(to right, #00DBDE, #FC00FF, #00DBDE);
}

.button-gradient-5 {
  background-image: linear-gradient(to right, #1db585, #34c759, #1db585);
}

[class*='button-gradient'] {
  -webkit-background-size: 300% 100%;
  -moz-background-size: 300% 100%;
  background-size: 300% 100%;
  border: 0;
  -webkit-box-shadow: 0 6px 30px 0 rgba(21, 25, 29, 0.13);
  box-shadow: 0 6px 30px 0 rgba(21, 25, 29, 0.13);
  color: white;
  -webkit-transition: all 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: all 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
}

[class*='button-gradient'] i {
  color: white;
}

[class*='button-gradient']:hover, [class*='button-gradient']:focus {
  -webkit-box-shadow: 0 6px 36px 0 rgba(21, 25, 29, 0.19);
  box-shadow: 0 6px 36px 0 rgba(21, 25, 29, 0.19);
  background-position: 100% 0;
  color: white;
}

.button-circle-hover-slide {
  overflow: hidden;
  line-height: 1;
}

.button-circle-hover-slide i {
  position: absolute;
  left: 50%;
  -webkit-transition: ease-out 0.16s;
  transition: ease-out 0.16s;
}

.button-circle-hover-slide i:first-child {
  top: 50%;
  -webkit-transform: translateX(-50%) translateY(-50%);
  transform: translateX(-50%) translateY(-50%);
  opacity: 1;
}

.button-circle-hover-slide i:last-child {
  top: auto;
  bottom: 0;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  opacity: 0;
}

.button-circle-hover-slide:hover i:first-child {
  top: 0;
  -webkit-transform: translateX(-50%) translateY(0);
  transform: translateX(-50%) translateY(0);
  opacity: 0;
}

.button-circle-hover-slide:hover i:last-child {
  top: 50%;
  bottom: auto;
  -webkit-transform: translateX(-50%) translateY(-50%);
  transform: translateX(-50%) translateY(-50%);
  opacity: 1;
}

[class*='bg-black'] .button-circle-outline,
[class*='bg-black'] .button-circle-outline-dashed,
[class*='bg-dark'] .button-circle-outline,
[class*='bg-dark'] .button-circle-outline-dashed,
[class*='bg-gradient'] .button-circle-outline,
[class*='bg-gradient'] .button-circle-outline-dashed,
.header-dark:not(.transparent-dark) .button-circle-outline,
.header-dark:not(.transparent-dark) .button-circle-outline-dashed,
.header.transparent-light .button-circle-outline,
.header.transparent-light .button-circle-outline-dashed {
  background: transparent;
  border-color: white;
  color: white;
}

[class*='bg-black'] .button-circle-outline i,
[class*='bg-black'] .button-circle-outline-dashed i,
[class*='bg-dark'] .button-circle-outline i,
[class*='bg-dark'] .button-circle-outline-dashed i,
[class*='bg-gradient'] .button-circle-outline i,
[class*='bg-gradient'] .button-circle-outline-dashed i,
.header-dark:not(.transparent-dark) .button-circle-outline i,
.header-dark:not(.transparent-dark) .button-circle-outline-dashed i,
.header.transparent-light .button-circle-outline i,
.header.transparent-light .button-circle-outline-dashed i {
  color: white;
}

[class*='bg-black'] .button-circle-outline:hover,
[class*='bg-black'] .button-circle-outline-dashed:hover,
[class*='bg-dark'] .button-circle-outline:hover,
[class*='bg-dark'] .button-circle-outline-dashed:hover,
[class*='bg-gradient'] .button-circle-outline:hover,
[class*='bg-gradient'] .button-circle-outline-dashed:hover,
.header-dark:not(.transparent-dark) .button-circle-outline:hover,
.header-dark:not(.transparent-dark) .button-circle-outline-dashed:hover,
.header.transparent-light .button-circle-outline:hover,
.header.transparent-light .button-circle-outline-dashed:hover {
  background: transparent;
}

[class*='bg-black'] .button-circle-outline.button-circle-hover-slide,
[class*='bg-black'] .button-circle-outline-dashed.button-circle-hover-slide,
[class*='bg-dark'] .button-circle-outline.button-circle-hover-slide,
[class*='bg-dark'] .button-circle-outline-dashed.button-circle-hover-slide,
[class*='bg-gradient'] .button-circle-outline.button-circle-hover-slide,
[class*='bg-gradient'] .button-circle-outline-dashed.button-circle-hover-slide,
.header-dark:not(.transparent-dark) .button-circle-outline.button-circle-hover-slide,
.header-dark:not(.transparent-dark) .button-circle-outline-dashed.button-circle-hover-slide,
.header.transparent-light .button-circle-outline.button-circle-hover-slide,
.header.transparent-light .button-circle-outline-dashed.button-circle-hover-slide {
  color: white;
}

[class*='bg-black'] .button-circle-outline.button-circle-hover-slide i,
[class*='bg-black'] .button-circle-outline-dashed.button-circle-hover-slide i,
[class*='bg-dark'] .button-circle-outline.button-circle-hover-slide i,
[class*='bg-dark'] .button-circle-outline-dashed.button-circle-hover-slide i,
[class*='bg-gradient'] .button-circle-outline.button-circle-hover-slide i,
[class*='bg-gradient'] .button-circle-outline-dashed.button-circle-hover-slide i,
.header-dark:not(.transparent-dark) .button-circle-outline.button-circle-hover-slide i,
.header-dark:not(.transparent-dark) .button-circle-outline-dashed.button-circle-hover-slide i,
.header.transparent-light .button-circle-outline.button-circle-hover-slide i,
.header.transparent-light .button-circle-outline-dashed.button-circle-hover-slide i {
  color: white;
}

[class*='bg-black'] .button-circle-outline:hover,
[class*='bg-dark'] .button-circle-outline:hover,
[class*='bg-gradient'] .button-circle-outline:hover,
.header-dark:not(.transparent-dark) .button-circle-outline:hover,
.header.transparent-light .button-circle-outline:hover {
  border-color: rgba(255, 255, 255, 0.7);
}

[class*='bg-black'] .button-circle-outline-dashed:hover,
[class*='bg-dark'] .button-circle-outline-dashed:hover,
[class*='bg-gradient'] .button-circle-outline-dashed:hover,
.header-dark:not(.transparent-dark) .button-circle-outline-dashed:hover,
.header.transparent-light .button-circle-outline-dashed:hover {
  border-color: rgba(255, 255, 255, 0.6);
}

.button-shadow {
  -webkit-box-shadow: 0 6px 30px 0 rgba(22, 24, 26, 0.1);
  box-shadow: 0 6px 30px 0 rgba(22, 24, 26, 0.1);
}

.button-shadow:hover, .button-shadow:focus {
  -webkit-box-shadow: 0 6px 36px 0 rgba(22, 24, 26, 0.13);
  box-shadow: 0 6px 36px 0 rgba(22, 24, 26, 0.13);
}

/*------------------------------------------------
  10. Circle Text
-------------------------------------------------*/
.circle-text {
  position: relative;
  max-width: 300px;
  max-height: 300px;
  text-transform: uppercase;
  font-weight: bold;
}

.circle-text .circle-svg {
  max-width: 100%;
  height: auto;
}

.circle-text .circle-text-inner {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

.rotating {
  animation: rotating 20s linear infinite;
}

@keyframes rotating {
  from {
    transform: rotate(0);
  }
  to {
    transform: rotate(360deg);
  }
}

/*------------------------------------------------
  11. Clients
-------------------------------------------------*/
.client-box a img {
  opacity: 0.5;
  width: 100%;
  -webkit-transition: ease-out 0.12s;
  transition: ease-out 0.12s;
}

.client-box a:hover img {
  opacity: 1;
}

.client-box-with-link {
  position: relative;
}

.client-box-with-link a {
  display: block;
}

.client-box-with-link a img {
  opacity: 0.8;
  width: 100%;
  -webkit-transition: ease-out 0.12s;
  transition: ease-out 0.12s;
}

.client-box-with-link a span {
  opacity: 0;
  visibility: hidden;
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  display: block;
  width: 100%;
  text-align: center;
  -webkit-transition: ease-out 0.12s;
  transition: ease-out 0.12s;
}

.client-box-with-link a:hover img {
  opacity: 0;
  visibility: hidden;
  -webkit-transform: translateY(-5px);
  transform: translateY(-5px);
}

.client-box-with-link a:hover span {
  opacity: 1;
  visibility: visible;
}

/*------------------------------------------------
  12. Gadgets
-------------------------------------------------*/
.bg-lines-5 {
  position: fixed;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
}

.bg-lines-5 .line-1,
.bg-lines-5 .line-2,
.bg-lines-5 .line-3,
.bg-lines-5 .line-4,
.bg-lines-5 .line-5 {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  border-right: 1px solid rgba(28, 29, 36, 0.1);
}

.bg-lines-5 .line-1:before,
.bg-lines-5 .line-2:before,
.bg-lines-5 .line-3:before,
.bg-lines-5 .line-4:before,
.bg-lines-5 .line-5:before {
  content: '';
  position: absolute;
  top: -80px;
  right: -1px;
  background: linear-gradient(transparent, rgba(28, 29, 36, 0.6));
  width: 1px;
  height: 80px;
}

.bg-lines-5 .line-1 {
  width: 10%;
}

.bg-lines-5 .line-2 {
  width: 30%;
}

.bg-lines-5 .line-3 {
  width: 50%;
}

.bg-lines-5 .line-4 {
  width: 70%;
}

.bg-lines-5 .line-5 {
  width: 90%;
}

.bg-lines-5.bg-lines-animated .line-1:before {
  -webkit-animation: bgLine 8s linear infinite;
  animation: bgLine 8s linear infinite;
}

.bg-lines-5.bg-lines-animated .line-2:before {
  -webkit-animation: bgLine 9s linear infinite;
  animation: bgLine 9s linear infinite;
  -webkit-animation-delay: 5s;
  animation-delay: 5s;
}

.bg-lines-5.bg-lines-animated .line-3:before {
  -webkit-animation: bgLine 7s linear infinite;
  animation: bgLine 7s linear infinite;
  -webkit-animation-delay: 4s;
  animation-delay: 4s;
}

.bg-lines-5.bg-lines-animated .line-4:before {
  -webkit-animation: bgLine 10s linear infinite;
  animation: bgLine 10s linear infinite;
  -webkit-animation-delay: 8s;
  animation-delay: 8s;
}

.bg-lines-5.bg-lines-animated .line-5:before {
  -webkit-animation: bgLine 8.5s linear infinite;
  animation: bgLine 8.5s linear infinite;
  -webkit-animation-delay: 3s;
  animation-delay: 3s;
}

@media (max-width: 991.98px) {
  .bg-lines-5 .line-1 {
    width: 10%;
  }
  .bg-lines-5 .line-2 {
    width: 50%;
  }
  .bg-lines-5 .line-3 {
    width: 90%;
  }
  .bg-lines-5 .line-4,
  .bg-lines-5 .line-5 {
    display: none;
  }
}

@-webkit-keyframes bgLine {
  0% {
    top: -80px;
  }
  100% {
    top: 100%;
  }
}

@keyframes bgLine {
  0% {
    top: -80px;
  }
  100% {
    top: 100%;
  }
}

.bg-lines-3 {
  position: fixed;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
}

.bg-lines-3 .line-1,
.bg-lines-3 .line-2,
.bg-lines-3 .line-3 {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  border-right: 1px solid rgba(28, 29, 36, 0.1);
}

.bg-lines-3 .line-1:before,
.bg-lines-3 .line-2:before,
.bg-lines-3 .line-3:before {
  content: '';
  position: absolute;
  top: -80px;
  right: -1px;
  background: linear-gradient(transparent, rgba(28, 29, 36, 0.6));
  width: 1px;
  height: 80px;
}

.bg-lines-3 .line-1 {
  width: 10%;
}

.bg-lines-3 .line-2 {
  width: 50%;
}

.bg-lines-3 .line-3 {
  width: 90%;
}

.bg-lines-3.bg-lines-animated .line-1:before {
  -webkit-animation: bgLine 8s linear infinite;
  animation: bgLine 8s linear infinite;
}

.bg-lines-3.bg-lines-animated .line-2:before {
  -webkit-animation: bgLine 9s linear infinite;
  animation: bgLine 9s linear infinite;
  -webkit-animation-delay: 5s;
  animation-delay: 5s;
}

.bg-lines-3.bg-lines-animated .line-3:before {
  -webkit-animation: bgLine 7s linear infinite;
  animation: bgLine 7s linear infinite;
  -webkit-animation-delay: 4s;
  animation-delay: 4s;
}

[class*='bg-black'] .bg-lines-5 *,
[class*='bg-black'] .bg-lines-3 *,
[class*='bg-dark'] .bg-lines-5 *,
[class*='bg-dark'] .bg-lines-3 *,
[class*='bg-gradient'] .bg-lines-5 *,
[class*='bg-gradient'] .bg-lines-3 * {
  border-color: rgba(255, 255, 255, 0.15);
}

[class*='bg-black'] .bg-lines-5 *:before,
[class*='bg-black'] .bg-lines-3 *:before,
[class*='bg-dark'] .bg-lines-5 *:before,
[class*='bg-dark'] .bg-lines-3 *:before,
[class*='bg-gradient'] .bg-lines-5 *:before,
[class*='bg-gradient'] .bg-lines-3 *:before {
  background: linear-gradient(transparent, rgba(255, 255, 255, 0.7));
}

.cursors {
  z-index: 1000;
  position: absolute;
  top: 0;
  left: 0;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  pointer-events: none;
}

.cursors .mouse-caption, .cursors img {
  position: absolute;
  top: 0;
  left: 0;
  margin-left: 8px;
}

.cursors .mouse-caption {
  backdrop-filter: blur(5px);
  background: rgba(255, 255, 255, 0.5);
  padding: 16px 20px;
}

.cursors .mouse-caption * {
  margin: 0;
}

.cursors .mouse-caption h2 {
  padding: 4px;
}

.cursors .mouse-caption.mouse-caption-dark {
  background: rgba(28, 29, 36, 0.7);
  color: white;
}

.cursors .mouse-caption.mouse-caption-dark * {
  color: white;
}

.cursors img {
  min-width: 300px;
  width: 300px;
  -webkit-transition: linear 0.1s;
  transition: linear 0.1s;
}

@media (max-width: 991.98px) {
  .cursors {
    display: none;
  }
}

#particles-js {
  z-index: -1;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}

.scrolltotop {
  z-index: 996;
  position: fixed;
  right: 20px;
  bottom: 20px;
  -webkit-transform: translateY(10px);
  transform: translateY(10px);
  visibility: hidden;
  opacity: 0;
  display: inline-block;
  background: rgba(255, 255, 255, 0.1);
  width: 46px;
  height: 46px;
  line-height: 46px;
  border-radius: 50%;
  color: white;
  text-align: center;
  mix-blend-mode: difference;
  cursor: pointer;
  backdrop-filter: blur(5px);
  -webkit-transition: ease-out 0.12s;
  transition: ease-out 0.12s;
}

.scrolltotop * {
  color: white;
}

.scrolltotop.show {
  -webkit-transform: translateY(0);
  transform: translateY(0);
  visibility: visible;
  opacity: 1;
}

@media (max-width: 991.98px) {
  .scrolltotop {
    right: 16px;
    bottom: 16px;
  }
}

/*------------------------------------------------
  13. Lightbox
-------------------------------------------------*/
.lightbox-video {
  position: relative;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  overflow: hidden;
}

.lightbox-video img {
  -webkit-transform: scale(1);
  transform: scale(1);
  width: 100%;
  -webkit-transition: transform 0.8s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: transform 0.8s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.lightbox-video .lightbox-play-btn {
  z-index: 1;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  display: inline-block;
  width: 100px;
  height: 100px;
  line-height: 100px;
  border-radius: 50%;
  text-align: center;
  color: white;
  font-size: 1.6em;
}

.lightbox-video .lightbox-play-btn i {
  color: white;
}

.lightbox-video .lightbox-play-btn:before, .lightbox-video .lightbox-play-btn:after {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  border-radius: 50%;
  -webkit-transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.lightbox-video .lightbox-play-btn:before {
  z-index: -1;
  background: rgba(0, 0, 0, 0.1);
  border-radius: 50%;
}

.lightbox-video .lightbox-play-btn:after {
  z-index: -1;
  -webkit-transform: scale(2.5);
  transform: scale(2.5);
  background: rgba(0, 0, 0, 0.1);
  border-radius: 50%;
}

.lightbox-video .lightbox-play-btn:hover {
  color: white;
}

.lightbox-video .lightbox-play-btn:hover:before {
  -webkit-transform: scale(1.2);
  transform: scale(1.2);
}

.lightbox-video .lightbox-play-btn:hover:after {
  -webkit-transform: scale(2.6);
  transform: scale(2.6);
}

.lightbox-video:hover img {
  -webkit-transform: scale(1.04);
  transform: scale(1.04);
}

@media (max-width: 1199.98px) {
  .lightbox-video .lightbox-play-btn {
    width: 80px;
    height: 80px;
    line-height: 80px;
  }
}

@media (max-width: 991.98px) {
  .lightbox-video .lightbox-play-btn {
    width: 60px;
    height: 60px;
    line-height: 60px;
  }
}

/*------------------------------------------------
  14. Link hovers
-------------------------------------------------*/
.link-hover-line {
  z-index: 1;
  position: relative;
  color: black;
}

.link-hover-line:before {
  content: '';
  position: absolute;
  right: 0;
  bottom: -1px;
  left: 0;
  background: black;
  height: 1px;
  -webkit-animation: line-out 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) both;
  animation: line-out 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) both;
}

.link-hover-line:hover {
  color: black;
}

.link-hover-line:hover:before {
  width: 100%;
  -webkit-animation: line-in 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) both;
  animation: line-in 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) both;
}

[class*='bg-black'] .link-hover-line,
[class*='bg-dark'] .link-hover-line,
[class*='bg-gradient'] .link-hover-line {
  color: white;
}

[class*='bg-black'] .link-hover-line:before,
[class*='bg-dark'] .link-hover-line:before,
[class*='bg-gradient'] .link-hover-line:before {
  background: white;
}

[class*='bg-black'] .link-hover-line:hover,
[class*='bg-dark'] .link-hover-line:hover,
[class*='bg-gradient'] .link-hover-line:hover {
  color: white;
}

[class*='link-hover-gradient'] {
  z-index: 1;
  position: relative;
  color: black;
}

[class*='link-hover-gradient']:before {
  content: '';
  z-index: -1;
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  opacity: 0.4;
  height: 30%;
  -webkit-animation: line-out 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) both;
  animation: line-out 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) both;
}

[class*='link-hover-gradient']:hover:before {
  width: 100%;
  -webkit-animation: line-in 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) both;
  animation: line-in 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) both;
}

.link-hover-gradient-1:before {
  background: linear-gradient(45deg, #ff5988, #500c7f);
}

.link-hover-gradient-2:before {
  background: linear-gradient(45deg, #2fbdff, #0f2f40);
}

.link-hover-gradient-3:before {
  background: linear-gradient(45deg, #ff2f78, #ff7582);
}

.link-hover-gradient-4:before {
  background: linear-gradient(45deg, #00DBDE, #FC00FF);
}

.link-hover-gradient-5:before {
  background: linear-gradient(45deg, #007990, #6CE5C0);
}

.display-1 [class*='link-hover-gradient']:before,
.display-2 [class*='link-hover-gradient']:before,
.display-3 [class*='link-hover-gradient']:before {
  height: 20%;
}

[class*='bg-black'] [class*='link-hover-gradient'],
[class*='bg-dark'] [class*='link-hover-gradient'],
[class*='bg-gradient'] [class*='link-hover-gradient'] {
  color: white;
}

@-webkit-keyframes line-out {
  0% {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
    -webkit-transform-origin: 100% 50%;
    transform-origin: 100% 50%;
  }
  100% {
    -webkit-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transform-origin: 100% 50%;
    transform-origin: 100% 50%;
  }
}

@keyframes line-out {
  0% {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
    -webkit-transform-origin: 100% 50%;
    transform-origin: 100% 50%;
  }
  100% {
    -webkit-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transform-origin: 100% 50%;
    transform-origin: 100% 50%;
  }
}

@-webkit-keyframes line-in {
  0% {
    -webkit-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transform-origin: 0 50%;
    transform-origin: 0 50%;
  }
  100% {
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-transform-origin: 0 50%;
    transform-origin: 0 50%;
  }
}

@keyframes line-in {
  0% {
    -webkit-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transform-origin: 0 50%;
    transform-origin: 0 50%;
  }
  100% {
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-transform-origin: 0 50%;
    transform-origin: 0 50%;
  }
}

.link-hover-reveal {
  position: relative;
  overflow: hidden;
  display: block;
  color: black;
  -webkit-transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.link-hover-reveal i {
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  visibility: hidden;
  opacity: 0;
  color: black;
  -webkit-transition: linear 0.1s;
  transition: linear 0.1s;
}

.link-hover-reveal:hover {
  padding-left: 24px;
}

.link-hover-reveal:hover i {
  visibility: visible;
  opacity: 1;
}

h5 .link-hover-reveal:hover, .h5 .link-hover-reveal:hover {
  padding-left: 30px;
}

h4 .link-hover-reveal:hover, .h4 .link-hover-reveal:hover {
  padding-left: 34px;
}

h3 .link-hover-reveal:hover, .h3 .link-hover-reveal:hover {
  padding-left: 38px;
}

h2 .link-hover-reveal:hover, .h2 .link-hover-reveal:hover {
  padding-left: 43px;
}

h1 .link-hover-reveal:hover, .h1 .link-hover-reveal:hover {
  padding-left: 50px;
}

[class*='bg-black'] .link-hover-reveal,
[class*='bg-dark'] .link-hover-reveal,
[class*='bg-gradient'] .link-hover-reveal {
  color: white;
}

[class*='bg-black'] .link-hover-reveal i,
[class*='bg-dark'] .link-hover-reveal i,
[class*='bg-gradient'] .link-hover-reveal i {
  color: white;
}

.link-hover-fill {
  color: black;
  -webkit-text-fill-color: transparent;
  -webkit-text-stroke-width: 1px;
  -webkit-text-stroke-color: black;
  -webkit-transition: linear 0.1s;
  transition: linear 0.1s;
}

.link-hover-fill:hover {
  text-shadow: 0 0 black;
}

.link-hover-stroke {
  color: black;
  -webkit-text-fill-color: transparent;
  -webkit-text-stroke-width: 1px;
  -webkit-text-stroke-color: black;
  -webkit-transition: linear 0.1s;
  transition: linear 0.1s;
  text-shadow: 0 0 black;
}

.link-hover-stroke:hover {
  text-shadow: none;
}

[class*='bg-black'] .link-hover-fill,
[class*='bg-black'] .link-hover-stroke,
[class*='bg-dark'] .link-hover-fill,
[class*='bg-dark'] .link-hover-stroke,
[class*='bg-gradient'] .link-hover-fill,
[class*='bg-gradient'] .link-hover-stroke {
  color: white;
  -webkit-text-fill-color: transparent;
  -webkit-text-stroke-width: 1px;
  -webkit-text-stroke-color: white;
}

[class*='bg-black'] .link-hover-fill:hover,
[class*='bg-dark'] .link-hover-fill:hover,
[class*='bg-gradient'] .link-hover-fill:hover {
  text-shadow: 0 0 white;
}

[class*='bg-black'] .link-hover-stroke,
[class*='bg-dark'] .link-hover-stroke,
[class*='bg-gradient'] .link-hover-stroke {
  text-shadow: 0 0 white;
}

[class*='bg-black'] .link-hover-stroke:hover,
[class*='bg-dark'] .link-hover-stroke:hover,
[class*='bg-gradient'] .link-hover-stroke:hover {
  text-shadow: none;
}

.link-hover-slide {
  display: inline-block;
  overflow: hidden;
  vertical-align: middle;
}

.link-hover-slide span {
  display: block;
  position: relative;
  color: transparent;
}

.link-hover-slide span:before, .link-hover-slide span:after {
  content: attr(data-text);
  position: absolute;
  left: 0;
  color: black;
  -webkit-transition: ease-out 0.16s;
  transition: ease-out 0.16s;
}

.link-hover-slide span:before {
  top: 0;
}

.link-hover-slide span:after {
  visibility: hidden;
  opacity: 0;
  top: 50%;
}

.link-hover-slide:hover:before {
  opacity: 0.4;
  -webkit-transform: translateY(-50%) scale(2.7);
  transform: translateY(-50%) scale(2.7);
}

.link-hover-slide:hover span:before {
  visibility: hidden;
  opacity: 0;
  top: -50%;
}

.link-hover-slide:hover span:after {
  visibility: visible;
  opacity: 1;
  top: 0;
}

[class*='bg-black'] .link-hover-slide span:before, [class*='bg-black'] .link-hover-slide span:after,
[class*='bg-dark'] .link-hover-slide span:before,
[class*='bg-dark'] .link-hover-slide span:after,
[class*='bg-gradient'] .link-hover-slide span:before,
[class*='bg-gradient'] .link-hover-slide span:after {
  color: white;
}

/*------------------------------------------------
  15. Maps
-------------------------------------------------*/
.gmap {
  width: 100%;
}

.gmap-sm {
  height: 350px;
}

.gmap-md {
  height: 400px;
}

.gmap-lg {
  height: 450px;
}

@media (max-width: 991.98px) {
  .gmap-sm {
    height: 300px;
  }
  .gmap-md {
    height: 350px;
  }
  .gmap-lg {
    height: 400px;
  }
}

/*------------------------------------------------
  16. Process
-------------------------------------------------*/
.process-box {
  position: relative;
  padding-left: 74px;
}

.process-box .process-order {
  z-index: 1;
  position: absolute;
  top: 0;
  left: 0;
  overflow: hidden;
  width: 50px;
  height: 50px;
  line-height: 50px;
  border: 1px dashed rgba(28, 29, 36, 0.2);
  border-radius: 50%;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  color: #1c1d24;
  text-align: center;
  -webkit-transition: linear 0.1s;
  transition: linear 0.1s;
}

.process-box .process-order:before {
  z-index: -1;
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-image: linear-gradient(45deg, #ff5988, #500c7f);
  opacity: 0;
  -webkit-transition: linear 0.1s;
  transition: linear 0.1s;
}

.process-box.process-gradient-2 .process-order:before {
  background-image: linear-gradient(45deg, #2fbdff, #0f2f40);
}

.process-box.process-gradient-3 .process-order:before {
  background-image: linear-gradient(45deg, #ff2f78, #ff7582);
}

.process-box.process-gradient-4 .process-order:before {
  background-image: linear-gradient(45deg, #00DBDE, #FC00FF);
}

.process-box.process-gradient-5 .process-order:before {
  background-image: linear-gradient(45deg, #1db585, #34c759);
}

.process-box.active .process-order, .process-box:hover .process-order {
  border-color: transparent;
  color: white;
}

.process-box.active .process-order:before, .process-box:hover .process-order:before {
  opacity: 1;
}

[class*='bg-black'] .process-box .process-order,
[class*='bg-dark'] .process-box .process-order {
  border-color: rgba(255, 255, 255, 0.3);
  color: white;
}

[class*='bg-black'] .process-box.active .process-order, [class*='bg-black'] .process-box:hover .process-order,
[class*='bg-dark'] .process-box.active .process-order,
[class*='bg-dark'] .process-box:hover .process-order {
  border-color: transparent;
}

[class*='bg-black'] .process-box.active .process-order:before, [class*='bg-black'] .process-box:hover .process-order:before,
[class*='bg-dark'] .process-box.active .process-order:before,
[class*='bg-dark'] .process-box:hover .process-order:before {
  opacity: 1;
}

@media (max-width: 991.98px) {
  .process-box {
    padding-left: 70px;
  }
}

/*------------------------------------------------
  17. Progress bars
-------------------------------------------------*/
.progress-box .animated-progress {
  position: relative;
  background: rgba(28, 29, 36, 0.1);
  height: 4px;
  margin-top: 4px;
  border-radius: 3px;
}

.progress-box .animated-progress div {
  position: absolute;
  display: block;
  background: #1c1d24;
  width: 10%;
  height: 100%;
  border-radius: 4px;
  color: #1c1d24;
  -webkit-transition: width 0.7s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: width 0.7s cubic-bezier(0.165, 0.84, 0.44, 1);
  -webkit-transition-delay: 0.1s;
  transition-delay: 0.1s;
}

.progress-box .animated-progress div:after {
  content: attr(data-progress) "%";
  position: absolute;
  top: -30px;
  right: 0;
  opacity: 0;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 500;
  -webkit-transition: ease-out 0.16s;
  transition: ease-out 0.16s;
}

.progress-box .animated-progress div.progress-show:after {
  opacity: 1;
}

[class*='bg-black'] .progress-box .animated-progress,
[class*='bg-dark'] .progress-box .animated-progress,
[class*='bg-gradient'] .progress-box .animated-progress {
  background: rgba(255, 255, 255, 0.1);
}

[class*='bg-black'] .progress-box .animated-progress div,
[class*='bg-dark'] .progress-box .animated-progress div,
[class*='bg-gradient'] .progress-box .animated-progress div {
  background: white;
  color: white;
}

.progress-box.progress-gradient-1 .animated-progress div {
  background: transparent;
  background-image: linear-gradient(45deg, #ff5988, #500c7f);
}

.progress-box.progress-gradient-2 .animated-progress div {
  background: transparent;
  background-image: linear-gradient(45deg, #2fbdff, #0f2f40);
}

.progress-box.progress-gradient-3 .animated-progress div {
  background: transparent;
  background-image: linear-gradient(45deg, #ff2f78, #ff7582);
}

.progress-box.progress-gradient-4 .animated-progress div {
  background: transparent;
  background-image: linear-gradient(45deg, #00DBDE, #FC00FF);
}

.progress-box.progress-gradient-5 .animated-progress div {
  background: transparent;
  background-image: linear-gradient(45deg, #007990, #6CE5C0);
}

/*------------------------------------------------
  18. Sliders
-------------------------------------------------*/
.sliding-text .swiper-slide,
.sliding-text-reverse .swiper-slide {
  width: auto;
}

.sliding-boxes .swiper-wrapper,
.sliding-text .swiper-wrapper,
.sliding-text-reverse .swiper-wrapper {
  transition-timing-function: linear;
}

.sliding-boxes .swiper-slide {
  max-width: 20%;
}

@media (max-width: 1399.98px) {
  .sliding-boxes .swiper-slide {
    max-width: 25%;
  }
}

@media (max-width: 991.98px) {
  .sliding-boxes .swiper-slide {
    max-width: 30%;
  }
}

@media (max-width: 767.98px) {
  .sliding-boxes .swiper-slide {
    max-width: 50%;
  }
}

@media (max-width: 575.98px) {
  .sliding-boxes .swiper-slide {
    max-width: 70%;
  }
}

.portfolio-horizontal-slider.swiper, .portfolio-horizontal-slider.swiper-container {
  overflow: visible;
}

.swiper-pagination-bullet {
  position: relative;
  display: inline-block;
  opacity: 1;
  background: transparent;
  width: 24px;
  height: 24px;
  margin: 0 2px;
  vertical-align: middle;
}

.swiper-pagination-bullet:before, .swiper-pagination-bullet:after {
  content: '';
  position: absolute;
  border-radius: 50%;
  -webkit-transition: ease-out 0.16s;
  transition: ease-out 0.16s;
}

.swiper-pagination-bullet:before {
  top: 2px;
  right: 2px;
  bottom: 2px;
  left: 2px;
  opacity: 0;
  background: transparent;
  border: 1px solid black;
}

.swiper-pagination-bullet:after {
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  opacity: 0.3;
  background: black;
  width: 5px;
  height: 5px;
}

.swiper-pagination-bullet:hover:after, .swiper-pagination-bullet:focus:after, .swiper-pagination-bullet.swiper-pagination-bullet-active:after {
  opacity: 1;
}

.swiper-pagination-bullet.swiper-pagination-bullet-active:after {
  opacity: 1;
}

.swiper-pagination-bullet.swiper-pagination-bullet-active:before {
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  opacity: 0.4;
}

[class*='bg-black'] .swiper-pagination-bullet:before,
[class*='bg-dark'] .swiper-pagination-bullet:before,
[class*='bg-gradient'] .swiper-pagination-bullet:before {
  border-color: white;
}

[class*='bg-black'] .swiper-pagination-bullet:after,
[class*='bg-dark'] .swiper-pagination-bullet:after,
[class*='bg-gradient'] .swiper-pagination-bullet:after {
  background: white;
  opacity: 0.5;
}

[class*='bg-black'] .swiper-pagination-bullet:hover:after, [class*='bg-black'] .swiper-pagination-bullet:focus:after, [class*='bg-black'] .swiper-pagination-bullet.swiper-pagination-bullet-active:after,
[class*='bg-dark'] .swiper-pagination-bullet:hover:after,
[class*='bg-dark'] .swiper-pagination-bullet:focus:after,
[class*='bg-dark'] .swiper-pagination-bullet.swiper-pagination-bullet-active:after,
[class*='bg-gradient'] .swiper-pagination-bullet:hover:after,
[class*='bg-gradient'] .swiper-pagination-bullet:focus:after,
[class*='bg-gradient'] .swiper-pagination-bullet.swiper-pagination-bullet-active:after {
  opacity: 1;
}

.horizontal-portfolio-pagination.swiper-pagination-horizontal {
  background: rgba(28, 29, 36, 0.3);
  width: auto;
  border-radius: 20px;
  margin: 0;
  padding: 5px;
}

@media (max-width: 991.98px) {
  .horizontal-portfolio-pagination.swiper-pagination-horizontal {
    bottom: 16px;
  }
}

@media (max-width: 991.98px) {
  .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
  .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 0 2px;
  }
  .horizontal-portfolio-pagination .swiper-pagination-bullet {
    width: 17px;
    height: 17px;
  }
}

.blog-slider-featured-3-pagination {
  text-align: center;
}

.blog-slider-featured-3-pagination.swiper-pagination-horizontal {
  width: auto;
  border-radius: 20px;
  margin: 0;
  padding: 0;
}

@media (max-width: 991.98px) {
  .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
  .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 0 2px;
  }
  .blog-slider-featured-3-pagination .swiper-pagination-bullet {
    width: 17px;
    height: 17px;
  }
}

.testimonial-single-wrapper {
  position: relative;
  padding: 0 80px;
}

@media (max-width: 991.98px) {
  .testimonial-single-wrapper {
    padding: 0 66px;
  }
}

.testimonial-single-nav {
  z-index: 1;
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  justify-content: space-between;
}

/*------------------------------------------------
  19. Team
-------------------------------------------------*/
.team-box {
  position: relative;
}

.team-box .team-img {
  overflow: hidden;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

.team-box .team-img img {
  -webkit-transform: scale(1);
  transform: scale(1);
  width: 100%;
  -webkit-transition: transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.team-box .team-hover {
  position: absolute;
  bottom: 0;
  left: 0;
  opacity: 0;
  visibility: hidden;
  width: 100%;
  -webkit-transition: linear 0.1s;
  transition: linear 0.1s;
}

.team-box:hover .team-img img {
  -webkit-transform: scale(1.04);
  transform: scale(1.04);
}

.team-box:hover .team-hover {
  opacity: 1;
  visibility: visible;
}

/*------------------------------------------------
  20. Testimonial
-------------------------------------------------*/
.testimonial-quote-box .quote {
  background: #f1f2fa;
  padding: 24px;
  border-radius: 1em;
}

.testimonial-quote-box .quote-author {
  position: relative;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  padding-top: 26px;
}

.testimonial-quote-box .quote-author:before, .testimonial-quote-box .quote-author:after {
  content: '';
  position: absolute;
  background: #f1f2fa;
  border-radius: 50%;
}

.testimonial-quote-box .quote-author:before {
  top: 14px;
  left: 40px;
  width: 8px;
  height: 8px;
}

.testimonial-quote-box .quote-author:after {
  top: -10px;
  left: 44px;
  width: 20px;
  height: 20px;
}

.testimonial-quote-box .quote-author img {
  display: inline-block;
  width: 60px;
  height: 60px;
  border-radius: 50%;
}

.bg-gray .testimonial-quote-box .quote,
.bg-iceblue .testimonial-quote-box .quote {
  background: white;
}

.bg-gray .testimonial-quote-box .quote-author:before, .bg-gray .testimonial-quote-box .quote-author:after,
.bg-iceblue .testimonial-quote-box .quote-author:before,
.bg-iceblue .testimonial-quote-box .quote-author:after {
  background: white;
}

[class*='bg-black'] .testimonial-quote-box .quote,
[class*='bg-dark'] .testimonial-quote-box .quote,
[class*='bg-gradient'] .testimonial-quote-box .quote {
  background: rgba(255, 255, 255, 0.1);
}

[class*='bg-black'] .testimonial-quote-box .quote-author,
[class*='bg-dark'] .testimonial-quote-box .quote-author,
[class*='bg-gradient'] .testimonial-quote-box .quote-author {
  padding-top: 16px;
}

[class*='bg-black'] .testimonial-quote-box .quote-author:before, [class*='bg-black'] .testimonial-quote-box .quote-author:after,
[class*='bg-dark'] .testimonial-quote-box .quote-author:before,
[class*='bg-dark'] .testimonial-quote-box .quote-author:after,
[class*='bg-gradient'] .testimonial-quote-box .quote-author:before,
[class*='bg-gradient'] .testimonial-quote-box .quote-author:after {
  display: none;
}

/*------------------------------------------------
  21. Text Highlights
-------------------------------------------------*/
[class*='text-highlight'] {
  position: relative;
  display: inline-block;
}

[class*='text-highlight']:before {
  z-index: -1;
  content: '';
  position: absolute;
  left: 50%;
  width: 50%;
  height: 6%;
}

.text-highlight:before {
  bottom: 0;
  background: rgba(28, 29, 36, 0.2);
}

[class*='bg-black'] .text-highlight:before,
[class*='bg-dark'] .text-highlight:before,
[class*='bg-gradient'] .text-highlight:before {
  background: rgba(255, 255, 255, 0.2);
}

[class*='text-highlight-gradient']:before {
  bottom: 8%;
}

.text-highlight-gradient-1:before {
  background-image: linear-gradient(45deg, #ff5988, #500c7f);
}

.text-highlight-gradient-2:before {
  background-image: linear-gradient(45deg, #2fbdff, #0f2f40);
}

.text-highlight-gradient-3:before {
  background-image: linear-gradient(45deg, #ff2f78, #ff7582);
}

.text-highlight-gradient-4:before {
  background-image: linear-gradient(45deg, #00DBDE, #FC00FF);
}

.text-highlight-gradient-5:before {
  background-image: linear-gradient(45deg, #007990, #6CE5C0);
}

/*------------------------------------------------
  22. Title Fade
-------------------------------------------------*/
.title-fade-gradient-1,
.title-fade-gradient-2,
.title-fade-gradient-3,
.title-fade-gradient-4,
.title-fade-gradient-5,
.title-fade-dark {
  overflow: hidden;
  position: relative;
  z-index: 1;
}

.title-fade-gradient-1:before,
.title-fade-gradient-2:before,
.title-fade-gradient-3:before,
.title-fade-gradient-4:before,
.title-fade-gradient-5:before,
.title-fade-dark:before {
  z-index: -1;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0.15;
  width: 100%;
  height: 100%;
}

.title-fade-gradient-1:before {
  background-image: linear-gradient(90deg, #ff5988, transparent 90%);
}

.title-fade-gradient-2:before {
  background-image: linear-gradient(90deg, #2fbdff, transparent 90%);
}

.title-fade-gradient-3:before {
  background-image: linear-gradient(90deg, #ff2f78, transparent 90%);
}

.title-fade-gradient-4:before {
  background-image: linear-gradient(90deg, #00DBDE, transparent 90%);
}

.title-fade-gradient-5:before {
  background-image: linear-gradient(90deg, #007990, transparent 90%);
}

.title-fade-dark:before {
  background-image: linear-gradient(90deg, rgba(28, 29, 36, 0.5), transparent 90%);
}

/*------------------------------------------------
  23. Border Grid
-------------------------------------------------*/
.border-grid {
  list-style-type: none;
  overflow: hidden;
  margin: 0;
  padding: 0;
  text-align: center;
}

.border-grid li {
  position: relative;
  float: left;
  width: 16.6%;
  margin: 0;
  padding: 30px;
}

.border-grid li:before, .border-grid li:after {
  content: '';
  position: absolute;
}

.border-grid li:before {
  top: 0;
  left: -1px;
  height: 100%;
  border-left: 1px dashed rgba(28, 29, 36, 0.2);
}

.border-grid li:after {
  left: 0;
  bottom: -1px;
  width: 100%;
  border-bottom: 1px dashed rgba(28, 29, 36, 0.2);
}

@media (max-width: 991.98px) {
  .border-grid li {
    width: 25%;
  }
}

@media (max-width: 767.98px) {
  .border-grid li {
    width: 33.3%;
  }
}

@media (max-width: 575.98px) {
  .border-grid li {
    width: 50%;
  }
}

.border-grid.column-5 li {
  width: 20%;
}

@media (max-width: 991.98px) {
  .border-grid.column-5 li {
    width: 25%;
  }
}

@media (max-width: 767.98px) {
  .border-grid.column-5 li {
    width: 33.3%;
  }
}

@media (max-width: 575.98px) {
  .border-grid.column-5 li {
    width: 50%;
  }
}

.border-grid.column-4 li {
  width: 25%;
}

@media (max-width: 767.98px) {
  .border-grid.column-4 li {
    width: 33.3%;
  }
}

@media (max-width: 575.98px) {
  .border-grid.column-4 li {
    width: 50%;
  }
}

.border-grid.column-3 li {
  width: 33.3%;
}

@media (max-width: 767.98px) {
  .border-grid.column-3 li {
    width: 50%;
  }
}

.border-grid.column-2 li {
  width: 50%;
}

.border-grid.border-style-solid {
  border: 0;
}

.border-grid.border-style-solid li:before {
  border-left-style: solid;
}

.border-grid.border-style-solid li:after {
  border-bottom-style: solid;
}

.border-grid.border-style-dotted {
  border: 0;
}

.border-grid.border-style-dotted li:before {
  border-left-style: dotted;
}

.border-grid.border-style-dotted li:after {
  border-bottom-style: dotted;
}

[class*='bg-black'] .border-grid li:before, [class*='bg-black'] .border-grid li:after,
[class*='bg-dark'] .border-grid li:before,
[class*='bg-dark'] .border-grid li:after,
[class*='bg-gradient'] .border-grid li:before,
[class*='bg-gradient'] .border-grid li:after {
  border-color: rgba(255, 255, 255, 0.2);
}

/*------------------------------------------------
  24. Fullscreen Menu
-------------------------------------------------*/
.header .fm-toggle {
  display: inline-block;
  position: relative;
  background: transparent;
  border: 0;
  color: black;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
}

.header .fm-toggle span {
  position: relative;
  display: inline-block;
  width: 24px;
  height: 10px;
  margin-left: 10px;
}

.header .fm-toggle span:before, .header .fm-toggle span:after {
  content: '';
  position: absolute;
  right: 0;
  background: black;
  height: 2px;
  border-radius: 2px;
  -webkit-transition: linear 0.1s;
  transition: linear 0.1s;
}

.header .fm-toggle span:before {
  top: 0;
  width: 70%;
}

.header .fm-toggle span:after {
  bottom: 0;
  width: 100%;
}

.header .fm-toggle:hover span:before {
  width: 100%;
}

.header.transparent-light .fm-toggle, .header.header-dark .fm-toggle {
  color: white;
}

.header.transparent-light .fm-toggle span:before, .header.transparent-light .fm-toggle span:after, .header.header-dark .fm-toggle span:before, .header.header-dark .fm-toggle span:after {
  background: white;
}

.header.logo-center .container,
.header.logo-center .container-fluid {
  justify-content: space-between;
}

.header.logo-center .header-logo {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

.header.logo-center .header-extra {
  margin: 0;
}

.fullscreen-menu {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 998;
  visibility: hidden;
  opacity: 0;
  background: black;
  width: 100%;
  height: 100%;
  -webkit-transition: ease-out 0.2s;
  transition: ease-out 0.2s;
}

.fullscreen-menu.show {
  visibility: visible;
  opacity: 1;
}

.fullscreen-menu .fm-close {
  position: absolute;
  top: 50px;
  right: 50px;
}

.fullscreen-menu .fm-close i {
  -webkit-transition: transform 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: transform 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.fullscreen-menu .fm-close:hover i {
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
}

/*------------------------------------------------
  25. Header
-------------------------------------------------*/
.header {
  z-index: 997;
  width: 100%;
  height: 80px;
  -webkit-transition: ease-in-out 0.2s;
  transition: ease-in-out 0.2s;
}

.header .container,
.header .container-fluid {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  height: 100%;
}

.header.hide {
  -webkit-transform: translateY(-100%);
  transform: translateY(-100%);
}

.header .header-logo {
  margin-right: auto;
}

.header .header-logo * {
  margin: 0;
}

.header .header-menu .nav {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 500;
}

.header .header-menu .nav .nav-item {
  position: relative;
}

.header .header-menu .nav .nav-item .nav-link {
  color: black;
}

.header .header-menu .nav .nav-item .nav-link:hover {
  color: rgba(0, 0, 0, 0.8);
}

.header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item {
  list-style-type: none;
}

.header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item .nav-subdropdown .nav-subdropdown-item {
  list-style-type: none;
}

.header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item .nav-subdropdown-toggle {
  position: absolute;
  font-size: 0.85em;
}

.header .header-menu .nav .nav-item .nav-dropdown-toggle,
.header .header-menu .nav .nav-item .nav-megadropdown-toggle {
  font-size: 0.85em;
}

.header.header-white {
  background: rgba(255, 255, 255, 0.9);
}

.header.header-dark {
  background: rgba(0, 0, 0, 0.85);
}

.header.header-dark:not(.transparent-dark) .header-logo, .header.transparent-light .header-logo {
  color: white;
}

.header.header-dark:not(.transparent-dark) .header-logo h1, .header.header-dark:not(.transparent-dark) .header-logo h2, .header.header-dark:not(.transparent-dark) .header-logo h3, .header.header-dark:not(.transparent-dark) .header-logo h4, .header.header-dark:not(.transparent-dark) .header-logo h5, .header.header-dark:not(.transparent-dark) .header-logo h6, .header.header-dark:not(.transparent-dark) .header-logo i, .header.transparent-light .header-logo h1, .header.transparent-light .header-logo h2, .header.transparent-light .header-logo h3, .header.transparent-light .header-logo h4, .header.transparent-light .header-logo h5, .header.transparent-light .header-logo h6, .header.transparent-light .header-logo i {
  color: white;
}

.header.header-dark:not(.transparent-dark) .header-logo a, .header.transparent-light .header-logo a {
  color: white;
}

.header.header-dark:not(.transparent-dark) .header-logo a i, .header.transparent-light .header-logo a i {
  color: white;
}

.header.header-dark:not(.transparent-dark) .header-logo a:hover, .header.header-dark:not(.transparent-dark) .header-logo a:focus, .header.transparent-light .header-logo a:hover, .header.transparent-light .header-logo a:focus {
  color: white;
}

.header.header-dark:not(.transparent-dark) .header-logo a:hover i, .header.header-dark:not(.transparent-dark) .header-logo a:focus i, .header.transparent-light .header-logo a:hover i, .header.transparent-light .header-logo a:focus i {
  color: white;
}

.header.header-dark:not(.transparent-dark) .header-extra, .header.transparent-light .header-extra {
  color: rgba(255, 255, 255, 0.8);
}

.header.header-dark:not(.transparent-dark) .header-extra h1, .header.header-dark:not(.transparent-dark) .header-extra h2, .header.header-dark:not(.transparent-dark) .header-extra h3, .header.header-dark:not(.transparent-dark) .header-extra h4, .header.header-dark:not(.transparent-dark) .header-extra h5, .header.header-dark:not(.transparent-dark) .header-extra h6, .header.header-dark:not(.transparent-dark) .header-extra i,
.header.header-dark:not(.transparent-dark) .header-extra .h1, .header.header-dark:not(.transparent-dark) .header-extra .h2, .header.header-dark:not(.transparent-dark) .header-extra .h3, .header.header-dark:not(.transparent-dark) .header-extra .h4, .header.header-dark:not(.transparent-dark) .header-extra .h5, .header.header-dark:not(.transparent-dark) .header-extra .h6, .header.transparent-light .header-extra h1, .header.transparent-light .header-extra h2, .header.transparent-light .header-extra h3, .header.transparent-light .header-extra h4, .header.transparent-light .header-extra h5, .header.transparent-light .header-extra h6, .header.transparent-light .header-extra i,
.header.transparent-light .header-extra .h1, .header.transparent-light .header-extra .h2, .header.transparent-light .header-extra .h3, .header.transparent-light .header-extra .h4, .header.transparent-light .header-extra .h5, .header.transparent-light .header-extra .h6 {
  color: white;
}

.header.header-dark:not(.transparent-dark) .header-extra a:not([class^='button']):not([class^='link-hover']), .header.transparent-light .header-extra a:not([class^='button']):not([class^='link-hover']) {
  color: white;
}

.header.header-dark:not(.transparent-dark) .header-extra a:not([class^='button']):not([class^='link-hover']) i, .header.transparent-light .header-extra a:not([class^='button']):not([class^='link-hover']) i {
  color: white;
}

.header.header-dark:not(.transparent-dark) .header-extra a:not([class^='button']):not([class^='link-hover']):hover, .header.header-dark:not(.transparent-dark) .header-extra a:not([class^='button']):not([class^='link-hover']):focus, .header.transparent-light .header-extra a:not([class^='button']):not([class^='link-hover']):hover, .header.transparent-light .header-extra a:not([class^='button']):not([class^='link-hover']):focus {
  color: rgba(255, 255, 255, 0.8);
}

.header.header-dark:not(.transparent-dark) .header-extra a:not([class^='button']):not([class^='link-hover']):hover i, .header.header-dark:not(.transparent-dark) .header-extra a:not([class^='button']):not([class^='link-hover']):focus i, .header.transparent-light .header-extra a:not([class^='button']):not([class^='link-hover']):hover i, .header.transparent-light .header-extra a:not([class^='button']):not([class^='link-hover']):focus i {
  color: rgba(255, 255, 255, 0.8);
}

.header.transparent-light, .header.transparent-dark {
  background: transparent;
}

.header.transparent-light:not(.sticky-autohide):not(.sticky), .header.transparent-dark:not(.sticky-autohide):not(.sticky) {
  position: absolute;
  top: 0;
  left: 0;
}

.header.sticky-autohide, .header.sticky {
  position: fixed;
  top: 0;
  left: 0;
}

@media (min-width: 992px) {
  .header .header-logo {
    z-index: 998;
  }
  .header .header-menu {
    margin-left: auto;
  }
  .header .header-menu .nav .nav-item {
    margin-right: 24px;
    height: 80px;
    display: inline-flex;
    align-items: center;
  }
  .header .header-menu .nav .nav-item:last-child {
    margin-right: 0;
  }
  .header .header-menu .nav .nav-item .nav-link {
    position: relative;
    padding: 0;
  }
  .header .header-menu.nav-link-hover-line .nav .nav-item .nav-link:before {
    content: '';
    position: absolute;
    right: 0;
    bottom: -1px;
    left: 0;
    background: black;
    height: 1px;
    -webkit-animation: line-out 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) both;
    animation: line-out 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) both;
  }
  .header .header-menu.nav-link-hover-line .nav .nav-item .nav-link:hover {
    color: black;
  }
  .header .header-menu.nav-link-hover-line .nav .nav-item .nav-link:hover:before {
    width: 100%;
    -webkit-animation: line-in 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) both;
    animation: line-in 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) both;
  }
  .header .header-menu.nav-link-hover-slide .nav .nav-item .nav-link {
    position: relative;
    color: transparent;
  }
  .header .header-menu.nav-link-hover-slide .nav .nav-item .nav-link:before, .header .header-menu.nav-link-hover-slide .nav .nav-item .nav-link:after {
    content: attr(data-text);
    position: absolute;
    left: 0;
    color: #1c1d24;
    -webkit-transition: ease-out 0.16s;
    transition: ease-out 0.16s;
  }
  .header .header-menu.nav-link-hover-slide .nav .nav-item .nav-link:before {
    top: 0;
  }
  .header .header-menu.nav-link-hover-slide .nav .nav-item .nav-link:after {
    visibility: hidden;
    opacity: 0;
    top: 50%;
  }
  .header .header-menu.nav-link-hover-slide .nav .nav-item .nav-link:hover:before {
    visibility: hidden;
    opacity: 0;
    top: -50%;
  }
  .header .header-menu.nav-link-hover-slide .nav .nav-item .nav-link:hover:after {
    visibility: visible;
    opacity: 1;
    top: 0;
  }
  .header .header-menu .nav .nav-item .nav-dropdown-toggle,
  .header .header-menu .nav .nav-item .nav-megadropdown-toggle {
    display: none;
  }
  .header .header-menu .nav .nav-item .nav-dropdown {
    z-index: 998;
    visibility: hidden;
    opacity: 0;
    position: absolute;
    top: 80px;
    right: 0;
    background: white;
    width: 250px;
    padding: 28px 0;
    -webkit-box-shadow: 0 8px 34px 0 rgba(22, 24, 26, 0.13);
    box-shadow: 0 8px 34px 0 rgba(22, 24, 26, 0.13);
    -webkit-transition: linear 0.06s;
    transition: linear 0.06s;
  }
  .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item {
    position: relative;
    list-style-type: none;
    padding: 0 30px;
    margin-bottom: 10px;
  }
  .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item.dropdown-icon-space {
    padding-right: 46px;
  }
  .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item:last-child {
    margin-bottom: 0;
  }
  .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item .nav-dropdown-link {
    display: block;
    width: 100%;
    color: rgba(28, 29, 36, 0.7);
  }
  .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item .nav-dropdown-link:hover {
    color: #1c1d24;
  }
  .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item .nav-subdropdown {
    position: absolute;
    top: -28px;
    right: 100%;
    visibility: hidden;
    opacity: 0;
    background: white;
    width: 250px;
    padding: 28px 0;
    -webkit-box-shadow: 0 8px 34px 0 rgba(22, 24, 26, 0.13);
    box-shadow: 0 8px 34px 0 rgba(22, 24, 26, 0.13);
    -webkit-transition: linear 0.06s;
    transition: linear 0.06s;
  }
  .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item .nav-subdropdown .nav-subdropdown-item {
    margin-bottom: 10px;
    padding: 0 30px;
  }
  .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item .nav-subdropdown .nav-subdropdown-item:last-child {
    margin-bottom: 0;
  }
  .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item .nav-subdropdown .nav-subdropdown-item .nav-subdropdown-link {
    display: block;
    width: 100%;
    color: rgba(28, 29, 36, 0.7);
  }
  .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item .nav-subdropdown .nav-subdropdown-item .nav-subdropdown-link:hover {
    color: #1c1d24;
  }
  .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item .nav-subdropdown-toggle {
    top: 50%;
    right: 30px;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
  }
  .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item .nav-subdropdown-toggle i {
    color: rgba(28, 29, 36, 0.7);
  }
  .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item:hover .nav-subdropdown-toggle i {
    color: #1c1d24;
  }
  .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item:hover .nav-subdropdown {
    visibility: visible;
    opacity: 1;
  }
  .header .header-menu .nav .nav-item .nav-dropdown.style-2 {
    padding: 0;
  }
  .header .header-menu .nav .nav-item .nav-dropdown.style-2 .nav-dropdown-item {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    align-items: center;
    margin-bottom: 0;
    padding: 16px 30px;
    border-bottom: 1px dashed rgba(28, 29, 36, 0.2);
  }
  .header .header-menu .nav .nav-item .nav-dropdown.style-2 .nav-dropdown-item:last-child {
    border-bottom: 0;
  }
  .header .header-menu .nav .nav-item .nav-dropdown.style-2 .nav-dropdown-item .nav-subdropdown {
    padding: 0;
  }
  .header .header-menu .nav .nav-item .nav-dropdown.style-2 .nav-dropdown-item .nav-subdropdown .nav-subdropdown-item {
    margin: 0;
    padding: 16px 30px;
    border-bottom: 1px dashed rgba(28, 29, 36, 0.2);
  }
  .header .header-menu .nav .nav-item .nav-dropdown.style-2 .nav-dropdown-item .nav-subdropdown .nav-subdropdown-item:last-child {
    border-bottom: 0;
  }
  .header .header-menu .nav .nav-item:hover .nav-dropdown {
    visibility: visible;
    opacity: 1;
  }
  .header .header-menu .nav .nav-item.mega-nav-item {
    position: static;
  }
  .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown {
    z-index: 998;
    visibility: hidden;
    opacity: 0;
    position: absolute;
    top: 80px;
    right: 0;
    background: white;
    width: 100%;
    padding: 30px;
    color: #787a7c;
    -webkit-box-shadow: 0 8px 34px 0 rgba(22, 24, 26, 0.13);
    box-shadow: 0 8px 34px 0 rgba(22, 24, 26, 0.13);
    -webkit-transition: linear 0.06s;
    transition: linear 0.06s;
  }
  .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown h1, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown h2, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown h3, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown h4, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown h5, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown h6, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown i,
  .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown .h1, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown .h2, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown .h3, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown .h4, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown .h5, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown .h6 {
    color: #1c1d24;
  }
  .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown a:not([class^='button']):not([class^='link-hover']) {
    color: rgba(28, 29, 36, 0.8);
  }
  .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown a:not([class^='button']):not([class^='link-hover']):hover, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown a:not([class^='button']):not([class^='link-hover']):focus {
    color: #1c1d24;
  }
  .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown.mega-nav-dropdown-dark {
    background: rgba(28, 29, 36, 0.9);
    color: rgba(255, 255, 255, 0.8);
  }
  .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown.mega-nav-dropdown-dark h1, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown.mega-nav-dropdown-dark h2, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown.mega-nav-dropdown-dark h3, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown.mega-nav-dropdown-dark h4, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown.mega-nav-dropdown-dark h5, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown.mega-nav-dropdown-dark h6, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown.mega-nav-dropdown-dark i,
  .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown.mega-nav-dropdown-dark .h1, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown.mega-nav-dropdown-dark .h2, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown.mega-nav-dropdown-dark .h3, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown.mega-nav-dropdown-dark .h4, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown.mega-nav-dropdown-dark .h5, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown.mega-nav-dropdown-dark .h6 {
    color: white;
  }
  .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown.mega-nav-dropdown-dark a:not([class^='button']):not([class^='link-hover']) {
    color: rgba(255, 255, 255, 0.8);
  }
  .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown.mega-nav-dropdown-dark a:not([class^='button']):not([class^='link-hover']) i {
    color: rgba(255, 255, 255, 0.8);
  }
  .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown.mega-nav-dropdown-dark a:not([class^='button']):not([class^='link-hover']):hover, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown.mega-nav-dropdown-dark a:not([class^='button']):not([class^='link-hover']):focus {
    color: white;
  }
  .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown.mega-nav-dropdown-dark a:not([class^='button']):not([class^='link-hover']):hover i, .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown.mega-nav-dropdown-dark a:not([class^='button']):not([class^='link-hover']):focus i {
    color: white;
  }
  .header .header-menu .nav .nav-item.mega-nav-item:hover .mega-nav-dropdown {
    visibility: visible;
    opacity: 1;
  }
  .header .header-menu .nav.dropdown-dark .nav-item .nav-dropdown {
    background: rgba(28, 29, 36, 0.9);
    color: white;
    font-weight: 400;
  }
  .header .header-menu .nav.dropdown-dark .nav-item .nav-dropdown a, .header .header-menu .nav.dropdown-dark .nav-item .nav-dropdown i {
    color: white;
  }
  .header .header-menu .nav.dropdown-dark .nav-item .nav-dropdown .nav-dropdown-item .nav-dropdown-link {
    color: rgba(255, 255, 255, 0.8);
  }
  .header .header-menu .nav.dropdown-dark .nav-item .nav-dropdown .nav-dropdown-item .nav-dropdown-link:hover {
    color: white;
  }
  .header .header-menu .nav.dropdown-dark .nav-item .nav-dropdown .nav-dropdown-item .nav-subdropdown-toggle i {
    color: rgba(255, 255, 255, 0.8);
  }
  .header .header-menu .nav.dropdown-dark .nav-item .nav-dropdown .nav-dropdown-item .nav-subdropdown {
    background: rgba(28, 29, 36, 0.9);
    color: white;
  }
  .header .header-menu .nav.dropdown-dark .nav-item .nav-dropdown .nav-dropdown-item .nav-subdropdown .nav-subdropdown-item .nav-subdropdown-link {
    color: rgba(255, 255, 255, 0.8);
  }
  .header .header-menu .nav.dropdown-dark .nav-item .nav-dropdown .nav-dropdown-item .nav-subdropdown .nav-subdropdown-item .nav-subdropdown-link:hover {
    color: white;
  }
  .header .header-menu .nav.dropdown-dark .nav-item .nav-dropdown .nav-dropdown-item:hover .nav-subdropdown-toggle i {
    color: white;
  }
  .header .header-menu .nav.dropdown-dark .nav-item .nav-dropdown.style-2 .nav-dropdown-item {
    border-color: rgba(255, 255, 255, 0.2);
  }
  .header .header-menu .nav.dropdown-dark .nav-item .nav-dropdown.style-2 .nav-dropdown-item .nav-subdropdown .nav-subdropdown-item {
    border-color: rgba(255, 255, 255, 0.2);
  }
  .header .header-extra {
    z-index: 998;
    margin-left: auto;
  }
  .header.nav-left .header-logo {
    margin-right: 30px;
  }
  .header.nav-left .header-menu {
    margin-right: auto;
    margin-left: 0;
  }
  .header.nav-left .header-menu .nav .nav-item .nav-dropdown {
    right: auto;
    left: 0;
  }
  .header.nav-left .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item .nav-subdropdown {
    right: auto;
    left: 100%;
  }
  .header.nav-left .header-menu .nav .nav-item .nav-dropdown, .header.nav-center .header-menu .nav .nav-item .nav-dropdown {
    right: auto;
    left: 0;
  }
  .header.nav-left .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item .nav-subdropdown, .header.nav-center .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item .nav-subdropdown {
    right: auto;
    left: 100%;
  }
  .header.nav-center .nav {
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    margin: 0 auto;
    text-align: center;
  }
  .header.nav-center .nav .nav-item {
    text-align: left;
  }
  .header.header-dark:not(.transparent-dark), .header.transparent-light {
    color: rgba(255, 255, 255, 0.8);
  }
  .header.header-dark:not(.transparent-dark) h1, .header.header-dark:not(.transparent-dark) h2, .header.header-dark:not(.transparent-dark) h3, .header.header-dark:not(.transparent-dark) h4, .header.header-dark:not(.transparent-dark) h5, .header.header-dark:not(.transparent-dark) h6, .header.header-dark:not(.transparent-dark) i,
  .header.header-dark:not(.transparent-dark) .h1, .header.header-dark:not(.transparent-dark) .h2, .header.header-dark:not(.transparent-dark) .h3, .header.header-dark:not(.transparent-dark) .h4, .header.header-dark:not(.transparent-dark) .h5, .header.header-dark:not(.transparent-dark) .h6, .header.transparent-light h1, .header.transparent-light h2, .header.transparent-light h3, .header.transparent-light h4, .header.transparent-light h5, .header.transparent-light h6, .header.transparent-light i,
  .header.transparent-light .h1, .header.transparent-light .h2, .header.transparent-light .h3, .header.transparent-light .h4, .header.transparent-light .h5, .header.transparent-light .h6 {
    color: white;
  }
  .header.header-dark:not(.transparent-dark) a:not([class^='button']):not([class^='link-hover']), .header.transparent-light a:not([class^='button']):not([class^='link-hover']) {
    color: white;
  }
  .header.header-dark:not(.transparent-dark) a:not([class^='button']):not([class^='link-hover']) i, .header.transparent-light a:not([class^='button']):not([class^='link-hover']) i {
    color: white;
  }
  .header.header-dark:not(.transparent-dark) a:not([class^='button']):not([class^='link-hover']):hover, .header.header-dark:not(.transparent-dark) a:not([class^='button']):not([class^='link-hover']):focus, .header.transparent-light a:not([class^='button']):not([class^='link-hover']):hover, .header.transparent-light a:not([class^='button']):not([class^='link-hover']):focus {
    color: rgba(255, 255, 255, 0.8);
  }
  .header.header-dark:not(.transparent-dark) a:not([class^='button']):not([class^='link-hover']):hover i, .header.header-dark:not(.transparent-dark) a:not([class^='button']):not([class^='link-hover']):focus i, .header.transparent-light a:not([class^='button']):not([class^='link-hover']):hover i, .header.transparent-light a:not([class^='button']):not([class^='link-hover']):focus i {
    color: rgba(255, 255, 255, 0.8);
  }
  .header.header-dark:not(.transparent-dark) .header-menu .nav .nav-item .nav-link, .header.transparent-light .header-menu .nav .nav-item .nav-link {
    color: white;
  }
  .header.header-dark:not(.transparent-dark) .header-menu .nav .nav-item .nav-link:hover, .header.transparent-light .header-menu .nav .nav-item .nav-link:hover {
    color: rgba(255, 255, 255, 0.8);
  }
  .header.header-dark:not(.transparent-dark) .header-menu.nav-link-hover-line .nav .nav-item .nav-link:before, .header.transparent-light .header-menu.nav-link-hover-line .nav .nav-item .nav-link:before {
    background: white;
  }
  .header.header-dark:not(.transparent-dark) .header-menu.nav-link-hover-line .nav .nav-item .nav-link:hover, .header.transparent-light .header-menu.nav-link-hover-line .nav .nav-item .nav-link:hover {
    color: white;
  }
  .header.header-dark:not(.transparent-dark) .header-menu.nav-link-hover-slide .nav .nav-item .nav-link:before, .header.header-dark:not(.transparent-dark) .header-menu.nav-link-hover-slide .nav .nav-item .nav-link:after, .header.transparent-light .header-menu.nav-link-hover-slide .nav .nav-item .nav-link:before, .header.transparent-light .header-menu.nav-link-hover-slide .nav .nav-item .nav-link:after {
    color: white;
  }
  .header.header-dark:not(.transparent-dark) .header-menu.nav-link-hover-line .nav .nav-item .nav-link:before, .header.transparent-light .header-menu.nav-link-hover-line .nav .nav-item .nav-link:before {
    background: white;
  }
  .header.header-dark:not(.transparent-dark) .header-menu.nav-link-hover-line .nav .nav-item .nav-link:hover, .header.transparent-light .header-menu.nav-link-hover-line .nav .nav-item .nav-link:hover {
    color: white;
  }
  .header.header-dark:not(.transparent-dark) .header-menu .nav, .header.transparent-light .header-menu .nav {
    font-weight: 400;
  }
  .header.transparent-light, .header.transparent-dark {
    backdrop-filter: none;
  }
  .header.header-lg {
    height: 90px;
  }
  .header.header-lg .header-menu .nav .nav-item {
    height: 90px;
  }
  .header.header-lg .header-menu .nav .nav-item .nav-dropdown,
  .header.header-lg .header-menu .nav .nav-item .mega-nav-dropdown {
    top: 90px;
  }
  .header.header-xl {
    height: 100px;
  }
  .header.header-xl .header-menu .nav .nav-item {
    height: 100px;
  }
  .header.header-xl .header-menu .nav .nav-item .nav-dropdown,
  .header.header-xl .header-menu .nav .nav-item .mega-nav-dropdown {
    top: 100px;
  }
  .header .mobile-menu-toggle {
    display: none;
  }
}

@media (max-width: 991.98px) {
  .header {
    height: 70px;
    overflow: visible;
  }
  .header .header-menu {
    z-index: 997;
    position: fixed;
    top: 0;
    left: -100%;
    overflow-y: auto;
    background: white;
    width: 320px;
    max-width: 100%;
    height: 100%;
    -webkit-box-shadow: 0 0 36px 0 rgba(22, 25, 28, 0.17);
    box-shadow: 0 0 36px 0 rgba(22, 25, 28, 0.17);
    padding: 30px;
    -webkit-transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
    transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  }
  .header .header-menu .nav {
    display: block;
  }
  .header .header-menu .nav .nav-item {
    margin-bottom: 8px;
  }
  .header .header-menu .nav .nav-item:last-child {
    margin-bottom: 0;
  }
  .header .header-menu .nav .nav-item .nav-link {
    display: inline-block;
    padding: 0;
  }
  .header .header-menu .nav .nav-item .nav-dropdown-toggle {
    position: absolute;
    top: 0;
    right: 0;
    cursor: pointer;
  }
  .header .header-menu .nav .nav-item .nav-dropdown-toggle i {
    color: rgba(28, 29, 36, 0.7);
  }
  .header .header-menu .nav .nav-item .nav-dropdown-toggle:hover i, .header .header-menu .nav .nav-item .nav-dropdown-toggle.active i {
    color: #1c1d24;
  }
  .header .header-menu .nav .nav-item .nav-dropdown {
    display: none;
    padding: 8px 0 0 16px;
  }
  .header .header-menu .nav .nav-item .nav-dropdown.show {
    display: block;
  }
  .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item {
    position: relative;
    margin-bottom: 8px;
  }
  .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item.dropdown-icon-space {
    padding-right: 16px;
  }
  .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item:last-child {
    margin-bottom: 0;
  }
  .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item .nav-subdropdown {
    display: none;
    padding: 8px 0 0 16px;
  }
  .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item .nav-subdropdown.show {
    display: block;
  }
  .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item .nav-subdropdown .nav-subdropdown-item {
    margin-bottom: 8px;
  }
  .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item .nav-subdropdown .nav-subdropdown-item:last-child {
    margin-bottom: 0;
  }
  .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item .nav-subdropdown-toggle {
    top: 0;
    right: 0;
    height: 23px;
    line-height: 23px;
    cursor: pointer;
  }
  .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item .nav-subdropdown-toggle i {
    color: rgba(28, 29, 36, 0.7);
  }
  .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item .nav-subdropdown-toggle:hover i, .header .header-menu .nav .nav-item .nav-dropdown .nav-dropdown-item .nav-subdropdown-toggle.active i {
    color: #1c1d24;
  }
  .header .header-menu .nav .nav-item .nav-dropdown.style-2 .nav-dropdown-item {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    align-items: center;
  }
  .header .header-menu .nav .nav-item.mega-nav-item .nav-megadropdown-toggle {
    position: absolute;
    top: 0;
    right: 0;
    cursor: pointer;
  }
  .header .header-menu .nav .nav-item.mega-nav-item .nav-megadropdown-toggle i {
    color: rgba(28, 29, 36, 0.7);
  }
  .header .header-menu .nav .nav-item.mega-nav-item .nav-megadropdown-toggle:hover i, .header .header-menu .nav .nav-item.mega-nav-item .nav-megadropdown-toggle.active i {
    color: #1c1d24;
  }
  .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown {
    display: none;
    padding: 8px 0 0 16px;
  }
  .header .header-menu .nav .nav-item.mega-nav-item .mega-nav-dropdown.show {
    display: block;
  }
  .header.header-menu-show .header-menu {
    left: 0;
  }
  .header .mobile-menu-toggle {
    display: inline-block;
    position: relative;
    background: transparent;
    border: 0;
    margin-left: 0px;
    color: black;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  }
  .header .mobile-menu-toggle span {
    position: relative;
    display: inline-block;
    width: 24px;
    height: 10px;
  }
  .header .mobile-menu-toggle span:before, .header .mobile-menu-toggle span:after {
    content: '';
    position: absolute;
    right: 0;
    background: black;
    height: 2px;
    border-radius: 2px;
    -webkit-transition: linear 0.1s;
    transition: linear 0.1s;
  }
  .header .mobile-menu-toggle span:before {
    top: 0;
    width: 70%;
  }
  .header .mobile-menu-toggle span:after {
    bottom: 0;
    width: 100%;
  }
  .header .mobile-menu-toggle:hover span:before {
    width: 100%;
  }
  .header .mobile-menu-toggle.toggle-close span:before {
    top: 50%;
    -webkit-transform: translateY(-50%) rotate(45deg);
    transform: translateY(-50%) rotate(45deg);
    width: 100%;
  }
  .header .mobile-menu-toggle.toggle-close span:after {
    top: 50%;
    bottom: auto;
    -webkit-transform: translateY(-50%) rotate(-45deg);
    transform: translateY(-50%) rotate(-45deg);
  }
  .header.transparent-light .mobile-menu-toggle, .header.header-dark:not(.transparent-dark) .mobile-menu-toggle {
    color: white;
  }
  .header.transparent-light .mobile-menu-toggle span:before, .header.transparent-light .mobile-menu-toggle span:after, .header.header-dark:not(.transparent-dark) .mobile-menu-toggle span:before, .header.header-dark:not(.transparent-dark) .mobile-menu-toggle span:after {
    background: white;
  }
}

.header-placeholder {
  height: 80px;
}

.header-placeholder-lg {
  height: 90px;
}

.header-placeholder-xl {
  height: 100px;
}

@media (max-width: 991.98px) {
  .header-placeholder, .header-placeholder-lg, .header-placeholder-xl {
    height: 70px;
  }
}

/*------------------------------------------------
  26. Portfolio
-------------------------------------------------*/
.portfolio-box {
  position: relative;
}

.portfolio-box a {
  display: block;
}

.portfolio-box .portfolio-img {
  position: relative;
  overflow: hidden;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  -webkit-transition: transform 0.8s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: transform 0.8s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.portfolio-box .portfolio-img img {
  -webkit-transform: scale(1);
  transform: scale(1);
  width: 100%;
  -webkit-transition: transform 0.8s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: transform 0.8s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.portfolio-box:hover .portfolio-img {
  -webkit-transform: translate3d(0, 0, 0) scale(0.96);
  transform: translate3d(0, 0, 0) scale(0.96);
}

.portfolio-box:hover .portfolio-img img {
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
}

.portfolio-box .portfolio-mobile-caption {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  justify-content: space-between;
  padding-top: 8px;
}

.portfolio-box .portfolio-mobile-caption * {
  margin: 0;
}

@media (min-width: 992px) {
  .portfolio-box .portfolio-mobile-caption {
    display: none;
  }
}

.filter ul {
  padding: 0;
}

.filter ul li {
  z-index: 1;
  list-style-type: none;
  position: relative;
  display: inline-block;
  color: #1c1d24;
  margin-right: 20px;
  cursor: pointer;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  -webkit-transition: linear 0.1s;
  transition: linear 0.1s;
}

.filter ul li:before {
  content: '';
  position: absolute;
  right: 0;
  bottom: -1px;
  left: 0;
  background: black;
  height: 1px;
  -webkit-animation: line-out 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) both;
  animation: line-out 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) both;
}

.filter ul li:hover, .filter ul li.mixitup-control-active {
  color: black;
}

.filter ul li:hover:before, .filter ul li.mixitup-control-active:before {
  width: 100%;
  -webkit-animation: line-in 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) both;
  animation: line-in 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) both;
}

.filter ul li:last-child {
  margin-right: 0;
}

[class*='bg-black'] .filter ul li,
[class*='bg-dark'] .filter ul li,
[class*='bg-gradient'] .filter ul li {
  color: white;
}

[class*='bg-black'] .filter ul li:before,
[class*='bg-dark'] .filter ul li:before,
[class*='bg-gradient'] .filter ul li:before {
  background: white;
}

.vertical-portfolio {
  position: relative;
  width: 100%;
  height: 100%;
}

.vertical-portfolio .vertical-portfolio-captions {
  height: 100%;
  max-height: 100%;
}

.vertical-portfolio .vertical-portfolio-captions ul {
  padding: 70px 0;
}

.vertical-portfolio .vertical-portfolio-captions ul li {
  list-style-type: none;
}

@media (min-width: 992px) {
  .vertical-portfolio .vertical-portfolio-captions {
    margin-left: calc(50% + 30px);
  }
  .vertical-portfolio .vertical-portfolio-captions ul li {
    margin-bottom: 40px;
  }
  .vertical-portfolio .vertical-portfolio-captions ul li:last-child {
    margin-bottom: 0;
  }
  .vertical-portfolio .vertical-portfolio-captions ul li img {
    position: fixed;
    top: 50%;
    right: calc(50% + 30px);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    opacity: 0;
    max-width: 40vw;
    margin-top: 20px;
    -webkit-transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
    transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  }
  .vertical-portfolio .vertical-portfolio-captions ul li a {
    opacity: 0.5;
  }
  .vertical-portfolio .vertical-portfolio-captions ul li.active a, .vertical-portfolio .vertical-portfolio-captions ul li.active img {
    opacity: 1;
  }
  .vertical-portfolio .vertical-portfolio-captions ul li.active img {
    margin: 0;
  }
  .vertical-portfolio .vertical-portfolio-captions ul li.active .link-hover-line:before {
    width: 100%;
    -webkit-animation: line-in 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) both;
    animation: line-in 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) both;
  }
  .vertical-portfolio .vertical-portfolio-captions ul li.active .link-hover-gradient:before {
    width: 100%;
    -webkit-animation: line-in 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) both;
    animation: line-in 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) both;
  }
}

@media (max-width: 991.98px) {
  .vertical-portfolio .vertical-portfolio-captions {
    max-width: 70%;
    margin: 0 auto;
    text-align: center;
  }
  .vertical-portfolio .vertical-portfolio-captions ul {
    padding: 0;
  }
  .vertical-portfolio .vertical-portfolio-captions ul li {
    margin-bottom: 20px;
  }
  .vertical-portfolio .vertical-portfolio-captions ul li:last-child {
    margin-bottom: 0;
  }
}

@media (max-width: 767.98px) {
  .vertical-portfolio .vertical-portfolio-captions {
    max-width: 100%;
  }
}

/*------------------------------------------------
  27. Preloader
-------------------------------------------------*/
.preloader {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 999;
  visibility: visible;
  opacity: 1;
  background: white;
  width: 100%;
  height: 100%;
  text-align: center;
}

.preloader div {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 50px;
  height: 50px;
}

.preloader div span {
  display: inline-block;
  width: 50px;
  height: 50px;
  border: 1px solid;
  border-radius: 50%;
  border-color: #1c1d24 rgba(28, 29, 36, 0.2) #1c1d24 rgba(28, 29, 36, 0.2);
  -webkit-animation: loader-spin 600ms infinite linear;
  animation: loader-spin 600ms infinite linear;
}

.preloader.preloader-dark {
  background: black;
}

.preloader.preloader-dark div span {
  border-color: white rgba(255, 255, 255, 0.3) white rgba(255, 255, 255, 0.3);
}

.loaded .preloader {
  visibility: hidden;
  opacity: 0;
  -webkit-transition: ease-out 0.4s;
  transition: ease-out 0.4s;
}

@keyframes loader-spin {
  100% {
    transform: rotate(360deg);
    transform: rotate(360deg);
  }
}

@-webkit-keyframes loader-spin {
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}

/*------------------------------------------------
  28. Utilities
*
-------------------------------------------------*/

/*------------------------------------------------
  29. Header Button - CSS REMOVED TEMPORARILY
-------------------------------------------------*/
/* Header button gradient CSS removed to fix conflicts */

/*------------------------------------------------
  SHAKE HANDS MOBILE GLOBAL STYLES - PRIORITIZED FROM INDEX.HTML
  All global styles consolidated here to prevent page CSS conflicts
-------------------------------------------------*/

/* Apple Typography & Design System */
* { 
  font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'SF Pro Text', 'Helvetica Neue', Helvetica, Arial, sans-serif !important; 
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3 { 
  font-weight: 600 !important; 
  letter-spacing: 0.02em !important;
  line-height: 1.1 !important;
}
h4, h5, h6 { 
  font-weight: 500 !important; 
  letter-spacing: 0.015em !important;
}

.display-1, .display-2, .display-3 { 
  font-weight: 700 !important; 
  letter-spacing: 0.01em !important;
  line-height: 1.05 !important;
}

/* Restore original Bootstrap display sizes - larger headings */
.display-4 {
  font-size: 3.5rem !important;
  font-weight: 600 !important;
  line-height: 1.1 !important;
}

.display-5 {
  font-size: 3rem !important;
  font-weight: 600 !important;
  line-height: 1.2 !important;
}

.display-6 {
  font-size: 2.5rem !important;
  font-weight: 600 !important;
  line-height: 1.2 !important;
}

/* Mobile responsive heading sizes */
@media (max-width: 768px) {
  .display-4 {
    font-size: 2.5rem !important;
  }
  
  .display-5 {
    font-size: 2.25rem !important;
  }
  
  .display-6 {
    font-size: 2rem !important;
  }
}

@media (max-width: 575.98px) {
  .display-4 {
    font-size: 2rem !important;
  }
  
  .display-5 {
    font-size: 1.75rem !important;
  }
  
  .display-6 {
    font-size: 1.5rem !important;
  }
}

p, li, span { 
  letter-spacing: 0.01em !important;
}

.nav-link { 
  letter-spacing: 0.02em !important;
}

/* Hero Section - Global */
.hero h1, .hero .text-highlight-gradient-2 { 
  text-decoration: none !important; 
  font-size: clamp(2.5rem, 5vw, 4rem) !important;
}
.text-highlight-gradient-2::after { display: none !important; }
.text-highlight-gradient-2 { background-image: none !important; border-bottom: none !important; }

/* Apple Section Spacing - Global */
.apple-section { 
  padding: 80px 0 !important; 
  background: #f5f5f7;
}
.apple-section-dark { 
  padding: 80px 0 !important; 
  background: #1d1d1f;
  color: #f5f5f7;
}

/* Apple Cards - Global */
.apple-card {
  background: white;
  border-radius: 18px;
  padding: 40px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.1);
  border: none;
}

/* Apple Colors - Global */
.apple-blue { color: #1db585 !important; }
.apple-green { color: #34C759 !important; }
.apple-orange { color: #FF9500 !important; }
.apple-purple { color: #AF52DE !important; }

/* Clean Lists - Global */
.apple-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.apple-list li {
  padding: 8px 0;
  font-size: 17px;
  font-weight: 400;
}

/* Custom Header and Body Backgrounds - Global */
.header {
  background-color: white !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.1);
}

body {
  background-color: #F5F5F7 !important;
}

/* Global Button Font Size Increase */
.button, .btn {
  font-size: 17px !important;
}
.button-lg {
  font-size: 19px !important;
}
.button-sm {
  font-size: 15px !important;
}

/* GLOBAL LAYOUT & BACKGROUNDS */
.header,
.shm-global-header {
  background-color: white !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.1);
}

body {
  background-color: #F5F5F7 !important;
}

.button, .btn {
  font-size: 17px !important;
}
.button-lg {
  font-size: 19px !important;
}
.button-sm {
  font-size: 15px !important;
}

/* Missing keyframes for phone call button */
@keyframes workingHeaderGradient {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* EXACT WORKING ANIMATION FROM INDEX.HTML */
.header-button-gradient {
  background-size: 400% 400% !important;
  animation: gradientShift 3s ease infinite !important;
  border: none !important;
  color: white !important;
  font-weight: 600 !important;
  transition: all 0.3s ease !important;
  box-shadow: 0 4px 15px rgba(0,0,0,0.2) !important;
}

.header-button-gradient:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 20px rgba(0,0,0,0.3) !important;
  animation-duration: 1.5s !important;
}

/* HEADER MOBILE STYLES - MOVED FROM INDEX */
/* Animated Gradient Header Button */
.header-button-gradient {
  color: rgba(255,255,255,0.9);
  border-radius: 50px;
  background: linear-gradient(-45deg, #FFA63D, #FF3D77, #338AFF, #3CF0C5);
  background-size: 600%;
  animation: anime 16s linear infinite;
  border: none;
  position: relative;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.15);
  transition: box-shadow 0.3s ease;
}

.header-button-gradient:hover,
.header-button-gradient:focus,
.header-button-gradient:active {
  transform: none;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
  animation: anime 16s linear infinite;
}

@keyframes anime {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}

.header-button-gradient span {
  color: rgba(255,255,255,0.9) !important;
}

/* Hide header social media icons on mobile */
@media (max-width: 991.98px) {
  .header-extra .list-inline-lg {
    display: none !important;
  }
  
  .header-extra .ms-3,
  .header-extra .ms-lg-4 {
    margin-left: 0 !important;
  }
}

/* BUTTON GROUP RESPONSIVENESS - MOVED FROM INDEX */
/* Button group responsiveness */
.d-inline-flex .button,
.d-inline-flex .btn,
.d-flex .button,
.d-flex .btn {
  flex-shrink: 0;
  margin: 0.25rem;
}

/* Mobile button groups stack vertically if needed */
@media (max-width: 575.98px) {
  .button-group-mobile-stack .button,
  .button-group-mobile-stack .btn {
    width: 100%;
    margin-bottom: 0.5rem;
  }
  
  .button-group-mobile-stack {
    display: flex;
    flex-direction: column;
  }
}

/* Navigation tab buttons specific responsiveness */
.d-inline-flex.gap-4 .btn {
  white-space: nowrap;
  flex-shrink: 0;
}

@media (max-width: 991.98px) {
  .d-inline-flex.gap-4 {
    flex-wrap: wrap;
    gap: 0.5rem !important;
    justify-content: center;
  }
  
  .d-inline-flex.gap-4 .btn {
    font-size: 0.8rem;
    padding: 0.25rem 0.5rem;
  }
}

@media (max-width: 575.98px) {
  .d-inline-flex.gap-4 .btn {
    font-size: 0.7rem;
    padding: 0.2rem 0.4rem;
  }
}

/* Header button */
.header-button-gradient {
  white-space: nowrap;
  flex-shrink: 0;
}

@media (max-width: 991.98px) {
  .header-button-gradient {
    font-size: 0.85rem;
    padding: 0.4rem 0.8rem;
  }
}

/* Mobile menu toggle */
.mobile-menu-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  flex-shrink: 0;
}




/* EXACT WORKING KEYFRAMES FROM INDEX.HTML */
@keyframes gradientShift {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}


/* PROFESSIONAL MOBILE MENU TOGGLE - OPTIMIZED FROM INDEX PAGE */
.mobile-menu-toggle {
  position: relative;
  display: inline-block;
  background: transparent;
  border: none;
  width: 44px;
  height: 44px;
  cursor: pointer;
  padding: 10px;
  touch-action: manipulation;
}

@media (min-width: 992px) {
  .mobile-menu-toggle {
    display: none !important;
  }
}

@media (max-width: 991.98px) {
  .mobile-menu-toggle {
    display: inline-block !important;
  }
}

.mobile-menu-toggle span {
  position: relative;
  display: block;
  width: 24px;
  height: 2px;
  background: #ffffff;
  border-radius: 1px;
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}

.mobile-menu-toggle span:before,
.mobile-menu-toggle span:after {
  content: '';
  position: absolute;
  left: 0;
  width: 24px;
  height: 2px;
  background: #ffffff;
  border-radius: 1px;
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}

.mobile-menu-toggle span:before {
  top: -8px;
}

.mobile-menu-toggle span:after {
  bottom: -8px;
}

/* Professional Menu Toggle Animation */
.mobile-menu-toggle.toggle-close span,
.mobile-menu-toggle.active span {
  background: transparent;
}

.mobile-menu-toggle.toggle-close span:before,
.mobile-menu-toggle.active span:before {
  top: 0;
  transform: rotate(45deg);
}

.mobile-menu-toggle.toggle-close span:after,
.mobile-menu-toggle.active span:after {
  bottom: 0;
  transform: rotate(-45deg);
}
.mobile-menu-toggle.toggle-close span:before {
  transform: rotate(45deg);
  top: 0;
}

.mobile-menu-toggle.toggle-close span:after {
  transform: rotate(-45deg);
  bottom: 0;
}

/* Show mobile toggle only on mobile screens */
@media (max-width: 991.98px) {
  .mobile-menu-toggle {
    display: inline-block !important;
  }
  
  /* Hide social media icons on mobile */
  .header-extra .list-inline-lg {
    display: none !important;
  }
  
  /* PROFESSIONAL MOBILE MENU - OPTIMIZED FROM INDEX PAGE */
  .header-menu {
    position: fixed;
    top: 0;
    right: -100%;
    width: 340px;
    max-width: 85vw;
    height: 100vh;
    background: rgba(255, 255, 255, 0.98);
    backdrop-filter: blur(40px);
    -webkit-backdrop-filter: blur(40px);
    z-index: 999;
    padding: 70px 30px 30px;
    transition: all 0.35s cubic-bezier(0.25, 0.8, 0.25, 1);
    overflow-y: auto;
    border-radius: 0;
    box-shadow: -4px 0 24px rgba(0, 0, 0, 0.1);
  }
  
  /* Show mobile menu when toggled */
  .header.header-menu-show .header-menu {
    right: 0;
  }
  
  /* Professional mobile menu navigation styling */
  .header-menu .nav {
    flex-direction: column;
    align-items: flex-start;
    margin: 0;
    padding: 0;
  }
  
  .header-menu .nav .nav-item {
    width: 100%;
    margin-right: 0;
    margin-bottom: 20px;
    height: auto;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
    padding-bottom: 12px;
  }
  
  .header-menu .nav .nav-item:last-child {
    margin-bottom: 0;
    border-bottom: none;
    padding-bottom: 0;
  }
  
  .header-menu .nav .nav-item .nav-link {
    font-size: 17px;
    font-weight: 500;
    color: #1d1d1f;
    padding: 8px 0;
    min-height: 40px;
    display: flex;
    align-items: center;
    letter-spacing: -0.3px;
    line-height: 1.3;
    touch-action: manipulation;
    transition: all 0.3s ease;
    width: 100%;
    border-bottom: none;
  }
  
  .header-menu .nav .nav-item .nav-link:hover,
  .header-menu .nav .nav-item .nav-link:active,
  .header-menu .nav .nav-item .nav-link.active {
    color: #1db585;
    transform: translateX(6px);
  }
  
  /* Add icon to dropdown links */
  .header-menu .nav .nav-item .dropdown-toggle::after {
    margin-left: auto;
    font-size: 12px;
    opacity: 0.6;
  }
  
  /* Mobile dropdown styling */
  .header-menu .dropdown-menu {
    position: static;
    display: none;
    float: none;
    width: 100%;
    background: rgba(249, 249, 249, 0.9);
    backdrop-filter: blur(10px);
    border: none;
    box-shadow: none;
    margin: 12px 0 0 0;
    padding: 12px 0;
    border-radius: 10px;
  }
  
  .header-menu .dropdown-item {
    padding: 10px 20px;
    font-size: 15px;
    font-weight: 400;
    color: #666;
    transition: all 0.2s ease;
    border-radius: 6px;
    margin: 0 8px;
  }
  
  .header-menu .dropdown-item:hover,
  .header-menu .dropdown-item:active {
    background: rgba(29, 181, 133, 0.1);
    color: #1db585;
    transform: translateX(4px);
  }
  
  /* Show dropdown when parent is active */
  .header-menu .nav-item.show .dropdown-menu {
    display: block;
  }
  
  /* Remove mobile menu overlay */
}

/* DESKTOP HEADER MENU VISIBILITY FIXES - FROM INDEX PAGE */
@media (min-width: 992px) {
  .header .header-menu {
    position: static !important;
    left: auto !important;
    right: auto !important;
    width: auto !important;
    height: auto !important;
    background: transparent !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin-left: auto !important;
    overflow: visible !important;
    transition: none !important;
    border-radius: 0 !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    max-width: none !important;
  }
  
  .header .header-menu .nav {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  
  .header .header-menu .nav .nav-item {
    display: inline-flex !important;
    align-items: center !important;
    height: 80px !important;
    margin-right: 24px !important;
    margin-bottom: 0 !important;
    border-bottom: none !important;
    padding-bottom: 0 !important;
    width: auto !important;
  }
  
  .header .header-menu .nav .nav-item:last-child {
    margin-right: 0 !important;
  }
  
  .header .header-menu .nav .nav-item .nav-link {
    font-size: 16px !important;
    font-weight: 500 !important;
    color: #1d1d1f !important;
    padding: 0 !important;
    min-height: auto !important;
    display: inline-flex !important;
    align-items: center !important;
    letter-spacing: normal !important;
    line-height: normal !important;
    touch-action: auto !important;
    transition: color 0.2s ease !important;
    transform: none !important;
    width: auto !important;
  }
  
  .header .header-menu .nav .nav-item .nav-link:hover,
  .header .header-menu .nav .nav-item .nav-link:active {
    color: #1db585 !important;
    transform: none !important;
  }
  
  .header .header-menu .dropdown-menu {
    position: absolute !important;
    display: none !important;
    top: 100% !important;
    left: 0 !important;
    background: white !important;
    backdrop-filter: none !important;
    border: 1px solid rgba(0,0,0,0.1) !important;
    box-shadow: 0 4px 20px rgba(0,0,0,0.1) !important;
    margin: 0 !important;
    padding: 8px 0 !important;
    border-radius: 8px !important;
    min-width: 200px !important;
  }
  
  .header .header-menu .nav-item:hover .dropdown-menu {
    display: block !important;
  }
  
  .header .header-menu .dropdown-item {
    padding: 8px 16px !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    color: #666 !important;
    transition: all 0.2s ease !important;
    transform: none !important;
  }
  
  .header .header-menu .dropdown-item:hover {
    background: #f8f9fa !important;
    color: #1db585 !important;
    transform: none !important;
  }
  
  /* Mobile header adjustments */
  .header .container-fluid {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
  
  /* Ensure header button is properly sized on mobile */
  .header-button-gradient {
    font-size: 14px !important;
    padding: 8px 16px !important;
  }
  
  /* Mobile responsive typography */
  h1, .h1, .display-1 {
    font-size: 2rem !important;
  }
  
  h2, .h2, .display-2 {
    font-size: 1.75rem !important;
  }
  
  h3, .h3, .display-3 {
    font-size: 1.5rem !important;
  }
  
  /* .display-4, .display-5, .display-6 {
    font-size: 1.25rem !important;
  } */
  
  /* Mobile card spacing */
  .apple-card {
    padding: 20px !important;
    margin-bottom: 1rem;
  }
  
  /* Mobile section padding */
  .apple-section {
    padding: 40px 0 !important;
  }
  
  /* Mobile container padding */
  .container {
    padding-left: 15px !important;
    padding-right: 15px !important;
  }
  
  /* Mobile form improvements */
  .form-control {
    font-size: 16px !important; /* Prevents zoom on iOS */
  }
  
  /* Mobile button improvements */
  .btn, .button {
    /* padding: 12px 20px !important; */
    font-size: 14px !important;
  }
  
  .btn-lg {
    padding: 16px 24px !important;
    font-size: 16px !important;
  }
  
  /* Product page mobile */
  .product-container {
    padding: 0 !important;
  }
  
  .product-gallery {
    flex-direction: column !important;
  }
  
  .product-thumbnails {
    display: flex !important;
    flex-direction: row !important;
    gap: 10px !important;
    margin-top: 15px !important;
    justify-content: center !important;
  }
  
  .thumbnail {
    width: 60px !important;
    height: 60px !important;
  }
  
  /* Statistics grid mobile */
  .col-md-3 {
    margin-bottom: 1rem;
  }
  
  /* Features grid mobile */
  .col-lg-4 {
    margin-bottom: 1.5rem;
  }
  
  /* Process steps mobile */
  .col-lg-3 {
    margin-bottom: 2rem;
  }
}

/* Tablet responsive - 768px to 991px */
@media (min-width: 768px) and (max-width: 991.98px) {
  .apple-section {
    padding: 60px 0 !important;
  }
  
  .apple-card {
    padding: 30px !important;
  }
  
  h1, .display-1 {
    font-size: 2.5rem !important;
  }
  
  h2, .display-2 {
    font-size: 2rem !important;
  }
  
  .container {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
}

/* Small mobile - below 576px */
@media (max-width: 575.98px) {
  .apple-section {
    padding: 30px 0 !important;
  }
  
  .apple-card {
    padding: 15px !important;
  }
  
  .container {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }
  
  /* Extra small typography */
  h1, .h1, .display-1, .display-2, .display-3 {
    font-size: 1.5rem !important;
  }
  
  h2, .h2 {
    font-size: 1.25rem !important;
  }
  
  /* Stack buttons vertically on very small screens */
  .d-flex.gap-3 {
    flex-direction: column !important;
  }
  
  .d-flex.gap-3 .btn {
    width: 100% !important;
    margin-bottom: 10px !important;
  }
  
  /* Contact popup mobile */
  .contact-popup-container {
    max-width: 95vw !important;
    margin: 10px !important;
  }
  
  .contact-popup-header {
    padding: 20px 24px 12px 24px !important;
  }
  
  .contact-popup-header h2 {
    font-size: 20px !important;
  }
  
  .contact-form {
    padding: 8px 24px 20px 24px !important;
  }
  
  .form-row {
    flex-direction: column !important;
    gap: 0 !important;
  }
  
  .form-group {
    margin-bottom: 16px !important;
  }
  
  .form-group input,
  .form-group select,
  .form-group textarea {
    padding: 14px 16px !important;
    font-size: 16px !important; /* Prevent zoom on iOS */
  }
}

/* CONTACT POPUP STYLES - FULLY RESPONSIVE */
.contact-popup-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: rgba(0, 0, 0, 0.4);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  z-index: 10000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  opacity: 0;
  visibility: hidden;
  transition: all 0.5s cubic-bezier(0.16, 1, 0.3, 1);
  pointer-events: none;
}

.contact-popup-overlay.active {
  display: flex;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.contact-popup-container {
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(30px);
  -webkit-backdrop-filter: blur(30px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 20px;
  max-width: min(500px, 90vw);
  width: 100%;
  max-height: 90vh;
  height: auto;
  overflow-y: auto;
  box-shadow: 
    0 25px 50px rgba(0, 0, 0, 0.15),
    0 0 0 1px rgba(255, 255, 255, 0.05);
  transform: scale(0.7) translateY(40px) rotateX(10deg);
  transition: all 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  position: relative;
  display: flex;
  flex-direction: column;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.contact-popup-container::-webkit-scrollbar {
  display: none;
}

.contact-popup-overlay.active .contact-popup-container {
  transform: scale(1) translateY(0) rotateX(0deg);
}

.contact-popup-header {
  padding: 24px 32px 16px 32px;
  text-align: center;
  position: relative;
  flex-shrink: 0;
}

.contact-popup-header h2 {
  font-size: 24px;
  font-weight: 600;
  color: #1d1d1f;
  margin-bottom: 6px;
  letter-spacing: -0.5px;
}

.contact-popup-header p {
  color: #6e6e73;
  font-size: 15px;
  line-height: 1.4;
  margin-bottom: 0;
}

.contact-popup-close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 32px !important;
  height: 32px !important;
  border: none;
  background: rgba(142, 142, 147, 0.12);
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #6e6e73;
  transition: all 0.2s ease;
  cursor: pointer;
  min-width: 32px;
  max-width: 32px;
  min-height: 32px;
  max-height: 32px;
  flex-shrink: 0;
  padding: 0;
  margin: 0;
}

.contact-popup-close:hover {
  background: rgba(142, 142, 147, 0.2);
  color: #1d1d1f;
  transform: scale(1.1);
}

.contact-form {
  padding: 10px 32px 24px 32px;
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: visible;
}

.form-row {
  display: flex;
  gap: 16px;
}

.form-group {
  margin-bottom: 20px;
  flex: 1;
}

.form-group label {
  display: block;
  font-size: 15px;
  font-weight: 500;
  color: #1d1d1f;
  margin-bottom: 8px;
  letter-spacing: -0.2px;
}

.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: 12px 16px;
  border: 1px solid rgba(0, 0, 0, 0.1);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.8);
  font-size: 15px;
  color: #1d1d1f;
  transition: all 0.2s ease;
  outline: none;
  box-sizing: border-box;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: #1db585;
  box-shadow: 0 0 0 3px rgba(0, 122, 255, 0.2);
  background: rgba(255, 255, 255, 0.95);
}

.form-group textarea {
  resize: vertical;
  min-height: 70px;
  height: 70px;
  font-family: inherit;
  padding: 16px 16px;
}

.form-group select {
  cursor: pointer;
  appearance: none;
  background-image: url('data:image/svg+xml;charset=US-ASCII,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 4 5"><path fill="%236e6e73" d="m2 0-2 2h4zm0 5 2-2H0z"/></svg>');
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 12px;
  padding-right: 36px;
}

.form-actions {
  display: flex;
  gap: 12px;
  justify-content: flex-end;
  margin-top: 20px;
  flex-shrink: 0;
}

.btn-primary,
.btn-secondary {
  padding: 12px 24px;
  border-radius: 8px;
  font-size: 15px;
  font-weight: 500;
  border: none;
  cursor: pointer;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 110px;
  justify-content: center;
}

.btn-primary {
  background: linear-gradient(135deg, #1db585, #20c997, #40e0d0, #20c997, #1db585);
  background-size: 300% 300%;
  color: white;
  border-radius: 50px;
  box-shadow: 0 4px 15px rgba(29, 181, 133, 0.3);
  transition: all 0.4s ease;
  position: relative;
  overflow: hidden;
}

.btn-primary::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, rgba(255,255,255,0.1), transparent, rgba(255,255,255,0.1));
  transition: transform 0.4s ease;
  transform: translateX(-100%);
}

.btn-primary:hover {
  background-position: 100% 100%;
  box-shadow: 0 8px 25px rgba(29, 181, 133, 0.4);
  transform: translateY(-2px);
  color: white;
}

.btn-primary:hover::before {
  transform: translateX(100%);
}

.btn-primary:active {
  transform: translateY(0);
  box-shadow: 0 4px 15px rgba(29, 181, 133, 0.3);
}

.btn-secondary {
  background: rgba(142, 142, 147, 0.12);
  color: #000000;
  border-radius: 50px;
}

.btn-secondary:hover {
  background: rgba(142, 142, 147, 0.2);
  color: #000000;
}

.loading-spinner {
  animation: spin 1s linear infinite;
}

@keyframes spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.success-message {
  padding: 32px;
  text-align: center;
}

.success-icon {
  margin: 0 auto 20px auto;
  width: 48px;
  height: 48px;
}

.success-message h3 {
  font-size: 22px;
  font-weight: 600;
  color: #1d1d1f;
  margin-bottom: 8px;
}

.success-message p {
  color: #6e6e73;
  font-size: 16px;
  margin-bottom: 24px;
}

/* Contact popup responsive styles */
@media (max-width: 768px) {
  .contact-popup-container {
    max-width: calc(100vw - 16px);
    margin: 8px;
    border-radius: 16px;
    max-height: calc(100vh - 80px);
  }
  
  .contact-popup-header {
    padding: 16px 18px 12px 18px;
  }
  
  .contact-form {
    padding: 0 18px 16px 18px;
  }
  
  .form-row {
    flex-direction: column;
    gap: 0;
  }
  
  .form-actions {
    flex-direction: column;
    gap: 10px;
    margin-top: 16px;
  }
  
  .btn-primary,
  .btn-secondary {
    width: 100%;
    padding: 14px 24px;
    font-size: 16px;
    min-height: 48px;
    border-radius: 8px;
  }
}

/* PHONE CALL BUTTON */
.phone-call-btn {
  z-index: 997 !important;
  position: fixed !important;
  right: 20px !important;
  bottom: 80px !important;
  display: inline-block !important;
  background: linear-gradient(135deg, #1db585, #20c997, #40e0d0) !important;
  background-size: 200% 200% !important;
  animation: workingHeaderGradient 3s ease infinite !important;
  width: 46px !important;
  height: 46px !important;
  line-height: 46px !important;
  border-radius: 50% !important;
  color: white !important;
  text-align: center !important;
  cursor: pointer !important;
  box-shadow: 0 4px 15px rgba(29, 181, 133, 0.4) !important;
}

.phone-call-btn *,
.phone-call-btn i,
.scrolltotop,
.scrolltotop * {
  color: white !important;
}

.phone-call-btn:hover {
  transform: scale(1.05) !important;
  background: linear-gradient(135deg, #16a575, #1db585, #20c997) !important;
  box-shadow: 0 6px 20px rgba(29, 181, 133, 0.5) !important;
}

/* PHONE CALL BUTTON RIPPLE EFFECTS */
.ripple-effect {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 46px;
  height: 46px;
  border: 2px solid rgba(29, 181, 133, 0.4);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  animation: ripple 2.5s ease-out infinite;
  pointer-events: none;
  will-change: transform, opacity;
  box-shadow: 0 0 6px rgba(29, 181, 133, 0.2);
}

.ripple-delay-1 {
  animation-delay: 0.8s;
  border-color: rgba(29, 181, 133, 0.3);
  box-shadow: 0 0 4px rgba(29, 181, 133, 0.15);
}

.ripple-delay-2 {
  animation-delay: 1.6s;
  border-color: rgba(29, 181, 133, 0.2);
  box-shadow: 0 0 3px rgba(29, 181, 133, 0.1);
}

@keyframes ripple {
  0% {
    transform: translate(-50%, -50%) scale(0.8);
    opacity: 0;
  }
  15% {
    transform: translate(-50%, -50%) scale(1);
    opacity: 0.6;
  }
  40% {
    transform: translate(-50%, -50%) scale(1.8);
    opacity: 0.4;
  }
  70% {
    transform: translate(-50%, -50%) scale(2.5);
    opacity: 0.2;
  }
  100% {
    transform: translate(-50%, -50%) scale(3);
    opacity: 0;
  }
}

/* APPLE COLORS & COMPONENTS */
.apple-blue { color: #1db585 !important; }
.apple-green { color: #34C759 !important; }
.apple-orange { color: #FF9500 !important; }
.apple-purple { color: #AF52DE !important; }

.apple-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.apple-list li {
  padding: 8px 0;
  font-size: 17px;
  font-weight: 400;
}

.apple-card {
  background: white;
  border-radius: 18px;
  padding: 40px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.1);
  border: none;
}

.apple-section { 
  padding: 80px 0 !important; 
  background: #f5f5f7 !important;
}
.apple-section-dark { 
  padding: 80px 0 !important; 
  background: #1d1d1f;
  color: #f5f5f7;
}

/* DIVIDERS */
.divider-green-holo {
  height: 4px;
  background: linear-gradient(45deg, 
    #065f46, #047857, #059669, #10b981, #34d399, #6ee7b7, #a7f3d0, #6ee7b7, #34d399, #10b981, #059669, #047857, #065f46);
  background-size: 800% 400%;
  animation: greenRainbow 8s ease-in-out infinite;
  margin: 30px 0;
  border-radius: 2px;
  position: relative;
  transform: perspective(150px) rotateX(20deg);
  box-shadow: 
    0 4px 8px rgba(16, 185, 129, 0.4),
    0 2px 4px rgba(52, 211, 153, 0.3);
}

@keyframes greenRainbow {
  0% { 
    background-position: 0% 50%; 
    filter: brightness(0.8) contrast(1.1);
  }
  50% { 
    background-position: 50% 50%; 
    filter: brightness(1.3) contrast(1.3);
  }
  100% { 
    background-position: 100% 50%; 
    filter: brightness(0.8) contrast(1.1);
  }
}

.divider-green-holo::after {
  content: '';
  position: absolute;
  top: -1px;
  left: 20%;
  right: 20%;
  height: 6px;
  background: rgba(220, 252, 231, 0.8);
  border-radius: 3px;
  filter: blur(3px);
}

/* LAYOUT FIXES */
.sliding-boxes .swiper-slide > div {
  background: white !important;
  box-shadow: 0 4px 15px rgba(0,0,0,0.08);
  border-radius: 12px;
}

.section-spacing.pt-0.pb-0 .bg-image.parallax {
  position: relative;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  min-height: 400px;
}

.section-spacing.pt-0.pb-0 .bg-image.parallax > * {
  position: relative;
  z-index: 2;
}

.section-spacing,
.section-spacing-lg,
.section-spacing-xl {
  background: transparent;
}

/* CONTACT POPUP STYLES */
.contact-popup-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: rgba(0, 0, 0, 0.4);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  z-index: 10000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  opacity: 0;
  visibility: hidden;
  transition: all 0.5s cubic-bezier(0.16, 1, 0.3, 1);
  pointer-events: none;
}

.contact-popup-overlay.active {
  display: flex;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.contact-popup-container {
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(30px);
  -webkit-backdrop-filter: blur(30px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 20px;
  max-width: min(500px, 90vw);
  width: 100%;
  max-height: 90vh;
  height: auto;
  overflow-y: auto;
  box-shadow: 
    0 25px 50px rgba(0, 0, 0, 0.15),
    0 0 0 1px rgba(255, 255, 255, 0.05);
  transform: scale(0.7) translateY(40px) rotateX(10deg);
  transition: all 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  position: relative;
  display: flex;
  flex-direction: column;
}

.contact-popup-overlay.active .contact-popup-container {
  transform: scale(1) translateY(0) rotateX(0deg);
}

.contact-popup-header {
  padding: 24px 32px 16px 32px;
  text-align: center;
  position: relative;
  flex-shrink: 0;
}

.contact-popup-header h2 {
  font-size: 24px;
  font-weight: 600;
  color: #1d1d1f;
  margin-bottom: 6px;
  letter-spacing: -0.5px;
}

.contact-popup-header p {
  color: #6e6e73;
  font-size: 15px;
  line-height: 1.4;
  margin-bottom: 0;
}

.contact-popup-close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 32px !important;
  height: 32px !important;
  border: none;
  background: rgba(142, 142, 147, 0.12);
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #6e6e73;
  transition: all 0.2s ease;
  cursor: pointer;
}

.contact-popup-close:hover {
  background: rgba(142, 142, 147, 0.2);
  color: #1d1d1f;
  transform: scale(1.1);
}

.contact-form {
  padding: 10px 32px 24px 32px;
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

.form-row {
  display: flex;
  gap: 16px;
}

.form-group {
  margin-bottom: 20px;
  flex: 1;
}

.form-group label {
  display: block;
  font-size: 15px;
  font-weight: 500;
  color: #1d1d1f;
  margin-bottom: 8px;
  letter-spacing: -0.2px;
}

.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: 12px 16px;
  border: 1px solid rgba(0, 0, 0, 0.1);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.8);
  font-size: 15px;
  color: #1d1d1f;
  transition: all 0.2s ease;
  outline: none;
  box-sizing: border-box;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: #1db585;
  box-shadow: 0 0 0 3px rgba(0, 122, 255, 0.2);
  background: rgba(255, 255, 255, 0.95);
}

.form-group textarea {
  resize: vertical;
  min-height: 70px;
  height: 70px;
}

.form-actions {
  display: flex;
  gap: 12px;
  justify-content: flex-end;
  margin-top: 20px;
  flex-shrink: 0;
}

.btn-primary,
.btn-secondary {
  padding: 12px 24px;
  border-radius: 8px;
  font-size: 15px;
  font-weight: 500;
  border: none;
  cursor: pointer;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  gap: 6px;
}

.btn-primary {
  background: linear-gradient(135deg, #1db585, #34c759, #2dd4bf, #10b981);
  background-size: 300% 300%;
  animation: greenGradientShift 3s ease infinite;
  color: white;
  border: none;
  font-weight: 600;
  box-shadow: 0 4px 15px rgba(29, 181, 133, 0.3);
  transition: all 0.3s ease;
}

.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(29, 181, 133, 0.4);
  animation-duration: 1.5s;
}

/* Green gradient animation */
@keyframes greenGradientShift {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}

/* Override all blue buttons with green gradient theme */
.btn-primary,
.button-primary,
.bg-primary,
.btn.btn-primary,
button[type="submit"],
input[type="submit"],
.button[class*="primary"] {
  background: linear-gradient(135deg, #1db585, #34c759, #2dd4bf, #10b981) !important;
  background-size: 300% 300% !important;
  animation: greenGradientShift 3s ease infinite !important;
  color: white !important;
  border: none !important;
  font-weight: 600 !important;
  box-shadow: 0 4px 15px rgba(29, 181, 133, 0.3) !important;
  transition: all 0.3s ease !important;
}

.btn-primary:hover,
.button-primary:hover,
.bg-primary:hover,
.btn.btn-primary:hover,
button[type="submit"]:hover,
input[type="submit"]:hover,
.button[class*="primary"]:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 20px rgba(29, 181, 133, 0.4) !important;
  animation-duration: 1.5s !important;
  color: white !important;
}

/* Ensure text remains white on green gradient buttons */
.btn-primary *,
.button-primary *,
.bg-primary *,
.btn.btn-primary *,
button[type="submit"] *,
input[type="submit"] *,
.button[class*="primary"] * {
  color: white !important;
}

/* Bootstrap Dropdown Styles for Navigation */
.header .dropdown-menu {
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 1000;
  display: none;
  border: none;
  border-radius: 8px;
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.12);
  padding: 8px 0;
  margin-top: 0;
  min-width: 180px;
  background: rgba(255, 255, 255, 0.98);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  pointer-events: none;
  border: 1px solid rgba(0, 0, 0, 0.06);
}

/* Create an invisible bridge area to prevent dropdown from disappearing */
.header .dropdown-menu:after {
  content: '';
  position: absolute;
  top: -8px;
  left: 0;
  right: 0;
  height: 8px;
  background: transparent;
  pointer-events: auto;
}

/* Show dropdown on hover */
.header .nav-item.dropdown:hover .dropdown-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
  display: block;
}

/* Keep dropdown visible when hovering over the menu itself */
.header .dropdown-menu:hover {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
  display: block;
}

/* Smooth arrow rotation on hover */
.header .nav-item.dropdown:hover .nav-link.dropdown-toggle:before {
  transform: rotate(180deg);
}

/* Add a small arrow pointing up from dropdown */
.header .dropdown-menu:before {
  content: '';
  position: absolute;
  top: -5px;
  left: 20px;
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-bottom: 5px solid rgba(255, 255, 255, 0.98);
  filter: drop-shadow(0 -1px 2px rgba(0, 0, 0, 0.08));
  z-index: 1001;
}

.header .dropdown-item {
  display: block;
  width: 100%;
  padding: 10px 20px;
  font-size: 15px;
  font-weight: 500;
  color: #1c1d24;
  text-decoration: none;
  background: transparent;
  border: none;
  transition: all 0.2s ease;
  position: relative;
  white-space: nowrap;
}

.header .dropdown-item:hover,
.header .dropdown-item:focus {
  background: linear-gradient(135deg, rgba(0, 122, 255, 0.08) 0%, rgba(0, 122, 255, 0.12) 100%);
  color: #1db585;
  transform: translateX(4px);
  text-decoration: none;
}

.header .dropdown-item:active {
  background: rgba(0, 122, 255, 0.15);
  transform: translateX(2px);
}

.header .dropdown-divider {
  margin: 6px 16px;
  border: none;
  border-top: 1px solid rgba(0, 0, 0, 0.08);
  height: 0;
}

.header .nav-item.dropdown {
  position: relative;
}

.header .nav-item.dropdown .nav-link.dropdown-toggle {
  position: relative;
}

.header .nav-item.dropdown .nav-link.dropdown-toggle:after {
  content: none;
}

.header .nav-item.dropdown .nav-link.dropdown-toggle:before {
  content: '\f107';
  font-family: 'Font Awesome 6 Free';
  font-weight: 900;
  margin-left: 8px;
  font-size: 12px;
  transition: transform 0.2s ease;
}

.header .nav-item.dropdown.show .nav-link.dropdown-toggle:before {
  transform: rotate(180deg);
}

/* Mobile dropdown styles */
@media (max-width: 991.98px) {
  .header .dropdown-menu {
    position: static;
    float: none;
    width: auto;
    margin-top: 0;
    background: rgba(248, 248, 248, 0.98);
    border-radius: 0;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border: none;
    opacity: 1;
    visibility: visible;
    transform: none;
    pointer-events: auto;
    display: none;
  }
  
  .header .dropdown-menu:before {
    display: none;
  }
  
  .header .dropdown-item {
    padding: 16px 32px;
    font-size: 16px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
  }
  
  .header .dropdown-item:last-child {
    border-bottom: none;
  }
  
  .header .nav-item.dropdown:hover .dropdown-menu {
    display: block;
  }
}

.btn-secondary {
  background: rgba(142, 142, 147, 0.12);
  color: #6e6e73;
}

.btn-secondary:hover {
  background: rgba(142, 142, 147, 0.2);
  color: #1d1d1f;
}

.loading-spinner {
  animation: spin 1s linear infinite;
}

@keyframes spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.success-message {
  text-align: center;
  padding: 40px 32px;
}

.success-icon {
  margin-bottom: 20px;
}

.success-message h3 {
  font-size: 22px;
  font-weight: 600;
  color: #1d1d1f;
  margin-bottom: 10px;
}

.success-message p {
  color: #6e6e73;
  font-size: 15px;
  line-height: 1.4;
  margin-bottom: 24px;
}

/* SKELETON LOADING STYLES
.skeleton {
  background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
  background-size: 200% 100%;
  animation: skeleton-loading 1.5s ease-in-out infinite;
  border-radius: 4px;
} */
/* 
@keyframes skeleton-loading {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
  background: #1c1d24;
} */

.bg-dark-90 {
  background: rgba(28, 29, 36, 0.9);
}

.bg-dark-80 {
  background: rgba(28, 29, 36, 0.8);
}

.bg-dark-70 {
  background: rgba(28, 29, 36, 0.7);
}

.bg-dark-60 {
  background: rgba(28, 29, 36, 0.6);
}

.bg-dark-50 {
  background: rgba(28, 29, 36, 0.5);
}

.bg-dark-40 {
  background: rgba(28, 29, 36, 0.4);
}

.bg-dark-30 {
  background: rgba(28, 29, 36, 0.3);
}

.bg-dark-20 {
  background: rgba(28, 29, 36, 0.2);
}

.bg-dark-10 {
  background: rgba(28, 29, 36, 0.1);
}

.bg-black {
  background: black;
}

.bg-black-90 {
  background: rgba(0, 0, 0, 0.9);
}

.bg-black-80 {
  background: rgba(0, 0, 0, 0.8);
}

.bg-black-70 {
  background: rgba(0, 0, 0, 0.7);
}

.bg-black-60 {
  background: rgba(0, 0, 0, 0.6);
}

.bg-black-50 {
  background: rgba(0, 0, 0, 0.5);
}

.bg-black-40 {
  background: rgba(0, 0, 0, 0.4);
}

.bg-black-30 {
  background: rgba(0, 0, 0, 0.3);
}

.bg-black-20 {
  background: rgba(0, 0, 0, 0.2);
}

.bg-black-10 {
  background: rgba(0, 0, 0, 0.1);
}

.bg-white {
  background: white;
}

.bg-white-90 {
  background: rgba(255, 255, 255, 0.9);
}

.bg-white-80 {
  background: rgba(255, 255, 255, 0.8);
}

.bg-white-70 {
  background: rgba(255, 255, 255, 0.7);
}

.bg-white-60 {
  background: rgba(255, 255, 255, 0.6);
}

.bg-white-50 {
  background: rgba(255, 255, 255, 0.5);
}

/* ==============================================
   PRODUCT PAGE STYLES
   ============================================== */

/* Product Page Styles */

/* Breadcrumb */
.breadcrumb-custom {
	background: transparent;
	padding: 1.5rem 0;
	font-size: 14px;
	margin-bottom: 1rem;
}

.breadcrumb-custom a {
	color: #2c2c2c;
	text-decoration: none;
}

.breadcrumb-custom a:hover {
	color: #1db585;
}

/* Product Container */
.product-container {
	background: white;
	border-radius: 12px;
	padding: 2rem;
	box-shadow: none;
	height: 100%;
}

/* Product Gallery */
.product-gallery {
	position: relative;
}

.product-thumbnails {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-right: 15px;
}

.thumbnail {
	width: 70px;
	height: 70px;
	border: 2px solid #e9ecef;
	border-radius: 8px;
	cursor: pointer;
	overflow: hidden;
	transition: all 0.3s;
}

.thumbnail.active,
.thumbnail:hover {
	border-color: #1db585;
}

.thumbnail img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.main-product-image {
	flex: 1;
	text-align: center;
	background: transparent;
	border-radius: 12px;
	padding: 1rem;
	min-height: 400px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.main-product-image img {
	max-width: 100%;
	max-height: 450px;
	object-fit: contain;
}

.wishlist-btn {
	position: static;
	background: transparent;
	border: none;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	box-shadow: none;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: all 0.3s;
	color: #2c2c2c;
	font-size: 24px;
}

.wishlist-btn:hover {
	color: #1db585;
	transform: scale(1.1);
}

.wishlist-btn.active {
	color: #d63031;
}

/* Product Info */
.product-title-wrapper {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 15px;
	margin-bottom: 8px;
}

.product-title {
	font-size: 28px;
	font-weight: 600;
	color: #1d1d1f;
	margin-bottom: 0;
	flex: 1;
}

.product-subtitle {
	font-size: 16px;
	color: #2c2c2c;
	margin-bottom: 12px;
}

.rating-section {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 15px;
}

.rating-badge {
	background: #1db585;
	color: white;
	padding: 6px 12px;
	border-radius: 6px;
	font-weight: 600;
	font-size: 14px;
	display: flex;
	align-items: center;
	gap: 4px;
}

.rating-badge i {
	color: #FFD700;
}

.reviews-count {
	color: #2c2c2c;
	font-size: 14px;
}

.timer-badge {
	display: none;
}

.timer-badge i {
	font-size: 16px;
	color: white;
}

/* Pricing */
.pricing-section {
	margin: 20px 0;
}

.discount-badge {
	background: #d63031;
	color: white;
	padding: 4px 12px;
	border-radius: 4px;
	font-weight: 600;
	font-size: 18px;
	margin-right: 10px;
}

.current-price {
	font-size: 32px;
	font-weight: 700;
	color: #1d1d1f;
}

.original-price {
	font-size: 20px;
	color: #2c2c2c;
	text-decoration: line-through;
	margin-left: 10px;
}

.emi-info {
	color: #2c2c2c;
	font-size: 14px;
	margin-top: 8px;
}

.emi-info a {
	color: #1db585;
	text-decoration: none;
	font-weight: 600;
}

/* Feature Badges */
.feature-badges {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin: 20px 0;
}

.feature-badge {
	background: #e8f5f1;
	color: #1db585;
	padding: 8px 16px;
	border-radius: 20px;
	font-size: 13px;
	font-weight: 500;
	display: flex;
	align-items: center;
	gap: 6px;
}

/* Condition & Storage */
.option-section {
	margin: 25px 0;
}

.option-label {
	font-size: 15px;
	font-weight: 600;
	color: #1d1d1f;
	margin-bottom: 10px;
	display: flex;
	align-items: center;
	gap: 6px;
}

.option-buttons {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}

.option-btn {
	padding: 12px 20px;
	border: 2px solid #e9ecef;
	border-radius: 8px;
	background: white;
	cursor: pointer;
	transition: all 0.3s;
	font-size: 14px;
	font-weight: 500;
	color: #495057;
}

.option-btn:hover {
	border-color: #1db585;
	background: #e8f5f1;
}

.option-btn.active {
	border-color: #1db585;
	background: #1db585;
	color: white;
}

.option-btn.disabled {
	opacity: 0.5;
	cursor: not-allowed;
	background: #f8f9fa;
}

/* Color Selection */
.color-options {
	display: flex;
	gap: 12px;
}

.color-option {
	width: 45px;
	height: 45px;
	border-radius: 50%;
	border: 3px solid transparent;
	cursor: pointer;
	transition: all 0.3s;
	position: relative;
}

.color-option.active {
	border-color: #1db585;
	transform: scale(1.1);
}

.color-option.active::after {
	content: '✓';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	color: white;
	font-weight: bold;
	font-size: 18px;
}

/* Action Buttons */
.action-buttons {
	display: flex;
	flex-direction: row;
	gap: 15px;
	margin: 30px 0;
}

/* Mobile Sticky Buttons - Match Reference Image */
@media (max-width: 991.98px) {
	.action-buttons {
		position: fixed;
		bottom: 0;
		left: 0;
		right: 0;
		background: white;
		padding: 10px;
		box-shadow: 0 -2px 10px rgba(0,0,0,0.08);
		z-index: 999;
		margin: 0 !important;
		gap: 8px;
		border-top: 1px solid #e9ecef;
		flex-direction: row !important;
		align-items: stretch;
		flex-wrap: nowrap;
	}
	
	/* Add bottom padding to main container so content doesn't hide behind sticky buttons */
	.product-container:last-of-type {
		margin-bottom: 0px !important;
	}
}

.btn-cart {
	flex: 0 0 auto;
	padding: 14px 20px;
	border: 2px solid #1db585;
	background: white;
	color: #1db585;
	border-radius: 8px;
	font-weight: 600;
	transition: all 0.3s;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	cursor: pointer;
	min-width: 60px;
}

.btn-cart:hover {
	background: #1db585;
	color: white;
}

.btn-buy-now {
	flex: 1;
	padding: 14px 30px;
	background: #1db585;
	color: white;
	border: none;
	border-radius: 8px;
	font-weight: 600;
	font-size: 16px;
	transition: all 0.3s;
	cursor: pointer;
	min-height: 48px;
}

.btn-buy-now:hover {
	background: #16a575;
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(29, 181, 133, 0.3);
}

.btn-emi {
	flex: 1;
	padding: 12px 30px;
	background: white;
	color: #1d1d1f;
	border: 2px solid #e9ecef;
	border-radius: 8px;
	font-weight: 600;
	font-size: 15px;
	transition: all 0.3s;
	cursor: pointer;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 2px;
	line-height: 1.2;
	min-height: 48px;
}

.btn-emi small {
	font-size: 12px;
	font-weight: 400;
	color: #2c2c2c;
	display: block;
}

.btn-emi:hover {
	border-color: #1db585;
	background: #e8f5f1;
}

/* Info Box */
.info-box {
	background: #f8f9fa;
	border-radius: 8px;
	padding: 15px;
	margin-top: 20px;
	border-left: 4px solid #1db585;
}

.info-box-title {
	font-weight: 600;
	color: #1d1d1f;
	margin-bottom: 8px;
	font-size: 14px;
}

/* Responsive Tablet & Desktop */
@media (min-width: 768px) and (max-width: 1199.98px) {
	.product-container {
		padding: 1.75rem;
	}
	
	.product-title {
		font-size: 24px;
	}
	
	.current-price {
		font-size: 28px;
	}
	
	.main-product-image {
		min-height: 350px;
	}
}

/* Responsive Tablet */
@media (max-width: 991.98px) {
	.product-container {
		padding: 1.5rem;
		margin-bottom: 1.5rem;
	}
	
	.product-gallery {
		flex-direction: column;
	}
	
	.product-thumbnails {
		flex-direction: row;
		margin-right: 0;
		margin-bottom: 15px;
		justify-content: center;
		overflow-x: auto;
		padding-bottom: 10px;
		-webkit-overflow-scrolling: touch;
		scroll-snap-type: x mandatory;
	}
	
	.thumbnail {
		scroll-snap-align: center;
		flex-shrink: 0;
	}
	
	.main-product-image {
		min-height: 300px;
		padding: 1rem;
		margin-bottom: 20px;
	}
	
	.main-product-image img {
		max-height: 350px;
	}
	
	.product-title {
		font-size: 22px;
		line-height: 1.3;
	}
	
	.current-price {
		font-size: 26px;
	}
	
	.action-buttons {
		flex-direction: row !important;
		gap: 12px;
		margin: 20px 0;
	}
	
	/* Cart button - Icon only, square */
	.btn-cart {
		flex: 0 0 auto !important;
		width: 50px !important;
		height: 50px !important;
		padding: 0 !important;
		order: 1;
		border-radius: 8px;
		display: flex !important;
		align-items: center;
		justify-content: center;
		margin: 0 !important;
	}
	
	.btn-cart i {
		font-size: 22px;
	}
	
	/* Buy Now button - Primary action, black bg */
	.btn-buy-now {
		flex: 1 !important;
		order: 3;
		padding: 0 !important;
		font-size: 16px;
		height: 50px !important;
		min-height: 50px;
		max-height: 50px;
		background: #000000 !important;
		border-radius: 8px;
		font-weight: 600;
		margin: 0 !important;
		display: flex !important;
		align-items: center;
		justify-content: center;
	}
	
	.btn-buy-now:hover {
		background: #1a1a1a !important;
		transform: none;
		box-shadow: none;
	}
	
	/* EMI button - Stacked text, white bg */
	.btn-emi {
		flex: 1 !important;
		order: 2;
		padding: 8px 12px !important;
		height: 50px !important;
		min-height: 50px;
		max-height: 50px;
		border-radius: 8px;
		font-size: 14px;
		font-weight: 600;
		line-height: 1.2;
		margin: 0 !important;
		display: flex !important;
		flex-direction: column !important;
		align-items: center;
		justify-content: center;
	}
	
	.btn-emi small {
		font-size: 11px;
		font-weight: 400;
	}
	
	.option-buttons {
		justify-content: flex-start;
	}
	
	.feature-badges {
		justify-content: flex-start;
	}
	
	.timer-badge {
		width: 100%;
		justify-content: center;
		max-width: 200px;
	}
}

/* Responsive Mobile */
@media (max-width: 767.98px) {
	.breadcrumb-custom {
		font-size: 13px;
		padding: 1rem 0;
	}
	
	.product-container {
		padding: 1.25rem;
		border-radius: 10px;
	}
	
	.product-title {
		font-size: 21px;
		line-height: 1.3;
	}
	
	.product-title-wrapper {
		flex-wrap: wrap;
	}
	
	.wishlist-btn {
		width: 36px;
		height: 36px;
		font-size: 20px;
	}
	
	.product-subtitle {
		font-size: 14px;
		line-height: 1.4;
	}
	
	.rating-section {
		flex-wrap: wrap;
	}
	
	.current-price {
		font-size: 26px;
	}
	
	.original-price {
		font-size: 18px;
		display: block;
		margin-left: 0;
		margin-top: 4px;
	}
	
	.discount-badge {
		font-size: 16px;
		padding: 4px 10px;
	}
	
	.feature-badges {
		gap: 8px;
	}
	
	.feature-badge {
		font-size: 12px;
		padding: 7px 14px;
	}
	
	.option-btn {
		padding: 11px 18px;
		font-size: 13px;
		flex: 1;
		min-width: calc(50% - 5px);
	}
	
	.color-option {
		width: 40px;
		height: 40px;
	}
}

@media (max-width: 575.98px) {
	.breadcrumb-custom {
		font-size: 12px;
		padding: 0.75rem 0;
	}
	
	.product-container {
		padding: 1rem;
		border-radius: 8px;
	}
	
	.product-title {
		font-size: 19px;
		line-height: 1.3;
	}
	
	.product-subtitle {
		font-size: 13px;
	}
	
	.rating-badge {
		padding: 5px 10px;
		font-size: 13px;
	}
	
	.reviews-count {
		font-size: 13px;
	}
	
	.timer-badge {
		padding: 7px 14px;
		font-size: 13px;
		min-width: auto;
		max-width: 100%;
	}
	
	.pricing-section {
		margin: 15px 0;
	}
	
	.current-price {
		font-size: 24px;
	}
	
	.original-price {
		font-size: 16px;
	}
	
	.discount-badge {
		font-size: 15px;
		padding: 3px 9px;
	}
	
	.emi-info {
		font-size: 13px;
	}
	
	.feature-badges {
		margin: 15px 0;
		gap: 6px;
	}
	
	.feature-badge {
		font-size: 11px;
		padding: 6px 12px;
	}
	
	.option-section {
		margin: 20px 0;
	}
	
	.option-label {
		font-size: 14px;
		margin-bottom: 8px;
	}
	
	.option-btn {
		padding: 10px 14px;
		font-size: 12px;
		flex: 1;
		min-width: calc(50% - 5px);
	}
	
	.color-option {
		width: 38px;
		height: 38px;
	}
	
	.thumbnail {
		width: 55px;
		height: 55px;
		flex-shrink: 0;
		margin-right: 5px;
	}
	
	.main-product-image {
		min-height: 230px;
		padding: 0.5rem;
	}
	
	.main-product-image img {
		max-height: 280px;
	}
	
	.action-buttons {
		margin: 20px 0;
		gap: 10px;
	}
	
	.btn-cart {
		padding: 12px 18px;
		font-size: 14px;
	}
	
	.btn-buy-now {
		padding: 14px 24px;
		font-size: 15px;
	}
	
	.btn-emi {
		padding: 12px 20px;
		font-size: 13px;
	}
	
	.info-box {
		padding: 12px;
		font-size: 12px;
		margin-top: 15px;
	}
	
	.info-box-title {
		font-size: 13px;
	}
}

/* Extra Small Mobile */
@media (max-width: 374.98px) {
	.product-title {
		font-size: 17px;
	}
	
	.current-price {
		font-size: 22px;
	}
	
	.thumbnail {
		width: 50px;
		height: 50px;
	}
	
	.option-btn {
		padding: 9px 12px;
		font-size: 11px;
		min-width: 100%;
	}
	
	.feature-badge {
		font-size: 10px;
		padding: 5px 10px;
	}
}

/* ==============================================
   INDEX PAGE STYLES - 3D CAROUSEL & SERVICES
   ============================================== */

/* Creative 3D Carousel */
.products-container {
	perspective: 1200px;
	min-height: 600px;
	position: relative;
	overflow: visible;
	padding: 80px 0;
}

.products-slider {
	transform-style: preserve-3d;
	position: relative;
}

.products-slider .swiper-slide {
	backface-visibility: hidden;
	transition: all 0.8s cubic-bezier(0.175, 0.885, 0.32, 1.275);
	transform-style: preserve-3d;
}

/* Unique 3D transform for each position */
.products-slider .swiper-slide-active {
	transform: translateZ(100px) scale(1.2) rotateY(0deg);
	z-index: 10;
	opacity: 1;
}

.products-slider .swiper-slide-next {
	transform: translateX(200px) translateZ(-100px) scale(0.9) rotateY(-25deg);
	z-index: 5;
	opacity: 0.8;
}

.products-slider .swiper-slide-prev {
	transform: translateX(-200px) translateZ(-100px) scale(0.9) rotateY(25deg);
	z-index: 5;
	opacity: 0.8;
}

/* Far slides */
.products-slider .swiper-slide:not(.swiper-slide-active):not(.swiper-slide-next):not(.swiper-slide-prev) {
	transform: translateZ(-300px) scale(0.7);
	opacity: 0.4;
	filter: blur(3px);
}

/* Hover effect */
.products-slider .swiper-slide:hover:not(.swiper-slide-active) {
	transform: translateZ(-50px) scale(1) !important;
	opacity: 0.9 !important;
	cursor: pointer;
}
.products-slider .apple-card {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	min-height: 480px;
	width: 100%;
	height: 100%;
	transition: all 0.4s ease;
	position: relative;
	border-radius: 18px;
	overflow: hidden;
}
.products-slider .apple-card h3 {
	min-height: 80px;
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 1.1 !important;
	text-align: center;
	margin-bottom: 1rem;
	padding: 0 15px;
	word-wrap: break-word;
	hyphens: auto;
	overflow-wrap: break-word;
	font-size: clamp(22px, 2.5vw, 28px) !important;
}
.products-slider .apple-card .product-image {
	height: 220px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1.5rem;
	flex-grow: 1;
}
.products-slider .swiper-button-next,
.products-slider .swiper-button-prev {
	color: #1db585;
	margin-top: -22px;
	width: 40px;
	height: 40px;
	background: white;
	border-radius: 50%;
	box-shadow: 0 2px 10px rgba(0,0,0,0.1);
	border: 1px solid #e5e5e7;
}
.products-slider .swiper-button-next {
	right: -60px;
}
.products-slider .swiper-button-prev {
	left: -60px;
}
.products-slider .swiper-button-next:after,
.products-slider .swiper-button-prev:after {
	font-size: 16px;
	font-weight: bold;
}
.products-slider .swiper-pagination {
	position: relative;
	bottom: auto;
}
.products-slider .swiper-pagination-bullet {
	width: 8px;
	height: 8px;
	background: #d1d1d6;
	opacity: 1;
	margin: 0 4px;
}
.products-slider .swiper-pagination-bullet-active {
	background: #1db585;
}

/* Hero Section */
.hero h1, .hero .text-highlight-gradient-2 { 
	text-decoration: none !important; 
	font-size: clamp(2.5rem, 5vw, 4rem) !important;
}
.text-highlight-gradient-2::after { display: none !important; }
.text-highlight-gradient-2 { background-image: none !important; border-bottom: none !important; }

/* Modern Bright Services Design */
.services-minimal {
	max-width: 1200px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 30px;
	padding: 0 20px;
}

.service-minimal-item:nth-child(4) {
	grid-column: 2 / 3;
}

.service-minimal-item {
	position: relative;
	background: linear-gradient(135deg, #ffffff 0%, #f8f9fa 100%);
	border-radius: 24px;
	padding: 40px 30px;
	border: 2px solid transparent;
	box-shadow: 0 10px 40px rgba(0,0,0,0.08);
	transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
	cursor: pointer;
	overflow: hidden;
}

.service-minimal-item::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 5px;
	background: linear-gradient(90deg, #1db585, #20c997, #40e0d0);
	opacity: 0;
	transition: opacity 0.4s ease;
}

.service-minimal-item:nth-child(1)::before {
	background: linear-gradient(90deg, #667eea, #764ba2);
}

.service-minimal-item:nth-child(2)::before {
	background: linear-gradient(90deg, #f093fb, #f5576c);
}

.service-minimal-item:nth-child(3)::before {
	background: linear-gradient(90deg, #4facfe, #00f2fe);
}

.service-minimal-item:nth-child(4)::before {
	background: linear-gradient(90deg, #43e97b, #38f9d7);
}

.service-minimal-item:hover {
	transform: translateY(-10px);
	box-shadow: 0 20px 60px rgba(0,0,0,0.15);
	border-color: rgba(29, 181, 133, 0.2);
}

.service-minimal-item:hover::before {
	opacity: 1;
}

.service-minimal-number {
	width: 70px;
	height: 70px;
	border-radius: 50%;
	background: linear-gradient(135deg, #1db585, #20c997);
	color: white;
	font-size: 28px;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 25px;
	box-shadow: 0 8px 20px rgba(29, 181, 133, 0.3);
	transition: all 0.4s ease;
}

.service-minimal-item:nth-child(1) .service-minimal-number {
	background: linear-gradient(135deg, #667eea, #764ba2);
	box-shadow: 0 8px 20px rgba(102, 126, 234, 0.4);
}

.service-minimal-item:nth-child(2) .service-minimal-number {
	background: linear-gradient(135deg, #f093fb, #f5576c);
	box-shadow: 0 8px 20px rgba(240, 147, 251, 0.4);
}

.service-minimal-item:nth-child(3) .service-minimal-number {
	background: linear-gradient(135deg, #4facfe, #00f2fe);
	box-shadow: 0 8px 20px rgba(79, 172, 254, 0.4);
}

.service-minimal-item:nth-child(4) .service-minimal-number {
	background: linear-gradient(135deg, #43e97b, #38f9d7);
	box-shadow: 0 8px 20px rgba(67, 233, 123, 0.4);
}

.service-minimal-item:hover .service-minimal-number {
	transform: scale(1.1) rotate(5deg);
}

.service-minimal-content {
	flex: 1;
}

.service-minimal-title {
	font-size: 24px;
	font-weight: 600;
	color: #1d1d1f;
	margin-bottom: 12px;
	line-height: 1.3;
	letter-spacing: -0.5px;
	transition: all 0.3s ease;
}

.service-minimal-item:hover .service-minimal-title {
	color: #1db585;
}

.service-minimal-desc {
	font-size: 15px;
	color: #6e6e73;
	line-height: 1.6;
	margin-bottom: 20px;
}

.service-minimal-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 20px;
}

.tag {
	background: rgba(29, 181, 133, 0.1);
	color: #1db585;
	padding: 6px 14px;
	border-radius: 20px;
	font-size: 12px;
	font-weight: 600;
	transition: all 0.3s ease;
	border: 1px solid rgba(29, 181, 133, 0.2);
}

.service-minimal-item:hover .tag {
	background: rgba(29, 181, 133, 0.15);
	border-color: rgba(29, 181, 133, 0.3);
	transform: translateY(-2px);
}

.service-minimal-action {
	margin-top: auto;
}

.minimal-link {
	color: #1db585;
	font-size: 15px;
	font-weight: 600;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	transition: all 0.3s ease;
	padding: 10px 20px;
	background: rgba(29, 181, 133, 0.1);
	border-radius: 30px;
}

.minimal-link:hover {
	background: rgba(29, 181, 133, 0.2);
	transform: translateX(5px);
}

.minimal-link::after {
	content: '→';
	font-size: 18px;
	transition: all 0.3s ease;
}

.minimal-link:hover::after {
	transform: translateX(5px);
}

/* Responsive Design for Bright Services */
/* Large Tablets & Small Desktops (992px - 1199px) */
@media (min-width: 992px) and (max-width: 1199.98px) {
	.services-minimal {
		grid-template-columns: repeat(2, 1fr);
		gap: 25px;
		max-width: 900px;
	}
	
	.service-minimal-item:nth-child(4) {
		grid-column: 1 / -1;
		max-width: 450px;
		margin: 0 auto;
	}
}

/* Tablets (768px - 991px) */
@media (max-width: 991.98px) {
	.services-minimal {
		grid-template-columns: repeat(2, 1fr);
		gap: 20px;
		padding: 0 20px;
	}

	.service-minimal-item {
		padding: 30px 25px;
	}
	
	.service-minimal-item:nth-child(4) {
		grid-column: 1 / -1;
		max-width: 450px;
		margin: 0 auto;
	}

	.service-minimal-number {
		width: 60px;
		height: 60px;
		font-size: 24px;
		margin-bottom: 20px;
	}

	.service-minimal-title {
		font-size: 22px;
	}

	.service-minimal-desc {
		font-size: 14px;
	}
}

/* Mobile Landscape & Small Tablets (576px - 767px) */
@media (max-width: 767.98px) and (min-width: 576px) {
	.services-minimal {
		grid-template-columns: repeat(2, 1fr);
		gap: 18px;
		padding: 0 15px;
	}

	.service-minimal-item {
		padding: 25px 20px;
		border-radius: 18px;
	}
	
	.service-minimal-item:nth-child(4) {
		grid-column: 1 / -1;
		max-width: 400px;
		margin: 0 auto;
	}

	.service-minimal-number {
		width: 55px;
		height: 55px;
		font-size: 22px;
		margin-bottom: 18px;
	}

	.service-minimal-title {
		font-size: 20px;
	}

	.service-minimal-desc {
		font-size: 14px;
		margin-bottom: 16px;
	}

	.tag {
		font-size: 11px;
		padding: 5px 12px;
	}

	.minimal-link {
		font-size: 14px;
		padding: 8px 16px;
	}
}

/* Mobile Portrait (up to 575px) */
@media (max-width: 575.98px) {
	.services-minimal {
		grid-template-columns: 1fr;
		gap: 16px;
		padding: 0 15px;
	}

	.service-minimal-item {
		padding: 25px 20px;
		border-radius: 16px;
	}
	
	.service-minimal-item:nth-child(4) {
		grid-column: auto;
	}

	.service-minimal-number {
		width: 50px;
		height: 50px;
		font-size: 20px;
		margin-bottom: 16px;
	}

	.service-minimal-title {
		font-size: 19px;
	}

	.service-minimal-desc {
		font-size: 14px;
		margin-bottom: 14px;
	}

	.tag {
		font-size: 10px;
		padding: 4px 10px;
	}

	.minimal-link {
		font-size: 13px;
		padding: 8px 14px;
	}
}

.bg-white-40 {
  background: rgba(255, 255, 255, 0.4);
}

.bg-white-30 {
  background: rgba(255, 255, 255, 0.3);
}

.bg-white-20 {
  background: rgba(255, 255, 255, 0.2);
}

.bg-white-10 {
  background: rgba(255, 255, 255, 0.1);
}

.bg-gray {
  background: #f1f2fa;
}

.bg-red {
  background: #E32227;
}

.bg-iceblue {
  background: #E8F3FF;
}

.bg-gradient-1,
.bg-gradient-2,
.bg-gradient-3,
.bg-gradient-4,
.bg-gradient-5 {
  overflow: hidden;
  position: relative;
  z-index: 1;
}

.bg-gradient-1:before,
.bg-gradient-2:before,
.bg-gradient-3:before,
.bg-gradient-4:before,
.bg-gradient-5:before {
  z-index: -1;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.bg-gradient-1:before {
  background-image: linear-gradient(45deg, #ff5988, #500c7f);
}

.bg-gradient-2:before {
  background-image: linear-gradient(45deg, #2fbdff, #0f2f40);
}

.bg-gradient-3:before {
  background-image: linear-gradient(45deg, #ff2f78, #ff7582);
}

.bg-gradient-4:before {
  background-image: linear-gradient(45deg, #00DBDE, #FC00FF);
}

.bg-gradient-5:before {
  background-image: linear-gradient(45deg, #1db585, #34c759);
}

.bg-opacity-90:before {
  opacity: 0.9;
}

.bg-opacity-80:before {
  opacity: 0.8;
}

.bg-opacity-70:before {
  opacity: 0.7;
}

.bg-opacity-60:before {
  opacity: 0.6;
}

.bg-opacity-50:before {
  opacity: 0.5;
}

.bg-opacity-40:before {
  opacity: 0.4;
}

.bg-opacity-30:before {
  opacity: 0.3;
}

.bg-opacity-20:before {
  opacity: 0.2;
}

.bg-opacity-10:before {
  opacity: 0.1;
}

.font-family-primary {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
}

.font-family-secondary {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
}

.font-family-tertiary {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
}

.font-family-poppins {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
}

.fw-medium {
  font-weight: 500;
}

.fw-semi-bold {
  font-weight: 600;
}

.letter-spacing-05 {
  letter-spacing: 0.5px;
}

.letter-spacing-1 {
  letter-spacing: 1px;
}

.letter-spacing-2 {
  letter-spacing: 2px;
}

.letter-spacing-3 {
  letter-spacing: 3px;
}

.letter-spacing-4 {
  letter-spacing: 4px;
}

.line-height-100 {
  line-height: 1;
}

.line-height-110 {
  line-height: 1.1;
}

.line-height-120 {
  line-height: 1.2;
}

.line-height-130 {
  line-height: 1.3;
}

.line-height-140 {
  line-height: 1.4;
}

[class*='bg-'] .text-white-90,
* .text-white-90 {
  color: rgba(255, 255, 255, 0.9);
}

[class*='bg-'] .text-white-80,
* .text-white-80 {
  color: rgba(255, 255, 255, 0.8);
}

[class*='bg-'] .text-white-70,
* .text-white-70 {
  color: rgba(255, 255, 255, 0.7);
}

[class*='bg-'] .text-white-60,
* .text-white-60 {
  color: rgba(255, 255, 255, 0.6);
}

[class*='bg-'] .text-white-50,
* .text-white-50 {
  color: rgba(255, 255, 255, 0.5);
}

[class*='bg-'] .text-white-40,
* .text-white-40 {
  color: rgba(255, 255, 255, 0.4);
}

[class*='bg-'] .text-white-30,
* .text-white-30 {
  color: rgba(255, 255, 255, 0.3);
}

[class*='bg-'] .text-white-20,
* .text-white-20 {
  color: rgba(255, 255, 255, 0.2);
}

[class*='bg-'] .text-white-10,
* .text-white-10 {
  color: rgba(255, 255, 255, 0.1);
}

[class*='bg-'] .text-black,
* .text-black {
  color: black;
}

[class*='bg-'] .text-black-90,
* .text-black-90 {
  color: rgba(0, 0, 0, 0.9);
}

[class*='bg-'] .text-black-80,
* .text-black-80 {
  color: rgba(0, 0, 0, 0.8);
}

[class*='bg-'] .text-black-70,
* .text-black-70 {
  color: rgba(0, 0, 0, 0.7);
}

[class*='bg-'] .text-black-60,
* .text-black-60 {
  color: rgba(0, 0, 0, 0.6);
}

[class*='bg-'] .text-black-50,
* .text-black-50 {
  color: rgba(0, 0, 0, 0.5);
}

[class*='bg-'] .text-black-40,
* .text-black-40 {
  color: rgba(0, 0, 0, 0.4);
}

[class*='bg-'] .text-black-30,
* .text-black-30 {
  color: rgba(0, 0, 0, 0.3);
}

[class*='bg-'] .text-black-20,
* .text-black-20 {
  color: rgba(0, 0, 0, 0.2);
}

[class*='bg-'] .text-black-10,
* .text-black-10 {
  color: rgba(0, 0, 0, 0.1);
}

[class*='bg-'] .text-primary,
* .text-primary {
  color: #787a7c;
}

[class*='bg-'] .text-green,
* .text-green {
  color: #32CD32;
}

[class*='bg-'] .text-red,
* .text-red {
  color: #E32227;
}

[class*='bg-'] .text-yellow,
* .text-yellow {
  color: #FFB657;
}

[class*='bg-'] .text-dark,
* .text-dark {
  color: #1c1d24;
}

[class*='bg-'] .text-dark-90,
* .text-dark-90 {
  color: rgba(28, 29, 36, 0.9);
}

[class*='bg-'] .text-dark-80,
* .text-dark-80 {
  color: rgba(28, 29, 36, 0.8);
}

[class*='bg-'] .text-dark-70,
* .text-dark-70 {
  color: rgba(28, 29, 36, 0.7);
}

[class*='bg-'] .text-dark-60,
* .text-dark-60 {
  color: rgba(28, 29, 36, 0.6);
}

[class*='bg-'] .text-dark-50,
* .text-dark-50 {
  color: rgba(28, 29, 36, 0.5);
}

[class*='bg-'] .text-dark-40,
* .text-dark-40 {
  color: rgba(28, 29, 36, 0.4);
}

[class*='bg-'] .text-dark-30,
* .text-dark-30 {
  color: rgba(28, 29, 36, 0.3);
}

[class*='bg-'] .text-dark-20,
* .text-dark-20 {
  color: rgba(28, 29, 36, 0.2);
}

[class*='bg-'] .text-dark-10,
* .text-dark-10 {
  color: rgba(28, 29, 36, 0.1);
}

.text-white * {
  color: white;
}

.text-white-90 * {
  color: rgba(255, 255, 255, 0.9);
}

.text-white-80 * {
  color: rgba(255, 255, 255, 0.8);
}

.text-white-70 * {
  color: rgba(255, 255, 255, 0.7);
}

.text-white-60 * {
  color: rgba(255, 255, 255, 0.6);
}

.text-white-50 * {
  color: rgba(255, 255, 255, 0.5);
}

.text-white-40 * {
  color: rgba(255, 255, 255, 0.4);
}

.text-white-30 * {
  color: rgba(255, 255, 255, 0.3);
}

.text-white-20 * {
  color: rgba(255, 255, 255, 0.2);
}

.text-white-10 * {
  color: rgba(255, 255, 255, 0.1);
}

[class*='text-gradient'] {
  display: inline-block;
}

.text-gradient-1 {
  background-image: linear-gradient(45deg, #ff5988, #500c7f);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.text-gradient-2 {
  background-image: linear-gradient(45deg, #2fbdff, #0f2f40);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.text-gradient-3 {
  background-image: linear-gradient(45deg, #ff2f78, #ff7582);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.text-gradient-4 {
  background-image: linear-gradient(45deg, #00DBDE, #FC00FF);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.text-gradient-5 {
  background-image: linear-gradient(45deg, #1db585, #34c759);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.stroke-text,
.stroke-text-dark {
  color: black;
  -webkit-text-fill-color: transparent;
  -webkit-text-stroke-width: 1.4px;
  -webkit-text-stroke-color: black;
}

@media (max-width: 1199.98px) {
  .stroke-text,
  .stroke-text-dark {
    -webkit-text-stroke-width: 1.2px;
  }
}

.stroke-text-white {
  color: white;
  -webkit-text-fill-color: transparent;
  -webkit-text-stroke-color: white;
}

[class*='bg-black'] .stroke-text,
[class*='bg-dark'] .stroke-text,
[class*='bg-gradient'] .stroke-text {
  color: white;
  -webkit-text-fill-color: transparent;
  -webkit-text-stroke-color: white;
}

.border-dashed {
  border: 1px dashed rgba(28, 29, 36, 0.2);
}

.border-top-dashed {
  border-top: 1px dashed rgba(28, 29, 36, 0.2);
}

.border-right-dashed {
  border-right: 1px dashed rgba(28, 29, 36, 0.2);
}

.border-bottom-dashed {
  border-bottom: 1px dashed rgba(28, 29, 36, 0.2);
}

.border-left-dashed {
  border-left: 1px dashed rgba(28, 29, 36, 0.2);
}

[class*='bg-black'] .border-top-dashed,
[class*='bg-dark'] .border-top-dashed,
[class*='bg-gradient'] .border-top-dashed {
  border-color: rgba(255, 255, 255, 0.3);
}

[class*='bg-black'] .border-bottom-dashed,
[class*='bg-dark'] .border-bottom-dashed,
[class*='bg-gradient'] .border-bottom-dashed {
  border-color: rgba(255, 255, 255, 0.3);
}

.backdrop-filter-blur {
  backdrop-filter: blur(5px);
}

.n-margin-1 {
  margin-top: -1rem;
}

.n-margin-2 {
  margin-top: -2rem;
}

.n-margin-3 {
  margin-top: -3rem;
}

.n-margin-4 {
  margin-top: -4rem;
}

.n-margin-5 {
  margin-top: -5rem;
}

.n-margin-6 {
  margin-top: -6rem;
}

.z-index-1 {
  z-index: 1;
}

.z-index-2 {
  z-index: 2;
}

@media (min-width: 992px) {
  .fixed-lg-top {
    position: fixed;
    top: 0;
  }
  .fixed-lg-bottom {
    position: fixed;
    bottom: 0;
  }
}

.opacity-90 {
  opacity: 0.9;
}

.opacity-80 {
  opacity: 0.8;
}

.opacity-70 {
  opacity: 0.7;
}

.opacity-60 {
  opacity: 0.6;
}

.opacity-50 {
  opacity: 0.5;
}

.opacity-40 {
  opacity: 0.4;
}

.opacity-30 {
  opacity: 0.3;
}

.opacity-20 {
  opacity: 0.2;
}

.opacity-10 {
  opacity: 0.1;
}

.divider-side-line {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
}

.divider-side-line:after {
  content: '';
  flex: 1 1 auto;
  background: rgba(28, 29, 36, 0.2);
  height: 1px;
}

/*------------------------------------------------
  OPTIMIZED UTILITY CLASSES - Mobile First Design
-------------------------------------------------*/

/* Typography Utilities */
.heading-primary {
  color: #1d1d1f;
  line-height: 1.1;
  letter-spacing: -0.5px;
}

.heading-muted {
  color: #86868b;
}

.text-apple-gray {
  color: #1d1d1f;
}

.text-apple-muted {
  color: #86868b;
}

.text-apple-light {
  color: #2c2c2c;
}

/* Button Utilities */
.button-green-gradient {
  background: linear-gradient(135deg, #1db585, #34c759);
  border: none;
  color: white;
  font-weight: 600;
  transition: all 0.3s ease;
  box-shadow: 0 4px 15px rgba(29, 181, 133, 0.3);
}

.button-green-gradient:hover {
  background: linear-gradient(135deg, #16a575, #2fb84d);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(29, 181, 133, 0.4);
  color: white;
}

.button-rounded {
  border-radius: 50px;
}

.button-large-padding {
  padding: 12px 32px;
  font-size: 18px;
}

/* Client Box Utilities */
.client-box-flex {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 60px;
}

.client-logo-apple {
  color: #2c2c2c;
}

.client-logo-samsung {
  font-family: Arial, sans-serif;
  font-weight: bold;
  font-size: 18px;
  color: #2c2c2c;
  letter-spacing: 2px;
}

.client-logo-google {
  font-family: 'Product Sans', Arial, sans-serif;
  font-weight: 400;
  font-size: 20px;
  color: #2c2c2c;
}

.client-logo-oneplus {
  font-family: Arial, sans-serif;
  font-weight: 300;
  font-size: 18px;
  color: #2c2c2c;
}

.client-logo-xiaomi {
  font-family: Arial, sans-serif;
  font-weight: 400;
  font-size: 18px;
  color: #2c2c2c;
}

.client-logo-oppo {
  font-family: Arial, sans-serif;
  font-weight: 600;
  font-size: 18px;
  color: #2c2c2c;
}

/* Service Text Utilities */
.service-description {
  line-height: 1.4;
  max-width: 480px;
  margin: 0 auto;
  font-weight: 300;
}

/* Display and Visibility Utilities */
.display-none {
  display: none;
}

.display-block {
  display: block;
}

.display-flex {
  display: flex;
}

/* Apple-style Section Spacing */
.section-apple-spacing {
  padding: 80px 0;
}

@media (max-width: 991.98px) {
  .section-apple-spacing {
    padding: 60px 0;
  }
}

@media (max-width: 575.98px) {
  .section-apple-spacing {
    padding: 40px 0;
  }
}

/* Apple-style Text Sizes */
.text-apple-hero {
  font-size: 18px;
  line-height: 1.4;
  font-weight: 400;
}

.text-apple-body {
  font-size: 17px;
  line-height: 1.5;
  font-weight: 400;
}

.text-apple-caption {
  font-size: 14px;
  line-height: 1.4;
  font-weight: 400;
}

/* Responsive Text Utilities */
@media (max-width: 991.98px) {
  .text-apple-hero {
    font-size: 16px;
  }
  
  .text-apple-body {
    font-size: 15px;
  }
}

/* Loading States */
.btn-loading {
  display: none;
  align-items: center;
  justify-content: center;
}

.btn-loading:not(.display-none) {
  display: flex;
}

/* Success Message */
.success-message {
  display: none;
  text-align: center;
  padding: 20px;
  border-radius: 12px;
  background: #f0f9f0;
  color: #1db585;
}

/* Footer Utilities */
.footer-text {
  font-size: 14px;
  line-height: 1.4;
}

.footer-divider {
  border-color: #d2d2d7;
}

/* Modern Card Shadows */
.shadow-apple {
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}

.shadow-apple-hover {
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12);
  transform: translateY(-2px);
  transition: all 0.3s ease;
}

/* Brand Colors as Utilities */
.bg-apple-gray {
  background-color: #f5f5f7;
}

.border-apple-gray {
  border-color: #d2d2d7;
}

/* Image and Container Utilities */
.img-rounded-18 {
  border-radius: 18px;
  overflow: hidden;
}

.img-responsive {
  width: 100%;
  height: auto;
  object-fit: cover;
}

/* Text Weight Utilities */
.text-weight-600 {
  font-weight: 600;
}

.text-weight-400 {
  font-weight: 400;
}

.text-weight-300 {
  font-weight: 300;
}

/* Apple-style Avatar Group */
.avatar-apple {
  width: 50px;
  height: 50px;
  border: 3px solid white;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
  margin-left: -8px;
  position: relative;
  object-fit: cover;
}

.avatar-apple:first-child {
  margin-left: 0;
}

.avatar-apple-1 {
  z-index: 3;
}

.avatar-apple-2 {
  z-index: 2;
}

.avatar-apple-3 {
  z-index: 1;
}

/* Rating and Stars */
.rating-apple {
  color: #ff9500;
}

/* Text Sizes */
.text-size-17 {
  font-size: 17px;
}

.text-size-15 {
  font-size: 15px;
}

/* Line Height Utilities */
.line-height-16 {
  line-height: 1.6;
}

