:root {
  --primary-grey:#6c7a89;
  --dark-grey:#4a5568;
  --light-grey:#a0aec0;
  --metallic-grey:#718096;
  --accent-orange:#ffa502;
  --accent-yellow:#f39c12;
  --dark-blue:#373f3f;
  --light-bg:#f7fafc;
  --white:#fff;
  --border-grey:#e2e8f0;
  --font-primary:"Open Sans", sans-serif;
  --font-secondary:"Montserrat", sans-serif;
  --transition-fast:0.2s ease;
  --transition-normal:0.3s ease;
  --transition-slow:0.4s ease;
  --shadow-light:0 2px 8px rgba(0, 0, 0, 0.1);
  --shadow-medium:0 4px 16px rgba(0, 0, 0, 0.15);
  --shadow-heavy:0 8px 32px rgba(0, 0, 0, 0.2);
}
*,
*::before,
*::after {
  margin:0;
  padding:0;
  box-sizing:border-box
}
html {
  scroll-behavior:smooth;
  overflow-x:hidden;
  -webkit-tap-highlight-color:transparent
}
body {
  font-family:var(--font-primary);
  line-height:1.6;
  color:#555;
  background:var(--white);
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-size:15px;
  overflow-x:hidden
}
[aria-hidden="true"] {
  pointer-events:none
}
[aria-hidden="true"] * {
  pointer-events:none
}
[aria-hidden="true"][tabindex="-1"] {
  visibility:hidden
}
*:focus:not(:focus-visible) {
  outline:none
}
*:focus-visible {
  outline:2px solid var(--accent-orange);
  outline-offset:2px
}
img {
  border:none;
  outline:none;
  max-width:100%;
  height:auto;
  font-style:italic;
  background-repeat:no-repeat;
  background-size:cover;
  shape-margin:0.75rem
}
.body-inner {
  position:relative;
  overflow:hidden
}
h1,
h2,
h3,
h4,
h5,
h6 {
  color:#212121;
  font-weight:700;
  font-family:var(--font-secondary);
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased
}
h1 {
  font-size:36px;
  line-height:48px
}
h2 {
  font-size:28px;
  line-height:36px;
  text-transform:uppercase;
  letter-spacing:-1px
}
h3 {
  font-size:24px;
  margin-bottom:20px;
  text-transform:uppercase;
  letter-spacing:-0.5px
}
h4 {
  font-size:18px;
  line-height:28px;
  text-transform:uppercase;
  letter-spacing:-0.2px
}
.btn {
  border-radius:3px;
  font-weight:700;
  text-transform:uppercase;
  font-family:var(--font-secondary);
  transition:all var(--transition-normal);
  font-size:14px;
  position:relative;
  overflow:hidden;
  cursor:pointer;
  will-change:transform
}
.btn:active,
.btn:focus {
  box-shadow:none !important
}
.btn-primary,
.btn-dark {
  border:0;
  border-radius:3px;
  padding:12px 20px 10px;
  color:var(--white)
}
.btn-primary {
  background:var(--accent-orange)
}
.btn-dark {
  background:#23282d
}
.btn-primary:hover,
.btn-dark:hover {
  background:#111;
  color:var(--white);
  transform:translateY(-2px);
  box-shadow:var(--shadow-medium)
}
.btn-primary:active,
.btn-dark:active {
  transform:translateY(0)
}
.modern-header {
  background:transparent !important;
  padding:0;
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:1000;
  box-shadow:none;
  border:none;
  width:100vw;
  height:90px
}
.modern-header .container {
  max-width:none !important;
  width:100vw !important;
  margin:0 !important;
  padding:0 !important
}
.header-content {
  display:flex;
  align-items:center;
  justify-content:flex-end;
  padding:0 40px 0 0;
  height:90px;
  background:transparent;
  width:100%;
  position:relative
}
.logo-section {
  display:flex;
  align-items:center;
  justify-content:center;
  padding:8px 15px;
  position:absolute;
  top:-5px;
  left:-40px;
  z-index:2;
  width:480px;
  height:100px;
  background:linear-gradient( 135deg,
  #1a1a1a 0%,
  #2d2d2d 30%,
  #000000 70%,
  #1a1a1a 100% );
  border-radius:0 20px 20px 0;
  margin:0 !important;
  border:2px solid rgba(255,
  165,
  2,
  0.2);
  outline:none !important;
  box-shadow:0 8px 32px rgba(0,
  0,
  0,
  0.4),
  0 4px 16px rgba(0,
  0,
  0,
  0.3),
  inset 0 1px 0 rgba(255,
  255,
  255,
  0.1),
  0 0 0 1px rgba(255,
  165,
  2,
  0.1);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  transform:translateZ(0);
  position:relative;
  overflow:hidden;
  transition:all 0.4s cubic-bezier(0.4,
  0,
  0.2,
  1);
  will-change:transform;
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden
}
.logo-section::before {
  content:"";
  position:absolute;
  top:0;
  left:-100%;
  width:100%;
  height:100%;
  background:linear-gradient( 90deg,
  transparent,
  rgba(255,
  165,
  2,
  0.1),
  transparent );
  transition:left 0.8s ease;
  z-index:1
}
.logo-section:hover::before {
  left:100%
}
.logo-section::after {
  content:"";
  position:absolute;
  top:50%;
  left:50%;
  width:0;
  height:0;
  background:radial-gradient( circle,
  rgba(255,
  165,
  2,
  0.1) 0%,
  transparent 70% );
  border-radius:50%;
  transform:translate(-50%,
  -50%);
  animation:pulse-glow 3s ease-in-out infinite;
  z-index:1
}
@keyframes pulse-glow {
  0%,
  100% {
    width:0;
    height:0;
    opacity:0
  }25% {
    width:80px;
    height:80px;
    opacity:0.2
  }50% {
    width:220px;
    height:220px;
    opacity:0.4
  }75% {
    width:120px;
    height:120px;
    opacity:0.25
  }
}
.logo-link {
  text-decoration:none !important;
  color:inherit !important;
  display:block !important;
  line-height:0 !important;
  transition:all 0.3s ease !important;
  height:100%;
  display:flex !important;
  align-items:center !important;
  position:relative;
  z-index:10;
  animation:logo-entrance 1s ease-out;
  border:none !important;
  outline:none !important;
  box-shadow:none !important
}
@keyframes logo-entrance {
  0% {
    opacity:0;
    transform:translateX(-30px)
  }100% {
    opacity:1;
    transform:translateX(0)
  }
}
.logo-link:hover {
  text-decoration:none !important;
  color:inherit !important
}
.site-logo {
  height:85px !important;
  width:450px !important;
  max-width:none !important;
  min-width:none !important;
  display:block !important;
  object-fit:contain !important;
  object-position:center center !important;
  filter:none !important;
  transform:translateZ(0) !important;
  image-rendering:-webkit-optimize-contrast !important;
  image-rendering:-moz-crisp-edges !important;
  image-rendering:crisp-edges !important;
  image-rendering:auto !important;
  image-rendering:high-quality !important;
  -webkit-backface-visibility:hidden;
  backface-visibility:hidden;
  -webkit-transform:translateZ(0) scale(1);
  -moz-transform:translateZ(0) scale(1);
  -ms-transform:translateZ(0) scale(1);
  -o-transform:translateZ(0) scale(1);
  transform:translateZ(0) scale(1);
  -webkit-font-smoothing:subpixel-antialiased;
  -moz-osx-font-smoothing:auto;
  image-orientation:from-image;
  -ms-interpolation-mode:bicubic;
  position:relative;
  z-index:10;
  transition:all 0.4s cubic-bezier(0.4,
  0,
  0.2,
  1);
  border:none !important;
  outline:none !important;
  box-shadow:none !important
}
.site-logo:hover {
  filter:brightness(1.15) drop-shadow(0 0 10px rgba(255,
  165,
  2,
  0.3)) !important;
  transform:translateZ(0) scale(1.03);
  transition:all 0.4s cubic-bezier(0.4,
  0,
  0.2,
  1)
}
.logo-section:hover {
  background:linear-gradient( 135deg,
  #2a2a2a 0%,
  #3d3d3d 30%,
  #1a1a1a 70%,
  #2a2a2a 100% );
  border-color:rgba(255,
  165,
  2,
  0.4);
  box-shadow:0 12px 40px rgba(0,
  0,
  0,
  0.5),
  0 6px 20px rgba(0,
  0,
  0,
  0.4),
  inset 0 1px 0 rgba(255,
  255,
  255,
  0.15),
  0 0 0 1px rgba(255,
  165,
  2,
  0.3),
  0 0 30px rgba(255,
  165,
  2,
  0.15);
  transform:translateY(-2px)
}
.logo-title {
  color:var(--accent-orange);
  font-size:2rem;
  font-weight:900;
  margin:0;
  line-height:1;
  font-family:var(--font-secondary);
  text-transform:uppercase;
  letter-spacing:1px
}
.logo-subtitle {
  color:#bdc3c7;
  font-size:0.9rem;
  font-weight:400;
  display:block;
  margin-top:2px;
  letter-spacing:0.5px
}
.main-navigation {
  position:relative;
  z-index:2;
  padding-right:30px;
  flex:1;
  display:flex;
  justify-content:flex-end
}
.nav-menu {
  display:flex;
  list-style:none;
  margin:0;
  padding:0;
  align-items:center;
  gap:0
}
.nav-item {
  opacity:0;
  transform:translateY(-20px);
  animation:navItemEntrance 0.6s cubic-bezier(0.4,
  0,
  0.2,
  1) forwards;
  position:relative
}
.nav-item::after {
  content:"";
  position:absolute;
  top:50%;
  left:50%;
  width:0;
  height:0;
  background:radial-gradient( circle,
  rgba(255,
  165,
  2,
  0.08) 0%,
  transparent 70% );
  border-radius:50%;
  transform:translate(-50%,
  -50%);
  animation:nav-pulse-glow 5s ease-in-out infinite;
  z-index:0;
  pointer-events:none
}
@keyframes nav-pulse-glow {
  0%,
  100% {
    width:0;
    height:0;
    opacity:0
  }30% {
    width:60px;
    height:60px;
    opacity:0.15
  }50% {
    width:120px;
    height:120px;
    opacity:0.25
  }70% {
    width:80px;
    height:80px;
    opacity:0.1
  }
}
.nav-item:nth-child(1) {
  animation-delay:0.1s
}
.nav-item:nth-child(2) {
  animation-delay:0.2s
}
.nav-item:nth-child(3) {
  animation-delay:0.3s
}
.nav-item:nth-child(4) {
  animation-delay:0.4s
}
.nav-item:nth-child(5) {
  animation-delay:0.5s
}
@keyframes navItemEntrance {
  0% {
    opacity:0;
    transform:translateY(-20px)
  }100% {
    opacity:1;
    transform:translateY(0)
  }
}
.nav-item {
  position:relative
}
.nav-link {
  color:#ffffff;
  text-decoration:none;
  font-family:var(--font-secondary);
  font-weight:600;
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:1px;
  padding:16px 30px 16px 25px;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  margin:0 3px;
  background:linear-gradient( 135deg,
  #1a1a1a 0%,
  #2d2d2d 30%,
  #000000 70%,
  #1a1a1a 100% );
  border-radius:18px;
  border:2px solid rgba(255,
  165,
  2,
  0.1);
  min-width:160px;
  height:55px;
  box-shadow:0 8px 32px rgba(0,
  0,
  0,
  0.4),
  0 4px 16px rgba(0,
  0,
  0,
  0.3),
  inset 0 1px 0 rgba(255,
  255,
  255,
  0.1),
  0 0 0 1px rgba(255,
  165,
  2,
  0.05);
  transition:all 0.4s cubic-bezier(0.4,
  0,
  0.2,
  1);
  overflow:hidden;
  z-index:0
}
.nav-link>* {
  position:relative;
  z-index:2
}
.nav-link::before {
  content:"";
  position:absolute;
  top:0;
  left:-100%;
  width:100%;
  height:100%;
  background:linear-gradient( 90deg,
  transparent,
  rgba(255,
  165,
  2,
  0.05),
  transparent );
  transition:left 0.8s ease;
  z-index:1
}
.nav-link:hover::before {
  left:100%
}
.nav-link::after {
  content:"";
  position:absolute;
  top:50%;
  left:50%;
  width:0;
  height:0;
  background:radial-gradient( circle,
  rgba(255,
  165,
  2,
  0.05) 0%,
  transparent 70% );
  border-radius:50%;
  transform:translate(-50%,
  -50%);
  animation:pulse-glow 3s ease-in-out infinite;
  z-index:1;
  pointer-events:none
}
.nav-link:hover,
.nav-item.active .nav-link {
  color:#ffffff;
  text-decoration:none;
  background:linear-gradient( 135deg,
  #2a2a2a 0%,
  #3d3d3d 30%,
  #1a1a1a 70%,
  #2a2a2a 100% );
  border-color:rgba(255,
  165,
  2,
  0.2);
  box-shadow:0 12px 40px rgba(0,
  0,
  0,
  0.5),
  0 6px 20px rgba(0,
  0,
  0,
  0.4),
  inset 0 1px 0 rgba(255,
  255,
  255,
  0.15),
  0 0 0 1px rgba(255,
  165,
  2,
  0.15),
  0 0 30px rgba(255,
  165,
  2,
  0.08);
  transform:translateY(-2px)
}
.nav-link:hover::before,
.nav-item.active .nav-link::before {
  left:100%
}
.nav-link:hover::after,
.nav-item.active .nav-link::after {
  animation:pulse-glow 3s ease-in-out infinite
}
.nav-item.active .nav-link {
  background:#1a1a1a;
  color:#ffffff !important
}
.nav-item i {
  margin-left:5px;
  font-size:12px;
  transition:transform 0.3s ease
}
.dropdown {
  position:relative;
  z-index:1000
}
.dropdown-menu {
  position:absolute;
  top:calc(100%+2px);
  left:0;
  background:linear-gradient( 135deg,
  #1a1a1a 0%,
  #2d2d2d 30%,
  #000000 70%,
  #1a1a1a 100% );
  min-width:300px;
  box-shadow:0 8px 32px rgba(0,
  0,
  0,
  0.4),
  0 4px 16px rgba(0,
  0,
  0,
  0.3),
  inset 0 1px 0 rgba(255,
  255,
  255,
  0.1),
  0 0 0 1px rgba(255,
  165,
  2,
  0.1);
  border:2px solid rgba(255,
  165,
  2,
  0.2);
  border-radius:15px;
  padding:15px 0;
  margin:0;
  opacity:0;
  visibility:hidden;
  transform:translateY(-10px) scale(0.95);
  transition:all 0.4s cubic-bezier(0.4,
  0,
  0.2,
  1);
  z-index:10000;
  overflow:visible;
  pointer-events:none
}
.dropdown-menu::before {
  content:"";
  position:absolute;
  top:-4px;
  left:0;
  right:0;
  height:4px;
  background:transparent;
  z-index:10001
}
.dropdown:hover .dropdown-menu,
.dropdown-menu:hover {
  opacity:1;
  visibility:visible;
  transform:translateY(0) scale(1);
  pointer-events:auto
}
.dropdown:hover .nav-link i {
  transform:rotate(180deg)
}
.dropdown-menu li {
  list-style:none;
  opacity:0;
  transform:translateX(-10px);
  animation:dropdownItemEntrance 0.3s cubic-bezier(0.4,
  0,
  0.2,
  1) forwards
}
.dropdown-menu li:nth-child(1) {
  animation-delay:0.1s
}
.dropdown-menu li:nth-child(2) {
  animation-delay:0.15s
}
.dropdown-menu li:nth-child(3) {
  animation-delay:0.2s
}
.dropdown-menu li:nth-child(4) {
  animation-delay:0.25s
}
.dropdown-menu li:nth-child(5) {
  animation-delay:0.3s
}
.dropdown-menu li:nth-child(6) {
  animation-delay:0.35s
}
@keyframes dropdownItemEntrance {
  0% {
    opacity:0;
    transform:translateX(-10px)
  }100% {
    opacity:1;
    transform:translateX(0)
  }
}
.dropdown-menu li a.long-label {
  font-size:12px;
  line-height:1.4;
  text-transform:uppercase;
  letter-spacing:0.5px;
  white-space:normal;
  text-align:left
}
.dropdown-menu li a {
  display:block;
  padding:14px 24px;
  color:#ffffff;
  text-decoration:none;
  font-size:13px;
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:0.5px;
  border-bottom:1px solid rgba(255,
  255,
  255,
  0.1);
  transition:all 0.3s cubic-bezier(0.4,
  0,
  0.2,
  1);
  position:relative;
  font-family:var(--font-secondary);
  margin:2px 8px;
  border-radius:8px;
  border-bottom:none;
  z-index:10001;
  cursor:pointer;
  pointer-events:auto
}
.dropdown-menu li:last-child a {
  border-bottom:none
}
.dropdown-menu li a:hover {
  background:rgba(255,
  255,
  255,
  0.15);
  color:#ffffff;
  transform:translateX(2px);
  box-shadow:none
}
.dropdown-menu li a::before {
  content:"";
  position:absolute;
  left:0;
  top:0;
  height:100%;
  width:0;
  background:rgba(255,
  255,
  255,
  0.15);
  transition:width 0.3s cubic-bezier(0.4,
  0,
  0.2,
  1);
  border-radius:8px 0 0 8px;
  z-index:-1
}
.dropdown-menu li a:hover::before {
  width:100%
}
.navbar-toggler {
  display:none;
  flex-direction:column;
  cursor:pointer;
  padding:10px;
  background:none;
  border:none;
  width:35px;
  height:35px;
  justify-content:center;
  align-items:center
}
.navbar-toggler span {
  width:25px;
  height:3px;
  background:var(--accent-orange);
  margin:2px 0;
  transition:all 0.3s ease;
  transform-origin:center
}
.navbar-toggler.active span:nth-child(1) {
  transform:rotate(45deg) translate(5px,
  5px)
}
.navbar-toggler.active span:nth-child(2) {
  opacity:0
}
.navbar-toggler.active span:nth-child(3) {
  transform:rotate(-45deg) translate(7px,
  -6px)
}
.modern-header.navbar-fixed {
  position:fixed;
  top:0;
  left:0;
  right:0;
  width:100%;
  animation:slideInDown 0.3s ease-out;
  z-index:9999
}
.hero {
  min-height:109.9vh;
  width:100vw;
  display:flex;
  align-items:center;
  position:relative;
  overflow:hidden;
  margin:0;
  padding:0;
  left:0;
  right:0;
  background:linear-gradient( 135deg,
  var(--primary-grey) 0%,
  var(--dark-grey) 100% );
  margin-top:-90px;
  padding-top:90px
}
.hero-content {
  position:relative;
  z-index:2;
  color:white;
  text-align:center;
  width:100%;
  padding:0 20px
}
.hero-title {
  font-size:3.5rem;
  font-weight:900;
  margin-bottom:1rem;
  color:white;
  font-family:var(--font-secondary);
  text-transform:uppercase;
  animation:fadeInLeft 1s ease-out 0.3s both
}
.hero-subtitle {
  font-size:1.5rem;
  margin-bottom:2rem;
  color:#f0f0f0;
  font-weight:300;
  animation:fadeInRight 1s ease-out 0.6s both
}
.hero-description {
  font-size:1.1rem;
  margin-bottom:3rem;
  color:#e0e0e0;
  max-width:800px;
  margin-left:auto;
  margin-right:auto;
  animation:fadeInUp 1s ease-out 0.9s both
}
.hero-buttons {
  display:flex;
  gap:20px;
  justify-content:center;
  flex-wrap:wrap;
  animation:bounceIn 1s ease-out 1.2s both
}
.hero-buttons .btn {
  padding:15px 30px;
  font-size:16px;
  margin:10px 5px
}
.hero-video-bg {
  position:absolute;
  top:50%;
  left:50%;
  width:100vw;
  height:109.9vh;
  min-width:100%;
  min-height:100%;
  object-fit:cover;
  object-position:center center;
  transform:translate(-50%,
  -50%) scale(1.15);
  -webkit-transform:translate(-50%,
  -50%) scale(1.15);
  z-index:1;
  opacity:1;
  will-change:transform,
  opacity;
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
  transform-style:preserve-3d;
  -webkit-transform-style:preserve-3d;
  -webkit-perspective:1000px;
  perspective:1000px;
  image-rendering:-webkit-optimize-contrast;
  image-rendering:crisp-edges;
  -ms-interpolation-mode:bicubic;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  filter:contrast(1.05) brightness(1.02);
  -webkit-filter:contrast(1.05) brightness(1.02);
  contain:layout style paint;
  -webkit-tap-highlight-color:transparent;
  touch-action:manipulation
}
.hero-video-bg[data-loading="slow"] {
  display:none
}
.hero-video-bg[data-loading="slow"]~.hero-fallback-bg {
  display:block
}
@media (prefers-reduced-motion:reduce) {
  .hero-video-bg {
    animation:none;
    transition:none
  }
}
section {
  padding:70px 0;
  position:relative
}
.section-title {
  font-size:18px;
  line-height:28px;
  margin:0;
  text-transform:uppercase;
  font-weight:300
}
.section-sub-title {
  font-weight:900;
  font-size:36px;
  line-height:46px;
  margin:0 0 60px;
  color:#212121
}
.solid-bg {
  background:#f9f9f9
}
.dark-bg {
  background:#252525;
  color:#fff
}
.dark-bg h2,
.dark-bg h3 {
  color:#fff
}
.ts-service-box {
  margin-bottom:40px;
  transition:transform var(--transition-slow),
  box-shadow var(--transition-slow);
  position:relative;
  overflow:hidden;
  will-change:transform
}
.ts-service-box:hover {
  transform:translateY(-8px);
  box-shadow:var(--shadow-heavy)
}
.ts-service-icon {
  margin-right:25px;
  margin-bottom:40px
}
.ts-service-icon i {
  font-size:28px;
  color:var(--accent-orange);
  transition:transform var(--transition-normal);
  will-change:transform
}
.ts-service-box:hover .ts-service-icon i {
  transform:scale(1.2)
}
.service-box-title {
  font-size:16px;
  margin:0 0 10px
}
.service-box-title a {
  color:#000 !important;
  text-decoration:none
}
.service-box-title a:hover {
  color:#000 !important;
  text-decoration:none
}
@keyframes fadeInUp {
  from {
    opacity:0;
    transform:translateY(30px)
  }to {
    opacity:1;
    transform:translateY(0)
  }
}
@keyframes fadeInLeft {
  from {
    opacity:0;
    transform:translateX(-50px)
  }to {
    opacity:1;
    transform:translateX(0)
  }
}
@keyframes fadeInRight {
  from {
    opacity:0;
    transform:translateX(50px)
  }to {
    opacity:1;
    transform:translateX(0)
  }
}
@keyframes slideInDown {
  from {
    opacity:0;
    transform:translateY(-50px)
  }to {
    opacity:1;
    transform:translateY(0)
  }
}
@keyframes bounceIn {
  0% {
    opacity:0;
    transform:scale(0.3)
  }50% {
    opacity:1;
    transform:scale(1.05)
  }70% {
    transform:scale(0.9)
  }100% {
    opacity:1;
    transform:scale(1)
  }
}
.language-switch-container {
  position:fixed !important;
  top:30px !important;
  right:0px !important;
  z-index:1000;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  pointer-events:none;
  transform:translateZ(0);
  will-change:auto;
  width:auto;
  min-width:50px
}
.language-switch-container>* {
  pointer-events:auto
}
.language-switch {
  --color:#18ffa0;
  --rotation:25deg;
  --pivot-distance:12px;
  --width:50px;
  --height:65px;
  background-color:black;
  width:var(--width);
  height:var(--height);
  box-shadow:0 0 10px 2px rgba(0,
  0,
  0,
  0.2),
  inset 0 2px 2px -2px white,
  inset 0 0 2px 22px black;
  border-radius:5px;
  padding:8px;
  perspective:500px;
  cursor:pointer;
  position:relative;
  transform:translateZ(0);
  backface-visibility:hidden
}
.language-switch input {
  display:none
}
.language-switch input:checked+.button {
  transform:translateZ(var(--pivot-distance)) rotateX(var(--rotation))
}
.language-switch input:checked+.button .shine {
  opacity:1
}
.language-switch input:checked+.button .shadow {
  opacity:0
}
.language-switch .button {
  transition:transform 0.3s cubic-bezier(1,
  0,
  1,
  1);
  transform-origin:center center calc(-1 * var(--pivot-distance));
  transform:translateZ(var(--pivot-distance)) rotateX(calc(-1 * var(--rotation)));
  transform-style:preserve-3d;
  background-color:#9b0621;
  width:100%;
  height:100%;
  position:relative;
  cursor:pointer;
  background:linear-gradient( #6b0015 0%,
  #660014 30%,
  #660014 70%,
  #6b0015 100% );
  background-repeat:no-repeat;
  backface-visibility:hidden
}
.language-switch .button::before {
  content:"";
  background:linear-gradient( rgba(255,
  255,
  255,
  0.8) 10%,
  rgba(255,
  255,
  255,
  0.3) 30%,
  #4d0010 75%,
  #3d000d 85% ) 50% 50% / 97% 97%,
  #6b0015;
  background-repeat:no-repeat;
  width:100%;
  height:30px;
  transform-origin:top;
  transform:rotateX(-90deg);
  position:absolute;
  top:0
}
.language-switch .button::after {
  content:"";
  background-image:linear-gradient(#4d0010,
  #3d000d);
  width:100%;
  height:30px;
  transform-origin:top;
  transform:translateY(30px) rotateX(-90deg);
  position:absolute;
  bottom:0;
  box-shadow:0 30px 5px 0px black,
  0 50px 12px 0px rgba(0,
  0,
  0,
  0.5)
}
.language-switch .light {
  display:none
}
.language-switch .dots {
  position:absolute;
  width:100%;
  height:100%;
  background-image:radial-gradient( transparent 30%,
  rgba(66,
  0,
  16,
  0.7) 70% );
  background-size:10px 10px
}
.language-switch .characters {
  position:absolute;
  width:100%;
  height:100%;
  background:linear-gradient(white,
  white) 50% 20% / 4% 18%,
  radial-gradient(circle,
  transparent 50%,
  white 52%,
  white 70%,
  transparent 72%) 50% 80% / 30% 22%;
  background-repeat:no-repeat
}
.language-switch .shine {
  transition:all 0.3s cubic-bezier(1,
  0,
  1,
  1);
  opacity:0.3;
  position:absolute;
  width:100%;
  height:100%;
  background:linear-gradient(white,
  transparent 3%) 50% 50% / 97% 97%,
  linear-gradient(rgba(255,
  255,
  255,
  0.5),
  transparent 50%,
  transparent 80%,
  rgba(255,
  255,
  255,
  0.5)) 50% 50% / 97% 97%;
  background-repeat:no-repeat
}
.language-switch .shadow {
  transition:all 0.3s cubic-bezier(1,
  0,
  1,
  1);
  opacity:1;
  position:absolute;
  width:100%;
  height:100%;
  background:linear-gradient(transparent 70%,
  rgba(0,
  0,
  0,
  0.8));
  background-repeat:no-repeat
}
.language-switch-info {
  text-align:center;
  color:rgba(255,
  255,
  255,
  0.95);
  background:linear-gradient( 135deg,
  rgba(0,
  0,
  0,
  0.85),
  rgba(30,
  30,
  30,
  0.75) );
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-radius:6px;
  padding:3px 6px;
  border:1px solid rgba(255,
  255,
  255,
  0.2);
  box-shadow:0 3px 12px rgba(0,
  0,
  0,
  0.5),
  0 0 0 1px rgba(255,
  255,
  255,
  0.05);
  min-width:60px;
  width:auto;
  display:inline-block;
  position:relative
}
.language-switch-current {
  font-size:0.5rem;
  font-weight:700;
  margin:0;
  color:var(--accent-orange);
  transition:opacity 0.2s ease,
  color 0.2s ease;
  text-transform:uppercase;
  letter-spacing:0.2px;
  white-space:nowrap;
  display:block;
  width:100%;
  text-align:center
}
.language-switch-hint {
  display:none
}
@media (max-width:1200px) {
  .language-switch-container {
    top:25px !important;
    right:0px !important
  }
}
@media (max-width:1000px) {
  .language-switch-container {
    top:15px !important;
    right:0px !important
  }
}
@media (max-width:768px) {
  .language-switch-container {
    top:25px !important;
    right:0px !important;
    gap:6px
  }.language-switch {
    --width:45px;
    --height:58px;
    --pivot-distance:10px;
    padding:7px
  }.language-switch .button::before,
  .language-switch .button::after {
    height:25px
  }.language-switch .button::after {
    transform:translateY(25px) rotateX(-90deg)
  }.language-switch-current {
    font-size:0.5rem
  }.language-switch-info {
    padding:3px 6px;
    min-width:60px
  }
}
@media (max-width:575px) {
  .language-switch-container {
    top:20px !important;
    right:0px !important;
    gap:5px
  }
}
@media (max-width:480px) {
  .language-switch-container {
    top:20px !important;
    right:0px !important;
    gap:5px
  }.language-switch {
    --width:40px;
    --height:52px;
    --pivot-distance:8px;
    padding:6px
  }.language-switch .button::before,
  .language-switch .button::after {
    height:22px
  }.language-switch .button::after {
    transform:translateY(22px) rotateX(-90deg)
  }.language-switch-current {
    font-size:0.45rem
  }.language-switch-info {
    padding:2px 5px;
    min-width:55px
  }
}
.language-switch-flag {
  background:transparent;
  border:none;
  border-radius:8px;
  padding:0;
  cursor:pointer;
  transition:all 0.3s ease;
  display:flex;
  align-items:center;
  justify-content:center;
  width:32px;
  height:32px
}
.language-switch-flag:hover {
  transform:scale(1.05)
}
.language-switch-flag:active {
  transform:scale(0.95)
}
.flag-icon {
  width:100%;
  height:100%;
  object-fit:contain;
  display:block
}
@media (max-width:1200px) {
  .language-switch-flag {
    width:30px;
    height:30px
  }
}
@media (max-width:768px) {
  .language-switch-flag {
    width:30px;
    height:30px
  }
}
@media (max-width:575px) {
  .language-switch-flag {
    width:28px;
    height:28px
  }
}
@media (max-width:480px) {
  .language-switch-flag {
    width:26px;
    height:26px
  }
}
.sidebar-toggle {
  position:fixed;
  top:20px;
  right:10px;
  z-index:10000;
  cursor:pointer;
  width:50px;
  height:50px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(0,
  0,
  0,
  0.8);
  border-radius:8px;
  transition:all 0.3s ease;
  border:2px solid var(--accent-orange)
}
.sidebar-toggle:hover {
  background:rgba(0,
  0,
  0,
  0.95);
  transform:scale(1.05)
}
.sidebar-toggle-icon {
  display:flex;
  flex-direction:column;
  gap:5px;
  width:24px
}
.sidebar-toggle-icon span {
  display:block;
  width:100%;
  height:3px;
  background:var(--accent-orange);
  border-radius:2px;
  transition:all 0.3s ease
}
.sidebar-toggle.active .sidebar-toggle-icon span:nth-child(1) {
  transform:rotate(45deg) translate(7px,
  7px)
}
.sidebar-toggle.active .sidebar-toggle-icon span:nth-child(2) {
  opacity:0
}
.sidebar-toggle.active .sidebar-toggle-icon span:nth-child(3) {
  transform:rotate(-45deg) translate(7px,
  -7px)
}
.language-sidebar {
  position:fixed;
  top:0;
  right:-350px;
  width:350px;
  height:100vh;
  background:linear-gradient(135deg,
  #2a2a2a 0%,
  #1a1a1a 100%);
  z-index:9999;
  transition:right 0.4s cubic-bezier(0.4,
  0,
  0.2,
  1);
  box-shadow:-5px 0 20px rgba(0,
  0,
  0,
  0.5);
  overflow-y:auto
}
.language-sidebar.open {
  right:0
}
.sidebar-content {
  padding:80px 30px 30px
}
.sidebar-title {
  color:#ffffff;
  font-size:1.5rem;
  margin-bottom:30px;
  text-align:center;
  font-weight:600
}
.sidebar-languages {
  display:flex;
  flex-direction:column;
  gap:15px
}
.sidebar-lang-btn {
  display:block;
  padding:15px 20px;
  background:rgba(255,
  255,
  255,
  0.1);
  color:#ffffff;
  text-decoration:none;
  border-radius:8px;
  transition:all 0.3s ease;
  border:2px solid transparent
}
.sidebar-lang-btn:hover {
  background:rgba(255,
  255,
  255,
  0.2);
  border-color:var(--accent-orange);
  transform:translateX(5px)
}
.sidebar-lang-btn.active {
  background:rgba(255,
  165,
  2,
  0.2);
  border-color:var(--accent-orange)
}
.sidebar-footer {
  margin-top:30px;
  text-align:center;
  color:rgba(255,
  255,
  255,
  0.7);
  font-size:0.9rem
}
.sidebar-overlay {
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:100%;
  background:rgba(0,
  0,
  0,
  0.5);
  z-index:9998;
  opacity:0;
  visibility:hidden;
  transition:all 0.3s ease
}
.sidebar-overlay.active {
  opacity:1;
  visibility:visible
}
@media (max-width:768px) {
  .sidebar-toggle {
    top:15px;
    right:10px;
    width:45px;
    height:45px
  }.language-sidebar {
    width:100%;
    right:-100%
  }
}
@media (max-width:480px) {
  .sidebar-toggle {
    top:10px;
    right:5px;
    width:40px;
    height:40px
  }.sidebar-content {
    padding:70px 20px 20px
  }
}
@media (max-width:991px) {
  .navbar-toggler {
    display:flex;
    background:linear-gradient( 135deg,
    #4a3728 0%,
    #5d4435 30%,
    #3a2a1f 70%,
    #4a3728 100% );
    border-radius:8px;
    padding:8px;
    margin-right:15px
  }.navbar-toggler span {
    background:#ffffff;
    width:20px;
    height:2px
  }.nav-menu {
    position:fixed;
    top:90px;
    right:-100%;
    width:100%;
    height:calc(100vh - 90px);
    background:linear-gradient(135deg,
    #2a2a2a 0%,
    #1a1a1a 100%);
    flex-direction:column;
    align-items:stretch;
    padding:30px 0;
    transition:right 0.4s cubic-bezier(0.4,
    0,
    0.2,
    1);
    overflow-y:auto;
    gap:0;
    z-index:9998;
    backdrop-filter:blur(20px);
    -webkit-backdrop-filter:blur(20px)
  }.nav-menu.active {
    right:0
  }.nav-item {
    width:100%;
    border-bottom:1px solid rgba(255,
    255,
    255,
    0.1);
    opacity:0;
    transform:translateX(50px);
    animation:mobileNavSlide 0.3s ease forwards
  }.nav-item:nth-child(1) {
    animation-delay:0.1s
  }.nav-item:nth-child(2) {
    animation-delay:0.2s
  }.nav-item:nth-child(3) {
    animation-delay:0.3s
  }.nav-item:nth-child(4) {
    animation-delay:0.4s
  }.nav-item:nth-child(5) {
    animation-delay:0.5s
  }@keyframes mobileNavSlide {
    to {
      opacity:1;
      transform:translateX(0)
    }
  }.nav-link {
    padding:25px 30px;
    width:100%;
    text-align:left;
    background:transparent;
    border-radius:0;
    box-shadow:none;
    border:none;
    margin:0;
    min-width:auto;
    height:auto;
    font-size:16px;
    color:#ffffff
  }.nav-link:hover {
    background:rgba(255,
    255,
    255,
    0.1);
    transform:translateX(10px);
    box-shadow:none
  }.dropdown-menu {
    position:static;
    background:rgba(0,
    0,
    0,
    0.3);
    box-shadow:none;
    border:none;
    border-radius:0;
    opacity:1;
    visibility:visible;
    transform:none;
    max-height:0;
    overflow:hidden;
    transition:max-height 0.4s ease;
    margin:0;
    padding:0
  }.dropdown.active .dropdown-menu {
    max-height:400px;
    padding:10px 0
  }.dropdown-menu li a {
    padding:18px 60px;
    border-bottom:1px solid rgba(255,
    255,
    255,
    0.05);
    color:#cccccc;
    font-size:14px;
    background:transparent;
    border-radius:0;
    margin:0
  }.dropdown-menu li a:hover {
    background:rgba(255,
    255,
    255,
    0.1);
    color:#ffffff;
    transform:translateX(10px)
  }
}
@media (max-width:1200px) {
  .logo-section {
    width:430px;
    height:90px;
    left:-35px
  }.site-logo {
    height:75px !important;
    width:400px !important
  }.nav-link {
    font-size:12px;
    padding:14px 20px 14px 18px;
    min-width:140px;
    height:50px
  }.modern-header {
    height:80px
  }.header-content {
    height:80px
  }
}
@media (max-width:1000px) {
  .logo-section {
    width:360px;
    height:80px;
    left:-30px;
    border-radius:0 15px 15px 0
  }.site-logo {
    height:65px !important;
    width:330px !important
  }.nav-link {
    font-size:11px;
    padding:12px 16px 12px 14px;
    min-width:120px;
    height:45px;
    margin:0 2px
  }.modern-header {
    height:70px
  }.header-content {
    height:70px;
    padding:0 20px 0 0
  }.hero-title {
    font-size:2.5rem
  }.hero-subtitle {
    font-size:1.2rem
  }.section-sub-title {
    font-size:28px
  }
}
@media (max-width:768px) {
  .logo-section {
    width:300px;
    height:65px;
    left:-25px;
    border-radius:0 12px 12px 0;
    padding:6px 12px
  }.site-logo {
    height:55px !important;
    width:270px !important
  }.modern-header {
    height:60px
  }.header-content {
    height:60px;
    padding:0 15px 0 0
  }.nav-link {
    font-size:10px;
    padding:10px 12px 10px 10px;
    min-width:100px;
    height:40px;
    margin:0 1px;
    border-radius:12px
  }.dropdown-menu {
    min-width:180px;
    border-radius:10px;
    padding:10px 0
  }.dropdown-menu li a {
    padding:12px 18px;
    font-size:11px
  }.nav-item:nth-child(n+5) {
    display:none
  }
}
@media (max-width:575px) {
  .logo-section {
    width:270px;
    height:60px;
    left:-20px;
    border-radius:0 10px 10px 0;
    padding:5px 10px
  }.site-logo {
    height:50px !important;
    width:240px !important
  }.modern-header {
    height:55px
  }.header-content {
    height:55px;
    padding:0 10px 0 0
  }.navbar-toggler {
    display:flex !important;
    margin-right:10px
  }.nav-menu {
    display:none
  }.hero-title {
    font-size:2rem
  }.hero-subtitle {
    font-size:1rem
  }.section-sub-title {
    font-size:24px
  }
}
.no-padding {
  padding:0
}
.gap-60 {
  clear:both;
  height:60px
}
.gap-40 {
  clear:both;
  height:40px
}
.gap-20 {
  clear:both;
  height:20px
}
.general-btn {
  margin-top:50px
}
.list-arrow {
  list-style:none;
  margin:0;
  padding:0
}
ul.list-arrow li:before {
  font-family:"Font Awesome 5 Free";
  content:"\f105";
  margin-right:10px;
  color:var(--accent-orange);
  font-size:16px;
  font-weight:bold
}
.services-title {
  color:var(--dark-grey);
  font-weight:600;
  margin-bottom:25px;
  font-size:1.3rem
}
.elevated-services-list {
  background:var(--white);
  border-radius:8px;
  padding:10px;
  box-shadow:0 2px 8px rgba(0,
  0,
  0,
  0.08);
  border:1px solid var(--border-grey)
}
.service-item {
  display:flex;
  align-items:flex-start;
  padding:6px 0;
  border-bottom:1px solid rgba(108,
  122,
  137,
  0.08);
  transition:all var(--transition-fast)
}
.service-item:last-child {
  border-bottom:none
}
.service-item:hover {
  background:rgba(108,
  122,
  137,
  0.03);
  margin:0 -6px;
  padding:6px 6px;
  border-radius:6px
}
.service-bullet {
  display:inline-block;
  width:6px;
  height:6px;
  background:var(--primary-grey);
  border-radius:50%;
  margin-right:12px;
  margin-top:8px;
  flex-shrink:0
}
.service-item:hover .service-bullet {
  background:var(--dark-grey)
}
.service-text {
  font-size:1rem;
  color:var(--dark-grey);
  font-weight:600;
  line-height:1.5;
  flex:1
}
@media (max-width:768px) {
  .elevated-services-list {
    padding:8px
  }.service-item {
    padding:5px 0
  }.service-item:hover {
    margin:0 -4px;
    padding:5px 4px
  }.service-bullet {
    width:5px;
    height:5px;
    margin-right:10px;
    margin-top:6px
  }.service-text {
    font-size:0.9rem
  }
}
.loading-spinner {
  display:inline-block;
  width:20px;
  height:20px;
  border:3px solid rgba(255,
  255,
  255,
  0.3);
  border-radius:50%;
  border-top-color:#fff;
  animation:spin 1s ease-in-out infinite
}
@keyframes spin {
  to {
    transform:rotate(360deg)
  }
}
@keyframes slideInUp {
  from {
    opacity:0;
    transform:translateY(30px)
  }to {
    opacity:1;
    transform:translateY(0)
  }
}
@keyframes slideInScale {
  from {
    opacity:0;
    transform:translateX(-50%) scaleX(0)
  }to {
    opacity:1;
    transform:translateX(-50%) scaleX(1)
  }
}
@keyframes pulse {
  0%,
  100% {
    transform:scale(1)
  }50% {
    transform:scale(1.05)
  }
}
@keyframes shake {
  0%,
  100% {
    transform:translateX(0)
  }10%,
  30%,
  50%,
  70%,
  90% {
    transform:translateX(-5px)
  }20%,
  40%,
  60%,
  80% {
    transform:translateX(5px)
  }
}
#back-to-top {
  right:40px;
  top:auto;
  z-index:10;
  display:none;
  position:fixed;
  bottom:20px
}
#back-to-top .btn:focus {
  outline:0;
  box-shadow:none
}
#back-to-top .btn.btn-primary {
  width:36px;
  height:36px;
  line-height:36px;
  background:rgba(0,
  0,
  0,
  0.9);
  border-radius:3px;
  color:var(--accent-orange);
  font-weight:700;
  font-size:16px;
  padding:0
}
#back-to-top .btn.btn-primary:hover {
  color:#fff
}
.footer {
  background-color:#0d0d0d;
  color:#999
}
.footer-main {
  padding:35px 0 25px
}
.footer .widget-title {
  font-size:14px;
  font-weight:700;
  position:relative;
  margin:0 0 15px;
  padding-left:15px;
  text-transform:uppercase;
  color:#fff;
  border-left:3px solid var(--accent-orange)
}
.footer .widget-title.operating-hours {
  letter-spacing:0.5px
}
.footer-logo {
  margin-bottom:10px
}
.footer-social {
  margin-top:15px
}
.footer-social ul {
  list-style:none;
  margin:0;
  padding:0;
  margin-left:-13px
}
.footer-social ul li {
  display:inline-block
}
.footer-social ul li a {
  display:block;
  color:#999;
  transition:color 0.3s ease;
  padding:10px 13px
}
.footer-social ul li a:hover {
  color:var(--accent-orange)
}
.footer-social ul li a i {
  font-size:16px
}
.footer-widget ul.list-arrow {
  list-style:none;
  margin:0;
  padding:0
}
.footer-widget ul.list-arrow li {
  border-bottom:1px solid rgba(255,
  255,
  255,
  0.07);
  padding:4px 0
}
.footer-widget ul.list-arrow li:before {
  content:none
}
.footer-widget ul.list-arrow li:last-child {
  border-bottom:0
}
.footer-widget ul.list-arrow li a {
  color:#747474;
  text-decoration:none;
  transition:color 0.3s ease
}
.footer-widget ul.list-arrow li:hover a {
  color:var(--accent-orange)
}
.footer-social-elegant {
  display:flex;
  gap:10px;
  margin:12px 0;
  flex-wrap:wrap
}
.social-link {
  display:flex;
  align-items:center;
  justify-content:center;
  width:45px;
  height:45px;
  background:rgba(255,
  255,
  255,
  0.1);
  border:2px solid rgba(255,
  255,
  255,
  0.2);
  border-radius:50%;
  color:#ccc;
  text-decoration:none;
  transition:all 0.3s ease;
  backdrop-filter:blur(10px)
}
.social-link:hover {
  background:var(--accent-orange);
  border-color:var(--accent-orange);
  color:white;
  transform:translateY(-2px);
  box-shadow:0 5px 15px rgba(255,
  165,
  2,
  0.3)
}
.social-link i {
  font-size:18px;
  transition:transform 0.3s ease
}
.social-link:hover i {
  transform:scale(1.1)
}
.social-description {
  color:#999;
  font-size:10px;
  line-height:1.2;
  margin-top:8px;
  font-style:italic
}
.contact-info-widget .footer-social-elegant {
  display:block;
  gap:0;
  margin:0;
  flex-wrap:nowrap
}
.contact-info-widget .social-link {
  display:flex;
  align-items:flex-start;
  justify-content:flex-start;
  width:auto;
  height:auto;
  background:transparent;
  border:none;
  border-radius:0;
  color:#747474;
  text-decoration:none;
  transition:color 0.3s ease;
  backdrop-filter:none;
  margin-bottom:12px;
  padding:0
}
.contact-info-widget .social-link:hover {
  background:transparent;
  border:none;
  color:var(--accent-orange);
  transform:none;
  box-shadow:none
}
.contact-info-widget .social-link i {
  font-size:14px;
  margin-right:10px;
  margin-top:2px;
  color:var(--accent-orange);
  transition:none;
  flex-shrink:0
}
.contact-info-widget .social-link:hover i {
  transform:none;
  color:var(--accent-orange)
}
.contact-info-widget .social-description {
  color:#747474;
  font-size:14px;
  line-height:1.4;
  margin-top:0;
  font-style:normal;
  flex:1
}
.contact-info-widget .social-link:hover .social-description {
  color:var(--accent-orange)
}
#language-toggle {
  border:1px solid rgba(255,
  255,
  255,
  0.3);
  background:rgba(255,
  255,
  255,
  0.1);
  color:#fff;
  font-size:12px;
  padding:6px 12px;
  border-radius:20px;
  transition:all 0.3s ease;
  backdrop-filter:blur(10px)
}
#language-toggle:hover {
  background:rgba(255,
  255,
  255,
  0.2);
  border-color:rgba(255,
  255,
  255,
  0.5);
  transform:translateY(-1px);
  box-shadow:0 4px 8px rgba(0,
  0,
  0,
  0.2)
}
#language-toggle:focus {
  box-shadow:0 0 0 3px rgba(255,
  165,
  2,
  0.3)
}
#language-toggle i {
  font-size:14px
}
@media (max-width:768px) {
  .footer-social-elegant {
    gap:12px;
    margin:15px 0
  }.social-link {
    width:40px;
    height:40px
  }.social-link i {
    font-size:16px
  }.social-description {
    font-size:12px;
    margin-top:12px
  }
}
.working-hours {
  padding-right:10px;
  line-height:1.2;
  margin-bottom:0
}
.footer .working-hours {
  line-height:1.1
}
.working-hours .text-right {
  float:right
}
.footer .working-hours {
  line-height:1.8;
  font-size:13px;
  color:#ccc;
  margin-top:10px
}
.footer .working-hours .text-right {
  float:none;
  margin-left:15px;
  font-weight:600;
  color:#fff;
  background:linear-gradient( 135deg,
  rgba(255,
  165,
  2,
  0.15),
  rgba(255,
  165,
  2,
  0.05) );
  padding:4px 12px;
  border-radius:6px;
  border-left:3px solid var(--accent-orange);
  font-family:var(--font-primary);
  font-size:12px;
  letter-spacing:0.5px;
  box-shadow:0 2px 4px rgba(0,
  0,
  0,
  0.1);
  transition:all 0.3s ease
}
.footer .working-hours .text-right:hover {
  background:linear-gradient( 135deg,
  rgba(255,
  165,
  2,
  0.25),
  rgba(255,
  165,
  2,
  0.1) );
  transform:translateY(-1px);
  box-shadow:0 4px 8px rgba(0,
  0,
  0,
  0.15)
}
.footer .working-hours br {
  margin:12px 0;
  display:block
}
.footer .working-hours .text-right:contains("Κλειστά") {
  background:linear-gradient( 135deg,
  rgba(255,
  0,
  0,
  0.1),
  rgba(255,
  0,
  0,
  0.05) );
  border-left-color:#ff4444;
  color:#ff6666
}
.footer .working-hours {
  position:relative;
  display:flex;
  flex-direction:column;
  gap:8px
}
.footer .hours-row {
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:6px 0;
  border-bottom:1px solid rgba(255,
  255,
  255,
  0.05);
  transition:all 0.3s ease
}
.footer .hours-row:hover {
  background:rgba(255,
  255,
  255,
  0.02);
  border-radius:4px;
  padding-left:8px;
  padding-right:8px
}
.footer .hours-row:last-child {
  border-bottom:none
}
.footer .day-name {
  font-weight:500;
  color:#e0e0e0;
  font-size:13px
}
.footer .text-right.closed {
  background:linear-gradient( 135deg,
  rgba(255,
  0,
  0,
  0.15),
  rgba(255,
  0,
  0,
  0.05) ) !important;
  border-left-color:#ff4444 !important;
  color:#ff6666 !important
}
.footer-banner-integrated {
  background:white;
  padding:0;
  margin:0;
  position:relative;
  transition:all 0.3s ease
}
.footer-banner-integrated::after {
  content:"";
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  height:1px;
  background:#000000;
  opacity:0.2
}
.banner-copyright-line {
  background:linear-gradient( 90deg,
  #0d0d0d,
  #1a1a1a,
  #0d0d0d );
  background-size:200% 100%;
  color:#111;
  padding:4px 0;
  position:relative;
  z-index:1;
  font-weight:600;
  font-size:12px;
  text-align:center;
  animation:none;
  overflow:hidden;
  border-top:2px solid rgba(255,
  255,
  255,
  0.2);
  border-bottom:2px solid rgba(0,
  0,
  0,
  0.1)
}
.banner-copyright-line::before {
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background:transparent;
  animation:none
}
.banner-copyright-line::after {
  content:"";
  position:absolute;
  top:50%;
  left:0;
  right:0;
  height:2px;
  background:linear-gradient( 90deg,
  transparent 0%,
  #ffa502 50%,
  transparent 100% );
  transform:translateY(-50%);
  animation:none;
  box-shadow:none
}
@keyframes electricalFlow {
  0% {
    background-position:0% 50%
  }100% {
    background-position:200% 50%
  }
}
@keyframes powerPulse {
  0%,
  100% {
    transform:scaleY(1);
    filter:brightness(1) contrast(1)
  }50% {
    transform:scaleY(1.02);
    filter:brightness(1.15) contrast(1.1)
  }
}
@keyframes electricalScan {
  0% {
    transform:translateX(-100%);
    opacity:0
  }50% {
    opacity:1
  }100% {
    transform:translateX(100%);
    opacity:0
  }
}
@keyframes pulseGlow {
  0%,
  100% {
    opacity:0.8;
    box-shadow:0 0 10px rgba(255,
    165,
    2,
    0.6),
    0 0 20px rgba(255,
    165,
    2,
    0.4)
  }50% {
    opacity:1;
    box-shadow:0 0 15px rgba(255,
    165,
    2,
    0.8),
    0 0 30px rgba(255,
    165,
    2,
    0.6)
  }
}
@keyframes subtleFlow {
  0%,
  100% {
    opacity:0.1;
    transform:scaleX(0.8)
  }50% {
    opacity:0.4;
    transform:scaleX(1.2)
  }
}
@keyframes electricalPulse {
  0% {
    opacity:0.1;
    transform:translateY(-50%) scaleX(0.2);
    box-shadow:0 0 2px rgba(255,
    102,
    0,
    0.3),
    0 0 4px rgba(255,
    102,
    0,
    0.2),
    0 0 8px rgba(255,
    102,
    0,
    0.1)
  }25% {
    opacity:0.7;
    transform:translateY(-50%) scaleX(0.7);
    box-shadow:0 0 8px rgba(255,
    102,
    0,
    0.8),
    0 0 16px rgba(255,
    102,
    0,
    0.6),
    0 0 24px rgba(255,
    102,
    0,
    0.4)
  }50% {
    opacity:1;
    transform:translateY(-50%) scaleX(1.3);
    box-shadow:0 0 20px rgba(255,
    102,
    0,
    1),
    0 0 40px rgba(255,
    102,
    0,
    0.8),
    0 0 60px rgba(255,
    102,
    0,
    0.6),
    0 0 80px rgba(255,
    102,
    0,
    0.3)
  }75% {
    opacity:0.8;
    transform:translateY(-50%) scaleX(0.8);
    box-shadow:0 0 12px rgba(255,
    102,
    0,
    0.9),
    0 0 24px rgba(255,
    102,
    0,
    0.7),
    0 0 36px rgba(255,
    102,
    0,
    0.5)
  }100% {
    opacity:0.2;
    transform:translateY(-50%) scaleX(0.3);
    box-shadow:0 0 4px rgba(255,
    102,
    0,
    0.4),
    0 0 8px rgba(255,
    102,
    0,
    0.3),
    0 0 12px rgba(255,
    102,
    0,
    0.2)
  }
}
.banner-copyright-line:hover {
  animation:none;
  transform:none;
  filter:none;
  box-shadow:none;
  transition:none
}
.banner-copyright-line:hover::after {
  box-shadow:none;
  animation:none
}
.footer-banner-container-integrated {
  display:flex;
  justify-content:center;
  align-items:center;
  width:100%;
  background:white;
  padding:0;
  margin:0
}
.footer-banner-image-integrated {
  width:100%;
  max-width:900px;
  height:auto;
  display:block;
  background:white;
  filter:none;
  mix-blend-mode:normal;
  box-shadow:none;
  border:none;
  margin:0;
  padding:0;
  -webkit-backface-visibility:hidden;
  backface-visibility:hidden;
  -webkit-transform:translateZ(0);
  transform:translateZ(0);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  -webkit-filter:brightness(1.05) contrast(1.15) saturate(1.1);
  filter:brightness(1.05) contrast(1.15) saturate(1.1);
  image-rendering:auto;
  image-rendering:smooth;
  will-change:transform;
  transform:translate3d(0,
  0,
  0)
}
.footer-banner-absolute {
  background:#ffffff;
  padding:20px 0;
  margin:0;
  position:relative;
  transition:all 0.3s ease;
  border-top:2px solid #ffa502;
  border-bottom:1px solid #000000
}
.footer-banner-absolute::after {
  display:none
}
.footer-banner-container-absolute {
  display:flex;
  justify-content:center;
  align-items:center;
  padding:15px 0;
  background:#ffffff;
  margin:0
}
.footer-banner-image-absolute {
  width:100%;
  max-width:900px;
  height:auto;
  display:block;
  margin:0 auto;
  border-radius:8px;
  box-shadow:0 4px 15px rgba(0,
  0,
  0,
  0.3);
  transition:all 0.3s ease
}
.footer-banner-image-absolute:hover {
  transform:translateY(-2px);
  box-shadow:0 6px 20px rgba(0,
  0,
  0,
  0.4)
}
@media (max-width:768px) {
  .footer-banner-integrated {
    padding:0
  }.footer-banner-container-integrated {
    padding:0
  }.footer-banner-absolute {
    padding:0
  }.footer-banner-container-absolute {
    padding:10px 0
  }.footer-main .container .row {
    flex-direction:column !important
  }.footer-widget.footer-about,
  .footer-widget.footer-about[style*="padding-right"],
  .footer-widget[style*="padding-right:70px"] {
    padding-right:15px !important;
    padding-left:15px !important;
    margin-left:0 !important;
    margin-bottom:30px !important
  }.footer-widget:last-child,
  .footer-widget[style*="padding-left:70px"],
  .footer-widget[style*="margin-right:-30px"] {
    padding-left:15px !important;
    padding-right:15px !important;
    margin-right:0 !important;
    margin-top:0 !important
  }.footer-widget .row>div[style*="gap:40px"],
  .footer-widget>div[style*="gap:40px"] {
    flex-direction:column !important;
    gap:20px !important;
    align-items:flex-start !important
  }.footer-widget .row>div[style*="gap:40px"]>div,
  .footer-widget>div[style*="gap:40px"]>div {
    width:100% !important;
    flex:1 1 100% !important
  }.working-hours .hours-row {
    flex-wrap:wrap !important
  }.working-hours .hours-row .text-right,
  .working-hours .hours-row span[style*="min-width:95px"] {
    min-width:auto !important;
    width:100% !important;
    margin-top:8px !important;
    text-align:left !important
  }.footer-social-elegant {
    flex-wrap:wrap !important;
    justify-content:center !important
  }.footer-main {
    padding:30px 0 20px !important
  }
}
@media (max-width:768px) {
  .footer-image-section {
    margin-top:20px
  }
}
@media (max-width:480px) {
  .footer-image-section {
    margin-top:15px
  }.footer-widget {
    padding-left:15px !important;
    padding-right:15px !important;
    margin-left:0 !important;
    margin-right:0 !important
  }.widget-title {
    font-size:13px !important;
    margin-bottom:15px !important
  }.footer-contact ul li,
  .list-arrow li {
    padding:8px 0 !important
  }.working-hours {
    gap:12px !important
  }.footer-main {
    padding:25px 0 15px !important
  }
}
.copyright {
  background:#000000;
  color:#ffffff;
  padding:4px 0;
  position:relative;
  z-index:1;
  font-weight:600;
  font-size:12px;
  text-align:center;
  animation:none;
  overflow:hidden;
  border-top:2px solid rgba(255,
  255,
  255,
  0.2);
  border-bottom:2px solid rgba(0,
  0,
  0,
  0.1)
}
.footer-menu ul {
  list-style:none;
  margin:0;
  padding:0
}
.footer-menu ul li {
  display:inline-block;
  line-height:12px;
  padding-left:15px
}
.footer-menu ul li a {
  background:none;
  color:#111;
  padding:0;
  text-decoration:none;
  transition:color 0.3s ease
}
.footer-menu ul li a:hover {
  color:#fff
}
.ts-intro {
  margin-bottom:60px
}
.into-title {
  font-size:18px;
  line-height:28px;
  margin:0;
  text-transform:uppercase;
  font-weight:300
}
.into-sub-title {
  font-weight:900;
  font-size:36px;
  line-height:46px;
  margin:0 0 40px;
  color:#212121
}
.ts-features {
  padding:80px 0;
  background:linear-gradient(135deg,
  #f8f9fa 0%,
  #e9ecef 100%);
  background-image:linear-gradient( 45deg,
  transparent 49%,
  rgba(44,
  62,
  80,
  0.02) 50%,
  transparent 51% ),
  linear-gradient( -45deg,
  transparent 49%,
  rgba(52,
  73,
  94,
  0.01) 50%,
  transparent 51% );
  background-size:60px 60px,
  60px 60px;
  position:relative
}
.ts-features::before {
  display:none
}
.ts-features .ts-service-box {
  background:white;
  border:2px solid #dee2e6;
  border-radius:8px;
  padding:30px;
  margin-bottom:40px;
  transition:all 0.3s ease;
  position:relative;
  overflow:hidden;
  box-shadow:0 4px 15px rgba(44,
  62,
  80,
  0.08)
}
.ts-features .ts-service-box::before {
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:4px;
  background:linear-gradient(90deg,
  #ff6b35,
  #f39c12)
}
.ts-features .ts-service-box:hover {
  transform:translateY(-5px);
  box-shadow:0 15px 35px rgba(44,
  62,
  80,
  0.15);
  border-color:#ff6b35
}
.ts-features .ts-service-icon i {
  font-size:32px;
  color:#ff6b35;
  transition:transform 0.3s ease;
  text-shadow:0 2px 4px rgba(0,
  0,
  0,
  0.1)
}
.ts-features .ts-service-box:hover .ts-service-icon i {
  transform:scale(1.1)
}
.ts-features .into-title {
  color:#373f3f;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:1px;
  font-size:18px;
  margin-bottom:15px
}
.ts-features .into-sub-title {
  color:#373f3f;
  font-weight:800;
  font-size:42px;
  line-height:1.2;
  margin-bottom:30px;
  text-transform:uppercase;
  letter-spacing:-0.5px;
  text-shadow:0 2px 4px rgba(0,
  0,
  0,
  0.1)
}
.ts-features p {
  color:#34495e;
  font-size:16px;
  line-height:1.7;
  margin-bottom:20px;
  font-weight:400
}
.ts-features {
  padding:100px 0 !important;
  background:linear-gradient(135deg,
  #f8f9fa 0%,
  #e9ecef 100%) !important;
  background-image:linear-gradient( 45deg,
  transparent 49%,
  rgba(44,
  62,
  80,
  0.03) 50%,
  transparent 51% ),
  linear-gradient( -45deg,
  transparent 49%,
  rgba(52,
  73,
  94,
  0.02) 50%,
  transparent 51% ) !important;
  background-size:80px 80px,
  80px 80px !important;
  overflow:hidden !important
}
.ts-features::after {
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background-image:linear-gradient( 90deg,
  transparent 48%,
  rgba(44,
  62,
  80,
  0.02) 49%,
  rgba(44,
  62,
  80,
  0.02) 51%,
  transparent 52% ),
  linear-gradient( 0deg,
  transparent 48%,
  rgba(44,
  62,
  80,
  0.02) 49%,
  rgba(44,
  62,
  80,
  0.02) 51%,
  transparent 52% );
  background-size:40px 40px;
  pointer-events:none;
  opacity:0.3
}
.ts-features .ts-service-box {
  background:linear-gradient(135deg,
  #ffffff 0%,
  #f8f9fa 100%) !important;
  border:3px solid #dee2e6 !important;
  border-radius:12px !important;
  padding:40px 30px !important;
  box-shadow:0 8px 25px rgba(44,
  62,
  80,
  0.1),
  inset 0 1px 0 rgba(255,
  255,
  255,
  0.8),
  inset 0 -1px 0 rgba(0,
  0,
  0,
  0.05) !important;
  transition:all 0.4s cubic-bezier(0.4,
  0,
  0.2,
  1) !important
}
.ts-features .ts-service-box::before {
  height:5px !important;
  border-radius:12px 12px 0 0 !important
}
.ts-features .ts-service-box::after {
  content:"";
  position:absolute;
  top:8px;
  left:8px;
  right:8px;
  bottom:8px;
  border:1px solid rgba(255,
  107,
  53,
  0.1);
  border-radius:8px;
  pointer-events:none
}
.ts-features .ts-service-box:hover {
  transform:translateY(-8px) scale(1.02) !important;
  box-shadow:0 20px 50px rgba(44,
  62,
  80,
  0.2),
  0 0 0 1px rgba(255,
  107,
  53,
  0.3),
  inset 0 1px 0 rgba(255,
  255,
  255,
  0.9),
  inset 0 -1px 0 rgba(0,
  0,
  0,
  0.1) !important
}
.ts-features .ts-service-icon i {
  font-size:36px !important;
  text-shadow:0 2px 4px rgba(0,
  0,
  0,
  0.2),
  0 0 8px rgba(255,
  107,
  53,
  0.3),
  inset 0 1px 0 rgba(255,
  255,
  255,
  0.3) !important;
  filter:drop-shadow(0 2px 4px rgba(0,
  0,
  0,
  0.1)) !important;
  transition:all 0.4s cubic-bezier(0.4,
  0,
  0.2,
  1) !important
}
.ts-features .ts-service-box:hover .ts-service-icon i {
  transform:scale(1.15) rotate(5deg) !important;
  color:#f39c12 !important;
  text-shadow:0 4px 8px rgba(0,
  0,
  0,
  0.3),
  0 0 15px rgba(255,
  107,
  53,
  0.5),
  inset 0 1px 0 rgba(255,
  255,
  255,
  0.4) !important;
  filter:drop-shadow(0 4px 8px rgba(0,
  0,
  0,
  0.2)) !important
}
.ts-features .into-title {
  color:#373f3f !important;
  font-weight:700 !important;
  text-transform:uppercase !important;
  letter-spacing:2px !important;
  font-size:20px !important;
  margin-bottom:20px !important;
  text-shadow:0 2px 4px rgba(0,
  0,
  0,
  0.1),
  0 0 8px rgba(44,
  62,
  80,
  0.2) !important;
  position:relative
}
.ts-features .into-title::after {
  display:none
}
.ts-features .into-sub-title {
  color:#373f3f !important;
  font-weight:900 !important;
  font-size:48px !important;
  line-height:1.1 !important;
  margin-bottom:40px !important;
  text-transform:uppercase !important;
  letter-spacing:-1px !important;
  text-shadow:0 3px 6px rgba(0,
  0,
  0,
  0.15),
  0 0 12px rgba(44,
  62,
  80,
  0.3),
  inset 0 1px 0 rgba(255,
  255,
  255,
  0.2) !important;
  position:relative;
  background:linear-gradient(135deg,
  #373f3f 0%,
  #34495e 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text
}
.ts-features p {
  color:#34495e !important;
  font-size:17px !important;
  line-height:1.8 !important;
  margin-bottom:25px !important;
  font-weight:500 !important;
  text-shadow:0 1px 2px rgba(0,
  0,
  0,
  0.05) !important
}
.ts-features {
  position:relative;
  background:#fff;
  background-image:linear-gradient( 45deg,
  transparent 49%,
  rgba(44,
  62,
  80,
  0.03) 50%,
  transparent 51% ),
  linear-gradient( -45deg,
  transparent 49%,
  rgba(52,
  73,
  94,
  0.02) 50%,
  transparent 51% );
  background-size:80px 80px,
  80px 80px
}
.ts-features::before {
  display:none
}
.ts-features .ts-intro {
  position:relative;
  z-index:2
}
.ts-features .ts-intro::before {
  display:none
}
.ts-features .container {
  position:relative;
  z-index:2
}
.ts-features .row {
  position:relative
}
.ts-features .row::before {
  content:"";
  position:absolute;
  top:50%;
  left:0;
  right:0;
  height:1px;
  background:linear-gradient( 90deg,
  transparent,
  rgba(44,
  62,
  80,
  0.1),
  transparent );
  z-index:1
}
.ts-features .ts-service-box {
  animation:fadeInUp 0.6s ease-out forwards;
  opacity:0;
  transform:translateY(30px)
}
.ts-features .ts-service-box:nth-child(1) {
  animation-delay:0.1s
}
.ts-features .ts-service-box:nth-child(2) {
  animation-delay:0.2s
}
.ts-features .ts-service-box:nth-child(3) {
  animation-delay:0.3s
}
.ts-features .ts-service-box:nth-child(4) {
  animation-delay:0.4s
}
@keyframes fadeInUp {
  to {
    opacity:1;
    transform:translateY(0)
  }
}
.ts-features .ts-service-box::before {
  height:5px !important;
  border-radius:12px 12px 0 0 !important;
  box-shadow:0 2px 4px rgba(255,
  107,
  53,
  0.2),
  inset 0 1px 0 rgba(255,
  255,
  255,
  0.3) !important
}
.ts-features .ts-service-box {
  cursor:pointer;
  transform-origin:center bottom
}
.ts-features .ts-service-box:active {
  transform:translateY(-4px) scale(1.01) !important;
  transition:all 0.1s ease !important
}
.ts-features .ts-service-icon {
  position:relative
}
.ts-features .ts-service-icon::after {
  content:"";
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,
  -50%);
  width:40px;
  height:40px;
  border:2px solid rgba(255,
  107,
  53,
  0.1);
  border-top:2px solid #ff6b35;
  border-radius:50%;
  opacity:0;
  transition:opacity 0.3s ease
}
.ts-features .ts-service-box:hover .ts-service-icon::after {
  opacity:1;
  animation:spin 1s linear infinite
}
.ts-features p {
  text-align:justify;
  hyphens:auto;
  word-spacing:0.1em
}
.ts-features .into-sub-title::before {
  content:"⚡";
  position:absolute;
  left:-40px;
  top:50%;
  transform:translateY(-50%);
  font-size:24px;
  opacity:0.6;
  animation:pulse 2s ease-in-out infinite
}
@keyframes pulse {
  0%,
  100% {
    opacity:0.6;
    transform:translateY(-50%) scale(1)
  }50% {
    opacity:1;
    transform:translateY(-50%) scale(1.1)
  }
}
.ts-features .ts-service-box {
  position:relative
}
.ts-features .ts-service-box::after {
  content:"";
  position:absolute;
  top:15px;
  right:15px;
  width:8px;
  height:8px;
  background:#28a745;
  border-radius:50%;
  opacity:0;
  transition:all 0.3s ease;
  box-shadow:0 0 8px rgba(40,
  167,
  69,
  0.5)
}
.ts-features .ts-service-box:hover::after {
  opacity:1;
  transform:scale(1.2)
}
.ts-features .ts-service-box:hover .service-box-title {
  color:#ff6b35 !important;
  transform:translateY(-2px);
  transition:all 0.3s ease
}
.ts-features .ts-intro {
  animation:slideInDown 0.8s ease-out
}
@keyframes slideInDown {
  from {
    opacity:0;
    transform:translateY(-30px)
  }to {
    opacity:1;
    transform:translateY(0)
  }
}
#userway-widget,
[data-userway],
.userway-widget-button,
div[class*="userway"],
iframe[src*="userway"],
button[class*="userway"],
a[class*="userway"],
.userway-accessibility-widget,
.userway-accessibility-button,
.userway-accessibility-icon,
.userway-accessibility-toggle {
  position:fixed !important;
  bottom:25px !important;
  left:25px !important;
  z-index:9999 !important
}
.ts-features .ts-service-box:focus {
  outline:3px solid rgba(255,
  107,
  53,
  0.5);
  outline-offset:2px
}
.ts-features .ts-service-box:focus-visible {
  outline:3px solid #ff6b35;
  outline-offset:2px
}
@media (max-width:768px) {
  .ts-features {
    padding:60px 0 !important
  }.ts-features .into-sub-title {
    font-size:36px !important;
    line-height:1.2 !important
  }.ts-features .ts-service-box {
    padding:30px 20px !important;
    margin-bottom:30px
  }.ts-features .ts-service-icon i {
    font-size:28px !important
  }.ts-features .service-box-title {
    font-size:15px !important
  }
}
@media (max-width:480px) {
  .ts-features .into-sub-title {
    font-size:28px !important
  }.ts-features .ts-service-box {
    padding:25px 15px !important
  }
}
.ts-features .service-box-title {
  color:#373f3f !important;
  font-weight:800 !important;
  text-transform:uppercase !important;
  letter-spacing:1px !important;
  font-size:17px !important;
  margin:0 !important;
  text-shadow:0 2px 4px rgba(0,
  0,
  0,
  0.1),
  0 0 6px rgba(44,
  62,
  80,
  0.2) !important
}
.construction-timeline {
  display:flex;
  justify-content:space-between;
  align-items:center;
  position:relative;
  padding:60px 0;
  margin:40px 0;
  background:white;
  background-image:linear-gradient( 45deg,
  transparent 49%,
  rgba(0,
  0,
  0,
  0.02) 50%,
  transparent 51% ),
  linear-gradient( -45deg,
  transparent 49%,
  rgba(0,
  0,
  0,
  0.01) 50%,
  transparent 51% );
  background-size:20px 20px,
  20px 20px
}
.construction-timeline::before {
  content:"";
  position:absolute;
  top:50%;
  left:0;
  right:0;
  height:4px;
  background:linear-gradient(90deg,
  #ff6b35 0%,
  #f39c12 100%);
  border-radius:2px;
  z-index:1
}
.timeline-item {
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  position:relative;
  z-index:3;
  background:white;
  border:1px solid #e0e0e0;
  border-radius:50%;
  width:100px;
  height:100px;
  padding:15px;
  box-shadow:0 4px 12px rgba(0,
  0,
  0,
  0.1);
  transition:all 0.3s ease;
  cursor:pointer
}
.timeline-item:hover {
  transform:translateY(-4px);
  box-shadow:0 8px 20px rgba(0,
  0,
  0,
  0.15)
}
.timeline-icon {
  margin-bottom:0
}
.timeline-icon i {
  font-size:24px;
  color:#ff6b35;
  transition:all 0.3s ease
}
.timeline-item:hover .timeline-icon i {
  transform:scale(1.1)
}
.timeline-content {
  text-align:center;
  position:absolute;
  top:120px;
  left:50%;
  transform:translateX(-50%);
  width:180px;
  background:white;
  padding:12px;
  border-radius:6px;
  box-shadow:0 4px 12px rgba(0,
  0,
  0,
  0.1);
  border:1px solid #e0e0e0;
  opacity:0;
  transform:translateX(-50%) translateY(-10px);
  transition:all 0.3s ease;
  pointer-events:none
}
.timeline-item:hover .timeline-content {
  opacity:1;
  transform:translateX(-50%) translateY(0)
}
.timeline-content h4 {
  color:#333;
  font-weight:600;
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:0.5px;
  margin:0 0 6px 0
}
.timeline-content p {
  color:#666;
  font-size:11px;
  line-height:1.4;
  margin:0;
  font-weight:400
}
.timeline-connector {
  display:none
}
.timeline-item::after {
  display:none
}
@media (max-width:768px) {
  .construction-timeline {
    flex-direction:column;
    gap:30px;
    padding:40px 0
  }.construction-timeline::before {
    top:0;
    bottom:0;
    left:50%;
    width:3px;
    height:auto;
    transform:translateX(-50%);
    background:linear-gradient(180deg,
    #ff6b35 0%,
    #f39c12 100%)
  }.timeline-item {
    width:80px;
    height:80px;
    padding:12px
  }.timeline-icon i {
    font-size:20px
  }.timeline-content {
    width:160px;
    top:100px
  }
}
@media (max-width:480px) {
  .timeline-item {
    width:70px;
    height:70px;
    padding:10px
  }.timeline-icon i {
    font-size:18px
  }.timeline-content {
    width:140px;
    top:90px;
    padding:10px
  }.timeline-content h4 {
    font-size:12px
  }.timeline-content p {
    font-size:10px
  }
}
.ts-features .into-title {
  color:#373f3f !important;
  font-weight:700 !important;
  text-transform:uppercase !important;
  letter-spacing:2px !important;
  font-size:20px !important;
  margin-bottom:20px !important;
  text-shadow:0 2px 4px rgba(0,
  0,
  0,
  0.1),
  0 0 8px rgba(44,
  62,
  80,
  0.2) !important;
  position:relative
}
.ts-features .into-title::after {
  display:none
}
.ts-features .into-sub-title {
  color:#373f3f !important;
  font-weight:900 !important;
  font-size:48px !important;
  line-height:1.1 !important;
  margin-bottom:40px !important;
  text-transform:uppercase !important;
  letter-spacing:-1px !important;
  text-shadow:0 3px 6px rgba(0,
  0,
  0,
  0.15),
  0 0 12px rgba(44,
  62,
  80,
  0.3),
  inset 0 1px 0 rgba(255,
  255,
  255,
  0.2) !important;
  position:relative;
  background:linear-gradient(135deg,
  #373f3f 0%,
  #34495e 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text
}
.ts-features p {
  color:#34495e !important;
  font-size:17px !important;
  line-height:1.8 !important;
  margin-bottom:25px !important;
  font-weight:500 !important;
  text-shadow:0 1px 2px rgba(0,
  0,
  0,
  0.05) !important
}
.ts-features .service-box-title {
  color:#373f3f !important;
  font-weight:800 !important;
  text-transform:uppercase !important;
  letter-spacing:1px !important;
  font-size:17px !important;
  margin:0 !important;
  text-shadow:0 2px 4px rgba(0,
  0,
  0,
  0.1),
  0 0 6px rgba(44,
  62,
  80,
  0.2) !important
}
.ts-service-box-bg .service-photo-container {
  margin-bottom:20px !important;
  width:100% !important;
  height:200px !important;
  border-radius:8px !important;
  overflow:visible !important;
  background:#fff !important;
  border:3px solid #ff0000 !important;
  display:block !important;
  position:relative !important;
  z-index:10 !important;
  box-shadow:0 4px 8px rgba(0,
  0,
  0,
  0.1) !important;
  min-height:200px !important
}
.ts-service-box-bg .service-photo-container img {
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  border-radius:6px !important;
  display:block !important;
  position:relative !important;
  z-index:5 !important;
  background:#f0f0f0 !important
}
.ts-service-area {
  padding:70px 0
}
.project-area {
  padding:70px 0
}
.project-category {
  background:white;
  padding:30px;
  border-radius:10px;
  box-shadow:0 5px 15px rgba(0,
  0,
  0,
  0.08);
  height:100%;
  transition:all 0.3s ease
}
.project-category:hover {
  transform:translateY(-5px);
  box-shadow:0 15px 35px rgba(0,
  0,
  0,
  0.15)
}
.project-category h3 {
  color:var(--accent-orange);
  margin-bottom:20px;
  font-size:1.3rem
}
.project-list {
  list-style:none;
  padding:0;
  margin:0
}
.project-list li {
  padding:10px 0;
  padding-left:20px;
  position:relative;
  border-bottom:1px solid #f0f0f0
}
.project-list li:last-child {
  border-bottom:none
}
.project-list li:before {
  content:"▸";
  position:absolute;
  left:0;
  color:var(--accent-orange);
  font-weight:bold
}
.projects-carousel {
  position:relative;
  background:#2f2f2f;
  border-radius:32px;
  box-shadow:0 28px 60px rgba(15,
  8,
  5,
  0.55);
  padding:3.75rem 4rem 4.75rem;
  overflow:hidden;
  min-height:420px;
  border:1px solid rgba(255,
  177,
  66,
  0.08)
}
.projects-carousel::after {
  display:none
}
.project-carousel-track {
  position:relative;
  min-height:300px
}
.project-carousel-slide {
  position:absolute;
  inset:0;
  opacity:0;
  visibility:hidden;
  transform:translateX(40px);
  transition:opacity 0.6s ease,
  transform 0.6s ease;
  display:flex;
  flex-direction:column;
  gap:2.2rem;
  pointer-events:none;
  padding:0 1rem
}
.project-carousel-slide.active {
  position:relative;
  opacity:1;
  visibility:visible;
  transform:translateX(0);
  pointer-events:auto
}
.project-carousel-header {
  display:flex;
  align-items:center;
  gap:1rem
}
.project-carousel-header::before {
  content:"";
  width:56px;
  height:3px;
  border-radius:999px;
  background:var(--accent-orange)
}
.project-carousel-title {
  text-transform:uppercase;
  letter-spacing:1px;
  font-size:1.9rem;
  font-weight:800;
  color:#f7ecdf;
  margin:0;
  text-shadow:0 6px 18px rgba(0,
  0,
  0,
  0.45)
}
.project-carousel-title span {
  color:var(--accent-orange)
}
.project-carousel-list {
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:1.35rem
}
.project-carousel-list li {
  position:relative;
  padding-left:2.4rem
}
.project-carousel-list li::before {
  content:"";
  position:absolute;
  left:0;
  top:0.6rem;
  width:14px;
  height:14px;
  border-radius:50%;
  background:var(--accent-orange);
  box-shadow:0 0 0 6px rgba(255,
  165,
  2,
  0.25)
}
.project-carousel-list li strong {
  display:block;
  font-size:1.24rem;
  font-weight:700;
  color:#f4eadf;
  letter-spacing:0.35px;
  text-shadow:0 4px 14px rgba(0,
  0,
  0,
  0.35)
}
.project-carousel-list li span {
  display:block;
  margin-top:0.45rem;
  color:#d6c5b5;
  font-size:1.03rem;
  line-height:1.55
}
.sr-only {
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,
  0,
  0,
  0);
  border:0
}
.project-carousel-control {
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:58px;
  height:58px;
  border-radius:50%;
  border:1px solid rgba(255,
  189,
  86,
  0.35);
  background:radial-gradient( circle at 40% 40%,
  rgba(255,
  222,
  173,
  0.95) 0%,
  rgba(255,
  171,
  47,
  0.85) 55%,
  rgba(112,
  61,
  16,
  0.9) 100% );
  color:#321807;
  display:none !important;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  z-index:5;
  transition:background 0.3s ease,
  transform 0.3s ease,
  color 0.3s ease,
  box-shadow 0.3s ease;
  box-shadow:0 18px 32px rgba(12,
  7,
  4,
  0.28)
}
.project-carousel-control .control-icon {
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  height:100%
}
.project-carousel-control i {
  font-size:1.1rem
}
.project-carousel-control.prev {
  left:0.75rem
}
.project-carousel-control.next {
  right:4rem
}
.project-carousel-control:hover,
.project-carousel-control:focus {
  background:radial-gradient( circle at 40% 40%,
  rgba(255,
  233,
  191,
  1) 0%,
  rgba(255,
  179,
  55,
  0.92) 60%,
  rgba(142,
  73,
  24,
  0.92) 100% );
  color:#200f05;
  outline:none;
  transform:translateY(-50%) scale(1.08);
  box-shadow:0 24px 40px rgba(255,
  165,
  2,
  0.32)
}
.project-carousel-control:focus-visible {
  outline:2px solid rgba(255,
  189,
  86,
  0.45);
  outline-offset:4px
}
.projects-hero {
  position:relative;
  min-height:360px;
  display:flex;
  align-items:center;
  background-image:url("/Erga2.png");
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
  padding:140px 0 100px;
  overflow:hidden;
  margin-top:70px;
  min-height:65vh
}
.projects-hero::before {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient( 135deg,
  rgba(15,
  8,
  5,
  0.4) 0%,
  rgba(15,
  8,
  5,
  0.3) 50%,
  rgba(15,
  7,
  5,
  0.5) 100% );
  z-index:0
}
.projects-hero .hero-overlay {
  position:absolute;
  inset:0;
  background:radial-gradient( circle at 30% 30%,
  rgba(255,
  184,
  86,
  0.18),
  transparent 55% ),
  radial-gradient( circle at 70% 70%,
  rgba(255,
  180,
  40,
  0.12),
  transparent 60% );
  z-index:1
}
.projects-hero .container {
  position:relative;
  z-index:2
}
.projects-showcase {
  background:radial-gradient( circle at top left,
  rgba(54,
  36,
  24,
  0.12),
  transparent 55% ),
  linear-gradient(180deg,
  #f6f3ee 0%,
  #f5f2ee 40%,
  #f2efeb 100%);
  padding:90px 0 110px
}
.projects-showcase-card {
  position:relative;
  background:#2f2f2f;
  border-radius:34px;
  box-shadow:0 24px 70px rgba(12,
  7,
  4,
  0.32);
  padding:3.75rem 4.25rem;
  overflow:hidden;
  border:1px solid rgba(255,
  189,
  86,
  0.08)
}
.projects-showcase-card::after {
  display:none
}
.projects-stack {
  position:relative;
  z-index:2;
  display:flex;
  flex-direction:column;
  gap:2.75rem
}
.projects-panel {
  --panel-primary:255,
  179,
  71;
  --panel-secondary:253,
  126,
  20;
  position:relative;
  background:linear-gradient( 135deg,
  rgba(26,
  16,
  11,
  0.96) 0%,
  rgba(12,
  7,
  5,
  0.98) 65%,
  rgba(7,
  4,
  3,
  1) 100% );
  border-radius:28px;
  padding:2.8rem 2.9rem;
  box-shadow:0 22px 50px rgba(7,
  4,
  3,
  0.38);
  border:1px solid rgba(255,
  189,
  86,
  0.1);
  overflow:hidden;
  transition:transform 0.35s ease,
  box-shadow 0.35s ease
}
.projects-panel::before {
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient( circle at 18% 20%,
  rgba(var(--panel-primary),
  0.22),
  transparent 58% ),
  radial-gradient( circle at 80% 78%,
  rgba(var(--panel-secondary),
  0.16),
  transparent 60% );
  pointer-events:none;
  z-index:0
}
.projects-panel:hover {
  transform:translateY(-16px);
  box-shadow:0 30px 60px rgba(15,
  8,
  5,
  0.45)
}
.panel-header {
  position:relative;
  z-index:2;
  display:flex;
  align-items:center;
  gap:1.4rem;
  margin-bottom:1.85rem
}
.panel-icon {
  width:66px;
  height:66px;
  border-radius:20px;
  background:linear-gradient( 135deg,
  rgba(var(--panel-primary),
  0.95),
  rgba(var(--panel-secondary),
  0.95) );
  display:flex;
  align-items:center;
  justify-content:center;
  color:#1f120a;
  font-size:1.9rem;
  box-shadow:0 18px 30px rgba(var(--panel-secondary),
  0.35)
}
.panel-heading-text {
  display:flex;
  flex-direction:column;
  gap:0.35rem
}
.panel-kicker {
  font-size:0.75rem;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(var(--panel-primary),
  0.75)
}
.panel-title {
  font-size:1.85rem;
  font-weight:700;
  color:#f7e5cf;
  text-transform:uppercase;
  letter-spacing:1.2px;
  margin:0;
  text-shadow:0 14px 30px rgba(0,
  0,
  0,
  0.35)
}
.panel-list {
  position:relative;
  z-index:2;
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  grid-template-columns:repeat(2,
  1fr);
  gap:1.4rem 2rem;
  column-gap:2rem
}
.panel-list li {
  position:relative;
  padding-left:2.5rem;
  break-inside:avoid
}
.panel-list li::before {
  content:"";
  position:absolute;
  left:0;
  top:0.45rem;
  width:15px;
  height:15px;
  border-radius:50%;
  background:radial-gradient( circle at 40% 40%,
  rgba(var(--panel-primary),
  0.92),
  rgba(var(--panel-secondary),
  0.95) );
  box-shadow:0 0 0 7px rgba(var(--panel-primary),
  0.22)
}
.panel-list li strong {
  display:block;
  font-size:1.18rem;
  font-weight:700;
  color:#f3ddc4;
  letter-spacing:0.3px
}
.panel-list li span {
  display:block;
  margin-top:0.35rem;
  color:rgba(236,
  220,
  200,
  0.76);
  font-size:1rem;
  line-height:1.6
}
.projects-panel.health {
  --panel-primary:109,
  213,
  237;
  --panel-secondary:33,
  147,
  176
}
.projects-panel.industry {
  --panel-primary:249,
  197,
  49;
  --panel-secondary:232,
  65,
  24
}
.projects-panel.renewables {
  --panel-primary:155,
  225,
  93;
  --panel-secondary:0,
  158,
  89
}
.projects-panel.networks {
  --panel-primary:116,
  212,
  255;
  --panel-secondary:58,
  123,
  213
}
.projects-panel.international {
  --panel-primary:196,
  113,
  237;
  --panel-secondary:246,
  79,
  89
}
.projects-panel.public {
  --panel-primary:255,
  193,
  7;
  --panel-secondary:255,
  152,
  0
}
.projects-panel.maintenance {
  --panel-primary:158,
  158,
  158;
  --panel-secondary:97,
  97,
  97
}
@media (max-width:1200px) {
  .projects-showcase-card {
    padding:3.5rem 3.25rem
  }.projects-stack {
    gap:2.3rem
  }
}
@media (max-width:992px) {
  .projects-hero {
    padding:110px 0 80px
  }.projects-showcase-card {
    padding:3rem 2.5rem
  }.projects-panel {
    padding:2.4rem 2.35rem
  }.panel-list {
    grid-template-columns:1fr;
    gap:1.4rem
  }.panel-title {
    font-size:1.65rem
  }
}
@media (max-width:768px) {
  .projects-hero {
    min-height:320px
  }.projects-showcase-card {
    padding:2.6rem 1.9rem
  }.projects-panel {
    padding:2.2rem 1.9rem
  }.panel-list {
    grid-template-columns:1fr;
    gap:1.2rem
  }.panel-icon {
    width:58px;
    height:58px;
    font-size:1.6rem
  }.panel-title {
    font-size:1.55rem
  }
}
@media (max-width:576px) {
  .projects-hero {
    padding:100px 0 70px
  }.projects-showcase {
    padding:70px 0 90px
  }.projects-panel {
    padding:2rem 1.6rem
  }.panel-icon {
    width:52px;
    height:52px;
    font-size:1.45rem
  }
}
.project-carousel-indicators {
  position:absolute;
  bottom:32px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  gap:0.8rem;
  z-index:5
}
.project-carousel-indicators::before {
  content:"";
  position:absolute;
  inset:-14px -20px;
  background:#000000;
  border-radius:999px;
  filter:blur(1px);
  z-index:-1
}
.carousel-dot {
  width:13px;
  height:13px;
  border-radius:50%;
  border:none;
  background:rgba(255,
  165,
  2,
  0.35);
  cursor:pointer;
  transition:background 0.3s ease,
  transform 0.3s ease,
  box-shadow 0.3s ease
}
.carousel-dot:hover,
.carousel-dot:focus {
  background:var(--accent-orange);
  transform:scale(1.1);
  outline:none;
  box-shadow:0 0 0 6px rgba(255,
  165,
  2,
  0.28)
}
.carousel-dot.active {
  background:var(--accent-orange);
  box-shadow:0 0 0 6px rgba(255,
  165,
  2,
  0.22)
}
@media (max-width:1200px) {
  .projects-carousel {
    padding:3.5rem 3.25rem 4.5rem
  }
}
@media (max-width:992px) {
  .projects-carousel {
    padding:3rem 2.5rem 4rem
  }.project-carousel-title {
    font-size:1.65rem
  }
}
@media (max-width:768px) {
  .projects-carousel {
    padding:2.5rem 1.75rem 3.75rem;
    min-height:400px
  }.project-carousel-header::before {
    width:36px
  }.project-carousel-title {
    font-size:1.35rem
  }.project-carousel-list {
    gap:1.2rem
  }.project-carousel-list li strong {
    font-size:1.05rem
  }.project-carousel-list li span {
    font-size:0.95rem
  }.project-carousel-control {
    left:2.5rem;
    right:2.5rem;
    font-size:0.85rem
  }
}
@media (max-width:576px) {
  .projects-carousel {
    padding:2.4rem 1.6rem 3.5rem
  }.project-carousel-control {
    display:none
  }.project-carousel-control.prev,
  .project-carousel-control.next {
    left:1.6rem;
    right:1.6rem
  }.project-carousel-title {
    font-size:1.25rem
  }.project-carousel-list {
    gap:1rem
  }.project-carousel-list li strong {
    font-size:1rem
  }.project-carousel-list li span {
    font-size:0.9rem
  }.project-carousel-indicators {
    bottom:24px
  }
}
.facts-area {
  padding:70px 0
}
.facts-wrapper {
  text-align:center
}
.facts-wrapper .ts-facts {
  color:#fff;
  transition:all 0.4s ease;
  position:relative
}
.ts-facts:hover {
  transform:scale(1.05)
}
.ts-facts .ts-facts-content .ts-facts-num {
  color:#fff;
  font-size:44px;
  margin:30px 0 20px;
  transition:all 0.3s ease;
  font-family:var(--font-secondary);
  font-weight:900
}
.ts-facts:hover .ts-facts-num {
  color:var(--accent-orange) !important
}
.ts-facts .ts-facts-content .ts-facts-title {
  font-size:16px;
  color:var(--accent-orange);
  margin:0;
  text-transform:uppercase;
  font-weight:600
}
.ts-facts .ts-facts-img {
  margin-bottom:20px
}
.scroll-reveal {
  opacity:0;
  transform:translateY(50px);
  transition:all 0.8s ease
}
.scroll-reveal.revealed {
  opacity:1;
  transform:translateY(0)
}
.page-header {
  background:linear-gradient( 135deg,
  var(--metallic-grey) 0%,
  var(--dark-grey) 100% );
  color:white;
  padding:8rem 0 4rem;
  text-align:center;
  margin-top:70px
}
.page-header h1 {
  font-size:2.5rem;
  color:white;
  margin-bottom:1rem
}
.page-header p {
  font-size:1.1rem;
  color:#f0f0f0;
  max-width:600px;
  margin:0 auto
}
.main-container {
  padding:70px 0
}
.ts-service-box-bg {
  background:#373f3f;
  padding:2rem;
  border-radius:10px;
  box-shadow:0 5px 15px rgba(0,
  0,
  0,
  0.08);
  transition:all 0.4s ease;
  position:relative;
  overflow:hidden;
  height:100%
}
.ts-service-box-bg::before {
  content:"";
  position:absolute;
  top:50%;
  left:50%;
  width:0;
  height:0;
  background:rgba(255,
  255,
  255,
  0.1);
  border-radius:50%;
  transform:translate(-50%,
  -50%);
  transition:all 0.4s ease
}
.ts-service-box-bg:hover::before {
  width:300px;
  height:300px
}
.ts-service-box-bg:hover {
  transform:translateY(-10px);
  background:linear-gradient( 135deg,
  var(--primary-grey),
  var(--accent-orange) );
  color:white
}
.ts-service-box-bg:hover .ts-service-icon i {
  transform:scale(1.3) rotate(15deg);
  color:white
}
.ts-service-box-bg:hover h4 {
  color:white
}
.ts-service-box-bg:hover p {
  color:white
}
.ts-service-icon.icon-round {
  display:inline-block;
  width:80px;
  height:80px;
  background:var(--accent-orange);
  border-radius:50%;
  line-height:80px;
  color:white;
  font-size:24px;
  margin-bottom:25px;
  transition:all 0.3s ease
}
.ts-service-box-content {
  text-align:center
}
.ts-service-box-content h4 {
  color:#ffffff;
  margin-bottom:15px;
  font-size:18px
}
.ts-service-box-content p {
  color:#ffffff;
  margin:0
}
.form-group {
  margin-bottom:25px;
  position:relative
}
.form-group label {
  display:block;
  margin-bottom:8px;
  font-weight:600;
  color:#333;
  font-size:14px;
  transition:color 0.3s ease
}
.form-control {
  width:100%;
  box-shadow:none;
  border:1px solid #dadada;
  padding:12px 20px;
  height:50px;
  background:#fff;
  color:#666;
  font-size:14px;
  border-radius:3px;
  transition:all 0.3s ease;
  font-family:var(--font-primary)
}
.form-control:focus {
  box-shadow:none;
  border:1px solid var(--accent-orange);
  outline:none;
  background:#fff;
  color:#333
}
.form-control:focus+label,
.form-group:focus-within label {
  color:var(--accent-orange)
}
.form-control-message {
  height:auto;
  min-height:150px;
  resize:vertical
}
.form-control.error {
  border-color:#ff6b6b !important;
  box-shadow:0 0 10px rgba(255,
  107,
  107,
  0.2) !important;
  animation:shake 0.5s ease-out
}
.form-control.success {
  border-color:#27ae60;
  box-shadow:0 0 10px rgba(39,
  174,
  96,
  0.2)
}
.field-error {
  color:#ff6b6b;
  font-size:12px;
  margin-top:5px;
  animation:fadeInUp 0.3s ease;
  display:block
}
.field-success {
  color:#27ae60;
  font-size:12px;
  margin-top:5px;
  animation:fadeInUp 0.3s ease;
  display:block
}
.error-container {
  margin-bottom:20px
}
.contact-info-box {
  background:white;
  padding:2rem;
  border-radius:10px;
  box-shadow:0 5px 15px rgba(0,
  0,
  0,
  0.08);
  height:100%;
  margin-bottom:2rem
}
.contact-info-box h4 {
  color:var(--accent-orange);
  margin-bottom:1.5rem;
  font-size:1.2rem
}
.contact-info-list {
  list-style:none;
  padding:0;
  margin:0
}
.contact-info-list li {
  padding:0.5rem 0;
  color:var(--primary-grey);
  display:flex;
  align-items:center
}
.contact-info-list li i {
  color:var(--accent-orange);
  margin-right:10px;
  width:16px
}
.map-container {
  transition:all 0.3s ease;
  border-radius:10px;
  overflow:hidden;
  box-shadow:0 5px 15px rgba(0,
  0,
  0,
  0.1)
}
.map-container:hover {
  transform:translateY(-5px);
  box-shadow:0 15px 35px rgba(0,
  0,
  0,
  0.15)
}
.column-title {
  font-size:1.5rem;
  color:var(--primary-grey);
  margin-bottom:2rem;
  text-align:center;
  font-family:var(--font-secondary);
  text-transform:uppercase
}
.btn-secondary {
  background:transparent;
  border:2px solid var(--accent-orange);
  color:var(--accent-orange);
  padding:12px 20px
}
.btn-secondary:hover {
  background:var(--accent-orange);
  color:white;
  border-color:var(--accent-orange)
}
.btn.solid.blank {
  background:var(--accent-orange);
  color:white;
  border:none;
  padding:15px 30px;
  font-size:14px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.5px;
  transition:all 0.3s ease
}
.btn.solid.blank:hover {
  background:#333;
  transform:translateY(-2px);
  box-shadow:0 5px 15px rgba(0,
  0,
  0,
  0.2)
}
.btn:disabled {
  opacity:0.7;
  cursor:not-allowed
}
.btn .loading-spinner {
  margin-right:8px
}
.notification {
  font-family:var(--font-primary);
  font-size:14px;
  border-radius:8px
}
.notification-content {
  display:flex;
  align-items:center;
  gap:10px
}
.notification-icon {
  font-size:16px;
  font-weight:bold;
  flex-shrink:0
}
.notification-message {
  flex:1;
  line-height:1.4
}
.notification-close {
  background:none;
  border:none;
  color:white;
  font-size:20px;
  cursor:pointer;
  margin-left:auto;
  padding:0;
  width:24px;
  height:24px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  transition:background-color 0.2s ease;
  flex-shrink:0
}
.notification-close:hover {
  background-color:rgba(255,
  255,
  255,
  0.2)
}
#contact-form {
  background:white;
  padding:2.5rem;
  border-radius:10px;
  box-shadow:0 5px 15px rgba(0,
  0,
  0,
  0.08);
  margin-top:2rem
}
@keyframes shake {
  0%,
  100% {
    transform:translateX(0)
  }10%,
  30%,
  50%,
  70%,
  90% {
    transform:translateX(-5px)
  }20%,
  40%,
  60%,
  80% {
    transform:translateX(5px)
  }
}
.text-right {
  text-align:right
}
.text-center {
  text-align:center
}
.text-left {
  text-align:left
}
.h-100 {
  height:100%
}
.mb-4 {
  margin-bottom:1.5rem
}
.mt-3 {
  margin-top:1rem
}
.mt-4 {
  margin-top:1.5rem
}
.mt-5 {
  margin-top:3rem
}
.pb-0 {
  padding-bottom:0
}
.bg-overlay {
  position:relative
}
.bg-overlay::before {
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background:rgba(0,
  0,
  0,
  0.05);
  pointer-events:none
}
.location-section {
  background:#2f2f2f;
  padding:80px 0 40px;
  margin-top:80px;
  position:relative;
  overflow:hidden
}
.location-section::before {
  display:none
}
.location-section::after {
  display:none
}
.section-title-dark {
  text-align:center;
  color:white;
  font-size:2.5rem;
  font-weight:800;
  margin-bottom:3rem;
  letter-spacing:2px;
  font-family:var(--font-secondary);
  text-transform:uppercase;
  opacity:0;
  transform:translateY(20px);
  animation:fadeInUp 0.8s ease-out 0.2s forwards;
  position:relative
}
.section-title-dark::after {
  content:"";
  position:absolute;
  bottom:-10px;
  left:50%;
  transform:translateX(-50%);
  width:50px;
  height:2px;
  background:linear-gradient( 90deg,
  rgba(255,
  165,
  2,
  0.6),
  rgba(243,
  156,
  18,
  0.6) );
  border-radius:1px;
  opacity:0.8;
  animation:slideInScale 0.6s ease-out 1s forwards
}
.contact-card-dark {
  background:#1a1a1a;
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,
  165,
  2,
  0.1);
  padding:2.5rem;
  text-align:center;
  border-radius:16px;
  margin-bottom:40px;
  transition:all 0.4s cubic-bezier(0.4,
  0,
  0.2,
  1);
  height:100%;
  position:relative;
  overflow:hidden;
  opacity:0;
  transform:translateY(30px);
  animation:slideInUp 0.6s ease-out forwards;
  box-shadow:0 8px 32px rgba(0,
  0,
  0,
  0.2),
  0 2px 8px rgba(255,
  165,
  2,
  0.1),
  inset 0 1px 0 rgba(255,
  255,
  255,
  0.1)
}
.contact-card-dark:nth-child(1) .contact-card-dark,
.col-lg-4:nth-child(1) .contact-card-dark {
  animation-delay:0.3s
}
.contact-card-dark:nth-child(2) .contact-card-dark,
.col-lg-4:nth-child(2) .contact-card-dark {
  animation-delay:0.5s
}
.contact-card-dark:nth-child(3) .contact-card-dark,
.col-lg-4:nth-child(3) .contact-card-dark {
  animation-delay:0.7s
}
.contact-card-dark::before {
  content:"";
  position:absolute;
  top:0;
  left:-100%;
  width:100%;
  height:100%;
  background:linear-gradient( 90deg,
  transparent,
  rgba(255,
  165,
  2,
  0.05),
  transparent );
  transition:left 0.8s ease;
  z-index:1
}
.contact-card-dark:hover::before {
  left:100%
}
.contact-card-dark::after {
  content:"";
  position:absolute;
  top:50%;
  left:50%;
  width:0;
  height:0;
  background:radial-gradient( circle,
  rgba(255,
  165,
  2,
  0.05) 0%,
  transparent 70% );
  border-radius:50%;
  transform:translate(-50%,
  -50%);
  animation:pulse-glow 3s ease-in-out infinite;
  z-index:1;
  pointer-events:none
}
.contact-card-dark:hover::after {
  animation:pulse-glow 3s ease-in-out infinite
}
.contact-card-dark:hover {
  transform:translateY(-2px);
  background:linear-gradient( 135deg,
  #2a2a2a 0%,
  #3d3d3d 30%,
  #1a1a1a 70%,
  #2a2a2a 100% );
  backdrop-filter:blur(15px);
  border-color:rgba(255,
  165,
  2,
  0.2);
  box-shadow:0 12px 40px rgba(0,
  0,
  0,
  0.5),
  0 6px 20px rgba(0,
  0,
  0,
  0.4),
  inset 0 1px 0 rgba(255,
  255,
  255,
  0.15),
  0 0 0 1px rgba(255,
  165,
  2,
  0.15),
  0 0 30px rgba(255,
  165,
  2,
  0.08)
}
.contact-icon-circle {
  width:80px;
  height:80px;
  background:linear-gradient( 135deg,
  var(--accent-orange),
  var(--accent-yellow) );
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 1.5rem;
  position:relative;
  transition:all 0.4s cubic-bezier(0.4,
  0,
  0.2,
  1);
  box-shadow:0 4px 15px rgba(255,
  165,
  2,
  0.3)
}
.contact-icon-circle::before {
  content:"";
  position:absolute;
  top:-2px;
  left:-2px;
  right:-2px;
  bottom:-2px;
  background:linear-gradient( 135deg,
  var(--accent-orange),
  var(--accent-yellow),
  var(--accent-orange) );
  border-radius:50%;
  z-index:-1;
  opacity:0;
  transition:opacity 0.3s ease
}
.contact-card-dark:hover .contact-icon-circle::before {
  opacity:1
}
.contact-card-dark:hover .contact-icon-circle {
  transform:scale(1.1) rotate(360deg);
  box-shadow:0 8px 25px rgba(255,
  165,
  2,
  0.5)
}
.contact-icon-circle i {
  font-size:2rem;
  color:white;
  transition:all 0.4s cubic-bezier(0.4,
  0,
  0.2,
  1);
  z-index:2;
  position:relative;
  filter:drop-shadow(0 2px 4px rgba(0,
  0,
  0,
  0.2));
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  height:100%;
  font-family:"Font Awesome 6 Free",
  "Font Awesome 6 Pro",
  "Font Awesome 6 Brands",
  "Font Awesome 5 Free",
  "Font Awesome 5 Pro",
  FontAwesome,
  sans-serif;
  font-weight:900
}
.contact-icon-circle i.fas {
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:auto;
  line-height:1
}
.contact-icon-circle i.fa-map-marker-alt::before,
.contact-icon-circle i.fa-location-dot::before {
  content:"\f3c5"
}
.contact-icon-circle i.fa-envelope::before {
  content:"\f0e0"
}
.contact-icon-circle i.fa-phone::before {
  content:"\f095"
}
@supports not (font-family:"Font Awesome 6 Free") {
  .contact-icon-circle i.fas.fa-map-marker-alt::before {
    content:"📍" !important;
    font-family:"Segoe UI Emoji",
    "Apple Color Emoji",
    "Noto Color Emoji",
    sans-serif !important
  }.contact-icon-circle i.fas.fa-envelope::before {
    content:"✉️" !important;
    font-family:"Segoe UI Emoji",
    "Apple Color Emoji",
    "Noto Color Emoji",
    sans-serif !important
  }.contact-icon-circle i.fas.fa-phone::before {
    content:"📞" !important;
    font-family:"Segoe UI Emoji",
    "Apple Color Emoji",
    "Noto Color Emoji",
    sans-serif !important
  }
}
.contact-card-dark:hover .contact-icon-circle i {
  transform:scale(1.15);
  text-shadow:0 4px 12px rgba(0,
  0,
  0,
  0.4);
  filter:drop-shadow(0 4px 8px rgba(255,
  165,
  2,
  0.3))
}
.contact-icon-circle::after {
  content:"";
  position:absolute;
  top:50%;
  left:50%;
  width:120%;
  height:120%;
  border:2px solid rgba(255,
  255,
  255,
  0.3);
  border-radius:50%;
  transform:translate(-50%,
  -50%) scale(0);
  opacity:0;
  transition:all 0.4s ease;
  z-index:0
}
.contact-card-dark:hover .contact-icon-circle::after {
  transform:translate(-50%,
  -50%) scale(1);
  opacity:1
}
.contact-card-dark h4 {
  color:white;
  font-size:1rem;
  font-weight:700;
  text-transform:uppercase;
  margin-bottom:1rem;
  letter-spacing:1px;
  font-family:var(--font-secondary);
  transition:all 0.3s ease;
  position:relative
}
.contact-card-dark:hover h4 {
  color:var(--accent-orange);
  transform:translateY(-2px)
}
.contact-card-dark p,
.contact-card-dark a {
  color:var(--light-grey);
  font-size:0.95rem;
  margin:0;
  transition:all 0.3s ease
}
.contact-card-dark:hover p {
  color:#e2e8f0;
  transform:translateY(-1px)
}
.contact-card-dark a {
  color:var(--accent-orange);
  text-decoration:none;
  transition:all 0.3s ease;
  position:relative;
  display:inline-block
}
.contact-card-dark a::after {
  content:"";
  position:absolute;
  bottom:-2px;
  left:0;
  width:0;
  height:2px;
  background:var(--accent-yellow);
  transition:width 0.3s ease
}
.contact-card-dark a:hover::after {
  width:100%
}
.contact-card-dark a:hover {
  color:var(--accent-yellow);
  transform:translateY(-1px)
}
.map-section {
  background:#2f2f2f;
  padding:0 0 80px 0;
  position:relative;
  margin-top:-1px
}
.map-section::before {
  display:none
}
.map-container-dark {
  height:450px;
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 15px 50px rgba(0,
  0,
  0,
  0.4),
  0 5px 20px rgba(255,
  165,
  2,
  0.1),
  inset 0 1px 0 rgba(255,
  255,
  255,
  0.1);
  opacity:1;
  transform:translateY(0);
  animation:slideInUp 0.8s ease-out 0.9s forwards;
  transition:all 0.4s cubic-bezier(0.4,
  0,
  0.2,
  1);
  border:2px solid rgba(255,
  165,
  2,
  0.2);
  position:relative
}
.map-container-dark iframe {
  width:100%;
  height:100%;
  display:block;
  border:0
}
.map-container-dark::before {
  content:"";
  position:absolute;
  top:-2px;
  left:-2px;
  right:-2px;
  bottom:-2px;
  background:linear-gradient( 45deg,
  rgba(255,
  165,
  2,
  0.3),
  transparent 30%,
  transparent 70%,
  rgba(255,
  165,
  2,
  0.3) );
  border-radius:16px;
  z-index:-1;
  opacity:0;
  transition:opacity 0.4s ease
}
.map-container-dark:hover::before {
  opacity:1
}
.map-container-dark:hover {
  transform:translateY(-8px) scale(1.01);
  box-shadow:0 25px 80px rgba(0,
  0,
  0,
  0.5),
  0 10px 40px rgba(255,
  165,
  2,
  0.2),
  inset 0 1px 0 rgba(255,
  255,
  255,
  0.2);
  border-color:rgba(255,
  165,
  2,
  0.4)
}
.form-section-light {
  background:linear-gradient(135deg,
  #f8f9fa 0%,
  #e9ecef 100%);
  background-image:linear-gradient( 45deg,
  transparent 49%,
  rgba(44,
  62,
  80,
  0.02) 50%,
  transparent 51% ),
  linear-gradient( -45deg,
  transparent 49%,
  rgba(52,
  73,
  94,
  0.01) 50%,
  transparent 51% );
  background-size:60px 60px,
  60px 60px;
  padding:80px 0;
  position:relative;
  overflow:hidden;
  margin-top:-1px
}
.form-section-light::before {
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background:radial-gradient( circle at 20% 30%,
  rgba(255,
  107,
  53,
  0.03) 0%,
  transparent 50% ),
  radial-gradient( circle at 80% 70%,
  rgba(243,
  156,
  18,
  0.02) 0%,
  transparent 50% );
  pointer-events:none
}
@keyframes float {
  0%,
  100% {
    transform:translate(0,
    0) rotate(0deg)
  }33% {
    transform:translate(30px,
    -30px) rotate(120deg)
  }66% {
    transform:translate(-20px,
    20px) rotate(240deg)
  }
}
.decorative-elements {
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  pointer-events:none;
  z-index:1
}
.floating-shape {
  position:absolute;
  border-radius:50%;
  background:rgba(255,
  165,
  2,
  0.1);
  animation:floatShape 15s ease-in-out infinite
}
.shape-1 {
  width:80px;
  height:80px;
  top:10%;
  left:10%;
  animation-delay:0s;
  background:radial-gradient( circle,
  rgba(255,
  165,
  2,
  0.15) 0%,
  transparent 70% )
}
.shape-2 {
  width:120px;
  height:120px;
  top:20%;
  right:15%;
  animation-delay:-5s;
  background:radial-gradient( circle,
  rgba(255,
  165,
  2,
  0.08) 0%,
  transparent 70% )
}
.shape-3 {
  width:60px;
  height:60px;
  bottom:30%;
  left:20%;
  animation-delay:-10s;
  background:radial-gradient( circle,
  rgba(255,
  165,
  2,
  0.12) 0%,
  transparent 70% )
}
.shape-4 {
  width:100px;
  height:100px;
  bottom:15%;
  right:10%;
  animation-delay:-7s;
  background:radial-gradient( circle,
  rgba(255,
  165,
  2,
  0.1) 0%,
  transparent 70% )
}
@keyframes floatShape {
  0%,
  100% {
    transform:translateY(0px) translateX(0px) rotate(0deg);
    opacity:0.3
  }25% {
    transform:translateY(-20px) translateX(10px) rotate(90deg);
    opacity:0.6
  }50% {
    transform:translateY(-10px) translateX(-15px) rotate(180deg);
    opacity:0.4
  }75% {
    transform:translateY(-30px) translateX(5px) rotate(270deg);
    opacity:0.7
  }
}
.form-title-main {
  text-align:center;
  font-size:2.5rem;
  font-weight:800;
  color:#373f3f;
  margin-bottom:3rem;
  letter-spacing:2px;
  font-family:var(--font-secondary);
  text-transform:uppercase;
  opacity:0;
  transform:translateY(20px);
  animation:fadeInUp 0.8s ease-out 0.2s forwards;
  position:relative
}
.form-title-main::after {
  content:"";
  position:absolute;
  bottom:-10px;
  left:50%;
  transform:translateX(-50%);
  width:60px;
  height:3px;
  background:linear-gradient( 90deg,
  var(--accent-orange),
  var(--accent-yellow) );
  border-radius:2px;
  opacity:0;
  animation:slideInScale 0.6s ease-out 1s forwards
}
.form-wrapper {
  background:rgba(255,
  255,
  255,
  0.95);
  backdrop-filter:blur(20px);
  border:1px solid rgba(255,
  165,
  2,
  0.1);
  padding:3rem;
  border-radius:20px;
  box-shadow:0 10px 40px rgba(0,
  0,
  0,
  0.1),
  0 4px 16px rgba(255,
  165,
  2,
  0.05),
  inset 0 1px 0 rgba(255,
  255,
  255,
  0.8);
  opacity:0;
  transform:translateY(30px);
  animation:slideInUp 0.8s ease-out 0.4s forwards;
  transition:all 0.4s cubic-bezier(0.4,
  0,
  0.2,
  1);
  position:relative;
  overflow:hidden
}
.form-wrapper::before {
  content:"";
  position:absolute;
  top:0;
  left:-100%;
  width:100%;
  height:100%;
  background:linear-gradient( 90deg,
  transparent,
  rgba(255,
  165,
  2,
  0.03),
  transparent );
  transition:left 0.8s ease
}
.form-wrapper:hover::before {
  left:100%
}
.form-wrapper:hover {
  box-shadow:0 20px 60px rgba(0,
  0,
  0,
  0.15),
  0 8px 32px rgba(255,
  165,
  2,
  0.1),
  inset 0 1px 0 rgba(255,
  255,
  255,
  0.9);
  transform:translateY(-5px);
  border-color:rgba(255,
  165,
  2,
  0.2)
}
.form-row-custom {
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:1.5rem;
  margin-bottom:1.5rem
}
.form-field {
  position:relative;
  margin-bottom:1.5rem
}
.form-field label {
  display:block;
  font-size:0.9rem;
  font-weight:600;
  color:var(--dark-grey);
  margin-bottom:0.5rem;
  font-family:var(--font-secondary);
  transition:all 0.3s ease;
  text-transform:uppercase;
  letter-spacing:0.5px
}
.form-field:focus-within label {
  color:var(--accent-orange);
  transform:translateY(-2px)
}
.form-input {
  width:100%;
  padding:1.2rem 1.5rem;
  border:2px solid var(--border-grey);
  border-radius:8px;
  font-size:0.95rem;
  transition:all 0.4s cubic-bezier(0.4,
  0,
  0.2,
  1);
  background:var(--light-bg);
  font-family:var(--font-primary);
  position:relative;
  z-index:1
}
.form-input::placeholder {
  color:#a0aec0;
  transition:all 0.3s ease
}
.form-input:focus::placeholder {
  opacity:0.7;
  transform:translateY(-2px)
}
.form-input:focus {
  outline:none;
  border-color:var(--accent-orange);
  background:white;
  box-shadow:0 0 0 4px rgba(255,
  165,
  2,
  0.1),
  0 8px 25px rgba(255,
  165,
  2,
  0.15),
  inset 0 1px 0 rgba(255,
  255,
  255,
  0.8);
  transform:translateY(-3px) scale(1.01)
}
.form-field::after {
  content:"";
  position:absolute;
  bottom:0;
  left:50%;
  width:0;
  height:2px;
  background:linear-gradient( 90deg,
  var(--accent-orange),
  var(--accent-yellow) );
  transform:translateX(-50%);
  transition:width 0.4s ease;
  border-radius:1px
}
.form-field:focus-within::after {
  width:100%
}
.form-textarea {
  width:100%;
  padding:1.5rem;
  border:2px solid var(--border-grey);
  border-radius:8px;
  font-size:0.95rem;
  min-height:180px;
  resize:vertical;
  background:var(--light-bg);
  margin-bottom:1.5rem;
  font-family:var(--font-primary);
  transition:all 0.4s cubic-bezier(0.4,
  0,
  0.2,
  1);
  position:relative;
  z-index:1
}
.form-textarea::placeholder {
  color:#a0aec0;
  transition:all 0.3s ease
}
.form-textarea:focus::placeholder {
  opacity:0.7;
  transform:translateY(-2px)
}
.form-textarea:focus {
  outline:none;
  border-color:var(--accent-orange);
  background:white;
  box-shadow:0 0 0 4px rgba(255,
  165,
  2,
  0.1),
  0 8px 25px rgba(255,
  165,
  2,
  0.15);
  transform:translateY(-2px)
}
.submit-button {
  background:linear-gradient( 135deg,
  var(--accent-orange),
  var(--accent-yellow) );
  color:white;
  border:none;
  padding:1.2rem 3.5rem;
  border-radius:50px;
  font-size:1rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:1.5px;
  cursor:pointer;
  transition:all 0.4s cubic-bezier(0.4,
  0,
  0.2,
  1);
  font-family:var(--font-secondary);
  position:relative;
  overflow:hidden;
  box-shadow:0 4px 15px rgba(255,
  165,
  2,
  0.3);
  min-width:200px
}
.submit-button::before {
  content:"";
  position:absolute;
  top:0;
  left:-100%;
  width:100%;
  height:100%;
  background:linear-gradient( 90deg,
  transparent,
  rgba(255,
  255,
  255,
  0.2),
  transparent );
  transition:left 0.6s ease
}
.submit-button:hover::before {
  left:100%
}
.submit-button:hover {
  background:linear-gradient( 135deg,
  var(--accent-yellow),
  var(--accent-orange) );
  transform:translateY(-3px) scale(1.02);
  box-shadow:0 8px 30px rgba(255,
  165,
  2,
  0.5)
}
.submit-button:active {
  transform:translateY(-1px) scale(0.98);
  box-shadow:0 4px 15px rgba(255,
  165,
  2,
  0.3)
}
.submit-button:disabled {
  opacity:0.7;
  cursor:not-allowed;
  transform:none
}
.submit-button.loading {
  pointer-events:none
}
.submit-button.loading::after {
  content:"";
  position:absolute;
  top:50%;
  left:50%;
  width:20px;
  height:20px;
  margin:-10px 0 0 -10px;
  border:2px solid rgba(255,
  255,
  255,
  0.3);
  border-radius:50%;
  border-top-color:white;
  animation:spin 1s linear infinite
}
.form-input.valid,
.form-textarea.valid {
  border-color:#10b981;
  background:#f0fdf4
}
.form-input.valid:focus,
.form-textarea.valid:focus {
  box-shadow:0 0 0 4px rgba(16,
  185,
  129,
  0.1),
  0 8px 25px rgba(16,
  185,
  129,
  0.15)
}
.form-input.invalid,
.form-textarea.invalid {
  border-color:#ef4444;
  background:#fef2f2;
  animation:shake 0.5s ease-out
}
.form-input.invalid:focus,
.form-textarea.invalid:focus {
  box-shadow:0 0 0 4px rgba(239,
  68,
  68,
  0.1),
  0 8px 25px rgba(239,
  68,
  68,
  0.15)
}
.form-field.valid::after {
  background:#10b981;
  width:100%
}
.form-field.invalid::after {
  background:#ef4444;
  width:100%
}
.form-field .field-icon {
  position:absolute;
  right:15px;
  top:50%;
  transform:translateY(-50%);
  font-size:1.2rem;
  opacity:0;
  transition:all 0.3s ease;
  z-index:2
}
.form-field.valid .field-icon.success {
  color:#10b981;
  opacity:1
}
.form-field.invalid .field-icon.error {
  color:#ef4444;
  opacity:1
}
.error-message {
  color:#ef4444;
  font-size:0.8rem;
  margin-top:0.5rem;
  opacity:0;
  transform:translateY(-10px);
  transition:all 0.3s ease;
  font-family:var(--font-secondary)
}
.error-message.show {
  opacity:1;
  transform:translateY(0)
}
.success-message {
  color:#10b981;
  font-size:0.8rem;
  margin-top:0.5rem;
  opacity:0;
  transform:translateY(-10px);
  transition:all 0.3s ease;
  font-family:var(--font-secondary)
}
.success-message.show {
  opacity:1;
  transform:translateY(0)
}
.form-field {
  opacity:0;
  transform:translateY(20px);
  animation:slideInUp 0.6s ease-out forwards
}
.form-field:nth-child(1) {
  animation-delay:0.1s
}
.form-field:nth-child(2) {
  animation-delay:0.2s
}
.form-field:nth-child(3) {
  animation-delay:0.3s
}
.form-field:nth-child(4) {
  animation-delay:0.4s
}
.submit-button {
  opacity:0;
  transform:translateY(20px);
  animation:slideInUp 0.6s ease-out 0.5s forwards
}
.services-carousel {
  position:relative;
  width:100%;
  max-width:1200px;
  margin:0 auto;
  overflow:hidden;
  border-radius:15px;
  box-shadow:0 10px 30px rgba(0,
  0,
  0,
  0.3);
  background:#2f2f2f
}
.carousel-container {
  position:relative;
  width:100%;
  height:500px;
  overflow:hidden
}
.carousel-slide {
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  opacity:0;
  transition:opacity 0.8s ease-in-out;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  display:flex;
  align-items:center;
  justify-content:flex-start
}
.carousel-slide.active {
  opacity:1
}
.carousel-slide::before {
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background:linear-gradient(45deg,
  rgba(0,
  0,
  0,
  0.4),
  rgba(0,
  0,
  0,
  0.2));
  z-index:1
}
.carousel-content {
  position:relative;
  z-index:2;
  text-align:left;
  color:white;
  padding:40px;
  max-width:600px;
  margin-left:50px
}
.carousel-title {
  font-size:2.5rem;
  font-weight:700;
  margin-bottom:20px;
  color:white;
  text-shadow:2px 2px 4px rgba(0,
  0,
  0,
  0.7);
  text-transform:uppercase;
  letter-spacing:1px
}
.carousel-description {
  font-size:1.2rem;
  line-height:1.8;
  margin-bottom:30px;
  color:#f0f0f0;
  text-shadow:1px 1px 2px rgba(0,
  0,
  0,
  0.7)
}
.carousel-service-icon {
  width:80px;
  height:80px;
  background:var(--accent-orange);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 0 20px 0;
  font-size:2rem;
  color:white;
  box-shadow:0 8px 20px rgba(255,
  165,
  2,
  0.3)
}
.carousel-slide.yde-slide .carousel-service-icon {
  width:60px;
  height:60px;
  font-size:1.5rem
}
.carousel-image-wrapper {
  margin:-40px -40px 20px -40px;
  max-width:calc(100%+80px);
  width:calc(100%+80px);
  border-radius:8px 8px 0 0;
  overflow:hidden;
  position:relative;
  z-index:3;
  display:flex;
  justify-content:center;
  align-items:flex-start;
  padding-top:0
}
.carousel-banner-image {
  width:100%;
  max-width:100%;
  height:auto;
  display:block;
  object-fit:cover;
  border-radius:0;
  position:relative;
  z-index:3
}
@keyframes slideInUp {
  from {
    opacity:0;
    transform:translateY(50px)
  }to {
    opacity:1;
    transform:translateY(0)
  }
}
.carousel-slide.active .carousel-content {
  animation:slideInUp 0.8s ease-out
}
@media (max-width:768px) {
  .carousel-container {
    height:400px
  }.carousel-content {
    padding:30px 20px;
    margin-left:20px;
    max-width:80%
  }.carousel-title {
    font-size:2rem
  }.carousel-description {
    font-size:1rem
  }.carousel-service-icon {
    width:60px;
    height:60px;
    font-size:1.5rem
  }.carousel-banner-image {
    max-width:100%
  }
}
@media (max-width:480px) {
  .carousel-container {
    height:350px
  }.carousel-content {
    padding:20px 15px;
    margin-left:15px;
    max-width:85%
  }.carousel-title {
    font-size:1.5rem
  }.carousel-description {
    font-size:0.9rem
  }.carousel-banner-image {
    max-width:100%
  }
}
@media (max-width:768px) {
  .form-row-custom {
    grid-template-columns:1fr
  }.location-section {
    padding:100px 0 40px
  }.section-title-dark,
  .form-title-main {
    font-size:1.8rem
  }.form-wrapper {
    padding:2rem
  }.contact-card-dark {
    margin-bottom:20px
  }.submit-button {
    padding:1rem 2.5rem;
    font-size:0.9rem
  }
}
@media (max-width:768px) {
  .notification {
    right:10px;
    left:10px;
    max-width:none;
    transform:translateY(-100px)
  }.notification.show {
    transform:translateY(0)
  }
}
.modern-header .main-navigation .nav-menu .nav-item.dropdown:hover .dropdown-menu {
  opacity:1;
  visibility:visible;
  transform:translateY(0);
  display:block
}
.modern-header .main-navigation .nav-menu .dropdown-menu {
  list-style:none
}
.modern-header .main-navigation .nav-menu .dropdown:hover .nav-link i {
  transform:rotate(180deg)
}
.modern-header .main-navigation .dropdown-menu li {
  list-style:none;
  margin:0;
  padding:0
}
.modern-header .main-navigation .dropdown-menu li a {
  text-decoration:none
}
.modern-header .main-navigation .dropdown-menu li a:hover {
  text-decoration:none
}
.container {
  width:100%;
  max-width:1320px;
  margin:0 auto;
  padding:0 15px
}
.row {
  display:flex;
  flex-wrap:wrap;
  margin:0 -15px
}
.sidebar-carousel-container {
  position:relative;
  overflow:hidden;
  background:transparent;
  border-radius:0;
  padding:0;
  margin-bottom:30px;
  box-shadow:none;
  width:100%;
  max-width:none
}
.sidebar-carousel {
  position:relative;
  height:auto;
  width:100%
}
.sidebar-carousel-slide {
  display:none;
  animation:fadeIn 0.5s ease-in-out
}
.sidebar-carousel-slide.active {
  display:block
}
.carousel-image-container {
  width:100%;
  height:100%;
  overflow:hidden;
  border-radius:20px;
  margin-bottom:10px;
  max-width:none
}
.carousel-image {
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:18px;
  transition:transform 0.3s ease;
  max-width:none
}
.carousel-image:hover {
  transform:scale(1.05)
}
.sidebar-carousel-slide {
  display:none;
  animation:fadeIn 0.5s ease-in-out
}
.sidebar-carousel-slide.active {
  display:block
}
@keyframes fadeIn {
  from {
    opacity:0
  }to {
    opacity:1
  }
}
.sidebar-carousel-dots {
  text-align:center;
  margin-top:15px
}
.sidebar-carousel-dots .dot {
  cursor:pointer;
  height:8px;
  width:8px;
  margin:0 4px;
  background-color:#bbb;
  border-radius:50%;
  display:inline-block;
  transition:background-color 0.3s ease
}
.sidebar-carousel-dots .dot.active,
.sidebar-carousel-dots .dot:hover {
  background-color:var(--accent-orange)
}
@media (max-width:768px) {
  .col-md-4 {
    flex:0 0 100%;
    max-width:100%
  }
}
.service-card {
  background:var(--white);
  border-radius:12px;
  padding:2rem;
  box-shadow:var(--shadow-light);
  transition:var(--transition-normal);
  height:100%;
  border:1px solid var(--border-grey)
}
.service-card:hover {
  transform:translateY(-5px);
  box-shadow:var(--shadow-medium);
  border-color:var(--accent-orange)
}
.service-card .service-icon {
  width:80px;
  height:80px;
  background:linear-gradient( 135deg,
  var(--accent-orange),
  var(--accent-yellow) );
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:1.5rem;
  color:white;
  font-size:2rem
}
.service-card h3 {
  color:#373f3f;
  font-size:1.3rem;
  font-weight:600;
  margin-bottom:1rem;
  font-family:var(--font-secondary)
}
.service-card p {
  color:var(--dark-grey);
  line-height:1.6;
  margin-bottom:1.5rem
}
.service-card ul {
  list-style:none;
  padding:0;
  margin:0
}
.service-card ul li {
  display:flex;
  align-items:center;
  margin-bottom:0.5rem;
  color:var(--dark-grey);
  font-size:0.95rem
}
.service-card ul li:before {
  content:"✓";
  color:var(--accent-orange);
  font-weight:bold;
  margin-right:0.75rem;
  font-size:0.9rem
}
.related-services {
  padding:80px 0;
  background:var(--light-bg)
}
.related-service-card {
  background:var(--white);
  border-radius:12px;
  padding:2rem;
  text-align:center;
  box-shadow:var(--shadow-light);
  transition:var(--transition-normal);
  height:100%;
  border:1px solid var(--border-grey)
}
.related-service-card:hover {
  transform:translateY(-5px);
  box-shadow:var(--shadow-medium);
  border-color:var(--accent-orange)
}
.related-service-card a {
  text-decoration:none;
  color:inherit;
  display:block
}
.related-service-card i {
  font-size:3rem;
  color:var(--accent-orange);
  margin-bottom:1rem;
  transition:var(--transition-normal)
}
.related-service-card:hover i {
  transform:scale(1.1);
  color:var(--accent-yellow)
}
.related-service-card h4 {
  color:#373f3f;
  font-size:1.2rem;
  font-weight:600;
  margin:0;
  font-family:var(--font-secondary);
  transition:var(--transition-normal)
}
.related-service-card:hover h4 {
  color:var(--accent-orange)
}
.section-title {
  font-size:2.5rem;
  font-weight:700;
  color:#373f3f;
  text-align:center;
  margin-bottom:3rem;
  font-family:var(--font-secondary);
  position:relative
}
.section-title:after {
  content:"";
  position:absolute;
  bottom:-10px;
  left:50%;
  transform:translateX(-50%);
  width:60px;
  height:4px;
  background:linear-gradient( 90deg,
  var(--accent-orange),
  var(--accent-yellow) );
  border-radius:2px
}
@media (max-width:768px) {
  .service-card,
  .related-service-card {
    padding:1.5rem
  }.service-card .service-icon {
    width:60px;
    height:60px;
    font-size:1.5rem
  }.related-service-card i {
    font-size:2.5rem
  }.section-title {
    font-size:2rem;
    margin-bottom:2rem
  }.related-services {
    padding:60px 0
  }
}
.professional-tools-showcase {
  padding:80px 0;
  background:var(--light-bg)
}
.tool-showcase-card {
  background:var(--white);
  border-radius:16px;
  overflow:hidden;
  box-shadow:var(--shadow-light);
  transition:var(--transition-normal);
  border:2px solid transparent
}
.tool-showcase-card:hover {
  transform:translateY(-8px);
  box-shadow:var(--shadow-medium);
  border-color:var(--accent-orange)
}
.tool-image-container {
  height:250px;
  overflow:hidden;
  position:relative
}
.tool-image {
  width:100%;
  height:100%;
  object-fit:cover;
  transition:var(--transition-normal)
}
.tool-showcase-card:hover .tool-image {
  transform:scale(1.05)
}
.tool-content {
  padding:2rem
}
.tool-content h3 {
  color:#373f3f;
  font-size:1.4rem;
  font-weight:600;
  margin-bottom:1rem;
  font-family:var(--font-secondary)
}
.tool-content p {
  color:var(--dark-grey);
  line-height:1.6;
  margin-bottom:1.5rem
}
.tool-features {
  list-style:none;
  padding:0;
  margin:0
}
.tool-features li {
  display:flex;
  align-items:center;
  margin-bottom:0.75rem;
  color:var(--dark-grey);
  font-size:0.95rem
}
.tool-features li i {
  color:var(--accent-orange);
  margin-right:0.75rem;
  font-size:0.9rem
}
@media (max-width:768px) {
  .professional-tools-showcase {
    padding:60px 0
  }.tool-image-container {
    height:200px
  }.tool-content {
    padding:1.5rem
  }.section-subtitle {
    font-size:1rem;
    margin-bottom:2rem
  }
}
.tools-grid-gallery {
  padding:20px 0
}
.gallery-title {
  font-size:1.5rem;
  font-weight:600;
  color:#373f3f;
  margin-bottom:1.5rem;
  text-align:center;
  font-family:var(--font-secondary)
}
.tools-grid {
  display:grid;
  grid-template-columns:repeat(2,
  1fr);
  gap:15px;
  max-height:500px;
  overflow-y:auto;
  padding:10px;
  border-radius:12px;
  background:rgba(255,
  255,
  255,
  0.1)
}
.tool-item {
  background:white;
  border-radius:8px;
  padding:10px;
  box-shadow:var(--shadow-light);
  transition:var(--transition-normal);
  text-align:center
}
.tool-item:hover {
  transform:translateY(-3px);
  box-shadow:var(--shadow-medium)
}
.tool-grid-image {
  width:100%;
  height:80px;
  object-fit:contain;
  border-radius:6px;
  margin-bottom:8px
}
.tool-caption {
  font-size:0.8rem;
  font-weight:500;
  color:var(--dark-grey);
  text-align:center
}
@media (max-width:768px) {
  .tools-grid {
    grid-template-columns:repeat(2,
    1fr);
    gap:10px;
    max-height:400px
  }.tool-grid-image {
    height:60px
  }.tool-caption {
    font-size:0.7rem
  }.gallery-title {
    font-size:1.3rem;
    margin-bottom:1rem
  }
}
.page-banner {
  margin-top:90px;
  padding:100px 0 80px;
  background:linear-gradient(135deg,
  #6c7a89 0%,
  #4a5568 100%)
}
.page-banner-title {
  color:#fff;
  font-size:3rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:2px;
  font-family:var(--font-secondary)
}
@media (max-width:768px) {
  .page-banner-title {
    font-size:2rem;
    letter-spacing:1px
  }
}
.values-section {
  padding:80px 0;
  background:#f8f9fa
}
.values-section.ts-features {
  background:#f8f9fa
}
.code-of-ethics {
  background:white;
  padding:3rem;
  border-radius:12px;
  box-shadow:var(--shadow-medium);
  max-width:100%
}
.ethics-intro {
  margin-bottom:3rem;
  padding-bottom:2rem;
  border-bottom:2px solid #e0e0e0
}
.ethics-title {
  font-size:1.8rem;
  font-weight:700;
  color:#373f3f;
  margin-bottom:1rem;
  font-family:var(--font-secondary)
}
.ethics-subtitle {
  font-size:1.3rem;
  font-weight:600;
  color:var(--accent-orange);
  margin-top:2rem;
  margin-bottom:1rem;
  font-family:var(--font-secondary)
}
.ethics-section {
  margin-bottom:2.5rem
}
.ethics-section p {
  margin-bottom:1rem;
  line-height:1.8;
  color:#444;
  font-size:1rem
}
.ethics-section p strong {
  color:#373f3f;
  font-weight:600
}
.ethics-list {
  list-style:none;
  padding-left:0;
  margin:1rem 0
}
.ethics-list li {
  padding:0.75rem 1rem;
  padding-left:2.5rem;
  position:relative;
  line-height:1.7;
  color:#555;
  margin-bottom:0.5rem;
  background:#f8f9fa;
  border-radius:6px;
  border-left:3px solid var(--accent-orange);
  transition:var(--transition-fast)
}
.ethics-list li:before {
  content:"\2022";
  position:absolute;
  left:1rem;
  color:var(--accent-orange);
  font-size:1.2rem;
  font-weight:bold
}
.ethics-list li:hover {
  background:#fff5e6;
  transform:translateX(5px)
}
.principle {
  background:linear-gradient(135deg,
  #ffffff 0%,
  #f9f9f9 100%);
  padding:1.5rem;
  margin-bottom:1.5rem;
  border-radius:10px;
  border:1px solid #e8e8e8;
  box-shadow:0 2px 8px rgba(0,
  0,
  0,
  0.05);
  transition:var(--transition-normal)
}
.principle:hover {
  box-shadow:0 4px 16px rgba(0,
  0,
  0,
  0.1);
  transform:translateY(-2px)
}
.principle-title {
  font-size:1.2rem;
  font-weight:600;
  color:#373f3f;
  margin-bottom:0.75rem;
  font-family:var(--font-secondary);
  display:flex;
  align-items:center;
  gap:0.5rem
}
.principle-number {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:2rem;
  height:2rem;
  background:var(--accent-orange);
  color:white;
  border-radius:50%;
  font-weight:700;
  font-size:1rem;
  flex-shrink:0
}
.principle .ethics-list {
  margin-top:0.5rem
}
.principle .ethics-list li {
  background:white;
  border-left-color:#373f3f;
  margin-bottom:0.4rem
}
.principle .ethics-list li:hover {
  background:#fff5e6;
  border-left-color:var(--accent-orange)
}
.ethics-footer {
  margin-top:3rem;
  padding-top:2rem;
  border-top:2px solid #e0e0e0;
  text-align:center
}
.footer-note {
  font-size:0.9rem;
  color:#888;
  font-style:italic
}
@media (max-width:992px) {
  .code-of-ethics {
    padding:2rem
  }.ethics-title {
    font-size:1.5rem
  }.page-banner-title {
    font-size:2.5rem
  }
}
@media (max-width:768px) {
  .values-section {
    padding:60px 0
  }.code-of-ethics {
    padding:1.5rem
  }.ethics-title {
    font-size:1.3rem
  }.ethics-subtitle {
    font-size:1.1rem
  }.principle {
    padding:1rem
  }.principle-title {
    font-size:1rem
  }.principle-number {
    width:1.75rem;
    height:1.75rem;
    font-size:0.9rem
  }.page-banner-title {
    font-size:1.75rem
  }.ethics-list li {
    padding:0.6rem 0.75rem;
    padding-left:2rem;
    font-size:0.95rem
  }
}
@media (max-width:576px) {
  .code-of-ethics {
    padding:1rem
  }.page-banner-title {
    font-size:1.5rem
  }.ethics-title {
    font-size:1.2rem
  }.principle-title {
    font-size:0.95rem
  }
}
.electrical-services-page {
  padding:120px 0 140px
}
.electrical-services-section .projects-showcase-card {
  padding:5rem 5rem
}
.electrical-services-content {
  gap:3.5rem
}
.electrical-services-panel {
  padding:3.4rem 3.6rem
}
.electrical-columns {
  gap:2.4rem 2.8rem;
  margin-bottom:3rem
}
.electrical-list {
  gap:2rem
}
.electrical-services-gallery {
  gap:2.6rem;
  width:min(42%,
  520px)
}
.gallery-frame {
  padding:22px
}
.electrical-cta {
  margin-top:1.5rem
}
@media (max-width:1100px) {
  .electrical-services-section .projects-showcase-card {
    padding:4rem 3.5rem
  }.electrical-services-panel {
    padding:3rem
  }.electrical-columns {
    margin-bottom:2.6rem
  }
}
@media (max-width:768px) {
  .electrical-services-section .projects-showcase-card {
    padding:3.4rem 2.6rem
  }.gallery-frame {
    padding:18px
  }
}
.electrical-services-page {
  background:linear-gradient(180deg,
  #f4f2ee 0%,
  #ebe7e1 100%)
}
.electrical-hero {
  position:relative;
  padding:0;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  min-height:auto;
  overflow:hidden;
  width:100vw;
  max-width:100vw;
  box-sizing:border-box;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw)
}
.electrical-hero::before {
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient( circle at 50% 35%,
  rgba(255,
  189,
  86,
  0.32),
  transparent 60% ),
  radial-gradient(circle at 50% 80%,
  rgba(35,
  26,
  18,
  0.35),
  transparent 70%);
  opacity:0.95;
  pointer-events:none
}
.hero-content {
  position:relative;
  z-index:2;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:1.6rem;
  max-width:100%;
  width:100%
}
.electrical-hero-image {
  width:100vw;
  max-width:100vw;
  height:35vh;
  max-height:35vh;
  min-height:35vh;
  display:block;
  object-fit:cover;
  object-position:center;
  border-radius:0;
  box-shadow:0 10px 30px rgba(0,
  0,
  0,
  0.3);
  position:relative;
  z-index:1;
  margin:0;
  left:0;
  right:0
}
.hero-content h1 {
  font-size:clamp(3rem,
  5vw,
  4rem);
  line-height:1.15;
  color:#1d140d;
  margin:0;
  white-space:nowrap
}
.hero-cta {
  display:flex;
  gap:1rem
}
@media (max-width:768px) {
  .electrical-hero {
    padding:130px 2.4rem 90px
  }.hero-content h1 {
    font-size:clamp(2.4rem,
    7vw,
    3rem);
    white-space:normal
  }
}
.service-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,
  minmax(260px,
  1fr));
  gap:1.8rem;
  margin:2.4rem 0 3rem;
  counter-reset:service-counter
}
.service-box {
  position:relative;
  padding:2.1rem 2rem;
  border-radius:26px;
  background:linear-gradient( 135deg,
  rgba(34,
  24,
  18,
  0.94),
  rgba(16,
  11,
  7,
  0.97) );
  box-shadow:0 24px 46px rgba(12,
  7,
  5,
  0.32);
  border:1px solid rgba(255,
  189,
  86,
  0.12);
  overflow:hidden;
  transition:transform 0.35s ease,
  box-shadow 0.35s ease
}
.service-box::before {
  counter-increment:service-counter;
  content:counter(service-counter,
  decimal-leading-zero);
  position:absolute;
  top:18px;
  right:22px;
  font-size:1.1rem;
  letter-spacing:2px;
  color:rgba(255,
  198,
  128,
  0.55)
}
.service-box::after {
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient( circle at 25% 25%,
  rgba(255,
  199,
  127,
  0.18),
  transparent 55% ),
  radial-gradient(circle at 80% 80%,
  rgba(40,
  28,
  20,
  0.4),
  transparent 70%);
  opacity:0.9;
  pointer-events:none
}
.service-box h4 {
  position:relative;
  z-index:2;
  margin:0;
  font-size:1.18rem;
  font-weight:700;
  color:#f6dec4;
  letter-spacing:0.25px;
  text-transform:uppercase
}
.service-box:hover {
  transform:translateY(-10px);
  box-shadow:0 32px 60px rgba(15,
  9,
  5,
  0.45)
}
@media (max-width:768px) {
  .service-box {
    padding:1.8rem 1.6rem
  }
}
.electrical-cta {
  display:flex;
  justify-content:center;
  gap:1rem
}
.service-panels {
  display:grid;
  grid-template-columns:repeat(auto-fit,
  minmax(280px,
  1fr));
  gap:1.6rem;
  margin:2.2rem 0 3rem
}
.service-panel {
  position:relative;
  overflow:hidden;
  border-radius:26px;
  background:#1c1510;
  box-shadow:0 28px 48px rgba(12,
  7,
  5,
  0.38);
  border:1px solid rgba(255,
  189,
  86,
  0.18);
  min-height:220px
}
.panel-image,
.panel-overlay {
  position:absolute;
  inset:0
}
.panel-image img {
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  transform:scale(1.05);
  transition:transform 0.6s ease
}
.panel-overlay {
  background:linear-gradient( 195deg,
  rgba(14,
  9,
  6,
  0.9) 20%,
  rgba(14,
  9,
  6,
  0.68) 65%,
  rgba(14,
  9,
  6,
  0.3) 100% );
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:1.1rem;
  padding:2.1rem
}
.panel-overlay h4 {
  margin:0;
  font-size:1.15rem;
  font-weight:700;
  color:#fef2d9;
  letter-spacing:0.3px;
  text-transform:uppercase;
  position:relative;
  padding-bottom:0.45rem
}
.panel-overlay h4::after {
  content:"";
  position:absolute;
  left:0;
  bottom:0;
  width:100%;
  height:1px;
  background:linear-gradient( 90deg,
  rgba(255,
  199,
  127,
  0.55) 0%,
  rgba(255,
  199,
  127,
  0) 100% )
}
.panel-overlay h4:last-child::after {
  display:none
}
.service-panel:hover .panel-image img {
  transform:scale(1.12)
}
.service-panel:hover::before {
  opacity:1
}
@media (max-width:768px) {
  .panel-overlay {
    padding:1.8rem
  }.panel-overlay h4 {
    font-size:1.02rem
  }
}
.services-text-carousel {
  position:relative;
  background:linear-gradient(135deg,
  #2a1b13 0%,
  #120804 100%);
  border-radius:32px;
  box-shadow:0 28px 60px rgba(15,
  8,
  5,
  0.55);
  padding:3.75rem 4rem 4.75rem;
  overflow:hidden;
  min-height:300px;
  border:1px solid rgba(255,
  177,
  66,
  0.08);
  margin:2.8rem 0 3.4rem;
  display:flex;
  flex-direction:column;
  gap:2.2rem
}
.services-text-carousel::after {
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient( circle at top left,
  rgba(255,
  190,
  90,
  0.12),
  transparent 55% ),
  radial-gradient( circle at bottom right,
  rgba(81,
  52,
  38,
  0.22),
  transparent 60% );
  pointer-events:none
}
.services-carousel-header {
  display:flex;
  align-items:center;
  gap:1rem
}
.services-carousel-header::before {
  content:"";
  width:56px;
  height:3px;
  border-radius:999px;
  background:linear-gradient(90deg,
  #f5c065 0%,
  var(--accent-orange) 100%)
}
.services-carousel-title {
  text-transform:uppercase;
  letter-spacing:1px;
  font-size:1.9rem;
  font-weight:800;
  color:#f7ecdf;
  margin:0;
  text-shadow:0 6px 18px rgba(0,
  0,
  0,
  0.45)
}
.services-carousel-list {
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:1.35rem
}
.services-carousel-list li {
  position:relative;
  padding-left:2.4rem
}
.services-carousel-list li::before {
  content:"";
  position:absolute;
  left:0;
  top:0.6rem;
  width:14px;
  height:14px;
  border-radius:50%;
  background:radial-gradient( circle at 40% 40%,
  #ffe4a1 0%,
  #ffad32 68%,
  #f48800 100% );
  box-shadow:0 0 0 6px rgba(255,
  170,
  50,
  0.25)
}
.services-carousel-list li {
  cursor:pointer;
  transition:transform 0.3s ease,
  opacity 0.3s ease
}
.services-carousel-list li:hover {
  transform:translateX(8px);
  opacity:0.9
}
.services-carousel-list li strong,
.services-carousel-list li>span:first-of-type {
  display:block;
  font-size:1.24rem;
  font-weight:400;
  font-family:var(--font-primary);
  color:#f4eadf;
  letter-spacing:0.35px;
  text-shadow:0 4px 14px rgba(0,
  0,
  0,
  0.35);
  margin-bottom:0.5rem
}
.services-carousel-list li span:not(:first-of-type) {
  display:block;
  color:#d6c5b5;
  font-size:1.03rem;
  line-height:1.55;
  margin-top:0.45rem
}
.services-carousel-indicators {
  position:absolute;
  bottom:32px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  gap:0.8rem;
  z-index:5
}
.services-carousel-indicators::before {
  content:"";
  position:absolute;
  inset:-14px -20px;
  background:rgba(34,
  21,
  15,
  0.78);
  border-radius:999px;
  filter:blur(1px);
  z-index:-1
}
@media (max-width:1200px) {
  .services-text-carousel {
    padding:3.5rem 3.25rem 4.5rem
  }
}
@media (max-width:992px) {
  .services-text-carousel {
    padding:3rem 2.5rem 4rem
  }.services-carousel-title {
    font-size:1.65rem
  }
}
@media (max-width:768px) {
  .services-text-carousel {
    padding:2.5rem 1.75rem 3.75rem;
    min-height:280px
  }.services-carousel-header::before {
    width:36px
  }.services-carousel-title {
    font-size:1.35rem
  }.services-carousel-list {
    gap:1.2rem
  }.services-carousel-list li strong {
    font-size:1.05rem
  }.services-carousel-indicators {
    bottom:24px
  }
}
@media (max-width:576px) {
  .services-text-carousel {
    padding:2.4rem 1.6rem 3.5rem
  }.services-carousel-title {
    font-size:1.25rem
  }.services-carousel-list {
    gap:1rem
  }.services-carousel-list li strong {
    font-size:1rem
  }.services-carousel-indicators {
    bottom:24px
  }
}
.service-strips {
  display:flex;
  flex-direction:column;
  gap:1.8rem;
  margin:2.8rem 0 3.4rem
}
.service-strip {
  position:relative;
  border-radius:22px;
  background:linear-gradient( 135deg,
  rgba(24,
  18,
  12,
  0.98),
  rgba(11,
  8,
  6,
  0.95) );
  box-shadow:0 28px 48px rgba(7,
  4,
  3,
  0.45);
  border:1px solid rgba(255,
  176,
  67,
  0.24);
  overflow:hidden;
  transition:background 0.3s ease,
  box-shadow 0.3s ease,
  transform 0.3s ease
}
.service-strip::after {
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:linear-gradient( 180deg,
  rgba(255,
  210,
  140,
  0.14),
  transparent 70% );
  pointer-events:none
}
.strip-overlay {
  display:flex;
  align-items:baseline;
  padding:1.35rem 2.2rem;
  background:radial-gradient( circle at 18% 50%,
  rgba(255,
  196,
  120,
  0.18),
  transparent 65% ),
  radial-gradient( circle at 85% 50%,
  rgba(255,
  140,
  50,
  0.16),
  transparent 75% )
}
.strip-overlay h4 {
  position:relative;
  margin:0;
  padding-left:1.6rem;
  font-size:1.04rem;
  font-weight:600;
  color:#f2ddbf;
  text-transform:uppercase;
  letter-spacing:0.28rem
}
.strip-overlay h4::before {
  content:"";
  position:absolute;
  left:0;
  top:0.3rem;
  width:2px;
  height:70%;
  border-radius:1px;
  background:linear-gradient(180deg,
  #ffb347,
  #ff914d)
}
.service-strip:hover {
  background:linear-gradient( 135deg,
  rgba(32,
  23,
  17,
  0.98),
  rgba(14,
  9,
  6,
  0.95) );
  box-shadow:0 36px 60px rgba(6,
  3,
  2,
  0.55);
  transform:translateY(-6px)
}
@media (max-width:768px) {
  .strip-overlay {
    padding:1.2rem 1.7rem
  }.strip-overlay h4 {
    font-size:0.96rem;
    letter-spacing:0.18rem
  }
}
.electrical-title {
  text-align:center;
  margin-bottom:2rem
}
.electrical-title h2 {
  position:relative;
  margin:0;
  font-size:clamp(2rem,
  3.5vw,
  2.6rem);
  letter-spacing:0.4rem;
  text-transform:uppercase;
  color:#f5e2c9;
  text-shadow:0 0 12px rgba(255,
  188,
  86,
  0.35)
}
.electrical-title h2::after {
  content:"";
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  bottom:-1rem;
  width:clamp(140px,
  25vw,
  220px);
  height:3px;
  border-radius:999px;
  background:linear-gradient( 90deg,
  rgba(255,
  140,
  40,
  0) 0%,
  rgba(255,
  180,
  80,
  0.9) 35%,
  rgba(255,
  210,
  140,
  0.6) 50%,
  rgba(255,
  180,
  80,
  0.9) 65%,
  rgba(255,
  140,
  40,
  0) 100% );
  background-size:220% 100%;
  animation:currentFlow 2.8s ease-in-out infinite;
  box-shadow:0 0 18px rgba(255,
  180,
  80,
  0.45)
}
@keyframes currentFlow {
  0% {
    background-position:0% 50%;
    opacity:0.2
  }40% {
    opacity:1
  }100% {
    background-position:200% 50%;
    opacity:0.35
  }
}
.ts-features .terms-content[style*="color:#ffffff"],
.ts-features .terms-content[style*="color:#ffffff"] *,
.ts-features .terms-content[style*="color:#ffffff"] p,
.ts-features .terms-content[style*="color:#ffffff"] h1,
.ts-features .terms-content[style*="color:#ffffff"] h2,
.ts-features .terms-content[style*="color:#ffffff"] h3,
.ts-features .terms-content[style*="color:#ffffff"] h4,
.ts-features .terms-content[style*="color:#ffffff"] h5,
.ts-features .terms-content[style*="color:#ffffff"] h6,
.ts-features .terms-content[style*="color:#ffffff"] ul,
.ts-features .terms-content[style*="color:#ffffff"] ol,
.ts-features .terms-content[style*="color:#ffffff"] li,
.ts-features .terms-content[style*="color:#ffffff"] strong,
.ts-features .terms-content[style*="color:#ffffff"] em,
.ts-features .terms-content[style*="color:#ffffff"] span,
.ts-features .terms-content[style*="color:#ffffff"] a {
  color:#ffffff !important
}
.ts-features .terms-content[style*="color:#000000"],
.ts-features .terms-content[style*="color:#000000"] p,
.ts-features .terms-content[style*="color:#333"],
.ts-features .terms-content[style*="color:#333"] p,
.ts-features .terms-content[style*="color:#000000"] h3,
.ts-features .terms-content[style*="color:#000000"] h4,
.ts-features .terms-content[style*="color:#000000"] h5,
.ts-features .terms-content[style*="color:#000000"] ul,
.ts-features .terms-content[style*="color:#000000"] li,
.ts-features .terms-content[style*="color:#000000"] strong {
  color:#000000 !important
}
