/*

TemplateMo 579 Cyborg Gaming

https://templatemo.com/tm-579-cyborg-gaming

*/

/* ---------------------------------------------
Table of contents
------------------------------------------------
01. font & reset css
02. reset
03. global styles
04. header
05. banner
06. features
07. testimonials
08. contact
09. footer

--------------------------------------------- */
/* 
---------------------------------------------
font & reset css
--------------------------------------------- 
*/
@import url("https://fonts.googleapis.com/css2?family=Poppins:wght@100;200;300;400;500;600;700;800;900");

:root {
  --color-green: #00954c;
  --color-green-rgb: 0, 149, 76;
  --color-green-glow: rgba(0, 149, 76, 0.45);
  --color-yellow: #f2eb0b;
  --color-yellow-rgb: 242, 235, 11;
  --color-yellow-glow: rgba(242, 235, 11, 0.45);
  --color-bg-dark: #07140e;
  --color-bg-gradient: radial-gradient(circle at 50% 50%, #0d261b 0%, #050d0a 100%);
  --color-bg-panel: rgba(15, 26, 20, 0.82);
  --color-border: rgba(0, 149, 76, 0.25);
  --color-text-main: #f2fbe8;
  --color-text-muted: #8fa394;
}

body.light-theme {
  background: #f4f7fb;
  color: #102a43;
}

body.light-theme .page-content,
body.light-theme .item,
body.light-theme .left-info,
body.light-theme .right-info,
body.light-theme .game-details,
body.light-theme .live-stream,
body.light-theme .contact-form-wrapper,
body.light-theme .success-message {
  background: #ffffff;
  border-color: rgba(15, 23, 42, 0.08);
  color: #102a43;
}

body.light-theme .header-area {
  background: rgba(255, 255, 255, 0.96);
  border-bottom: 1px solid rgba(15, 23, 42, 0.12);
}

body.light-theme .header-area .main-nav .nav a,
body.light-theme .header-area .main-nav .nav a:hover,
body.light-theme .header-area .main-nav .nav a:focus,
body.light-theme .header-area .main-nav .nav a.active {
  color: #102a43 !important;
}

body.light-theme .main-button a {
  background-color: #047857;
  color: #ffffff;
}

body.light-theme .main-button a:hover {
  background-color: #0f766e;
  color: #ffffff;
}

body.light-theme .main-border-button a {
  border-color: #047857;
  color: #047857;
}

body.light-theme h1,
body.light-theme h2,
body.light-theme h3,
body.light-theme h4,
body.light-theme h5,
body.light-theme h6,
body.light-theme p,
body.light-theme li,
body.light-theme a,
body.light-theme span,
body.light-theme label {
  color: #102a43;
}

body.light-theme .heading-section h4 {
  color: #047857;
}

body.light-theme .heading-section h4 em {
  color: #065f46;
}

.theme-toggle,
.lang-toggle {
  border: none;
  background: rgba(255, 255, 255, 0.08);
  color: #f2fbe8;
  padding: 8px 12px;
  font-size: 14px;
  border-radius: 999px;
  cursor: pointer;
  transition: all 0.2s ease;
}

.theme-toggle:hover,
.lang-toggle:hover {
  background: rgba(242, 235, 11, 0.18);
}

body.light-theme .theme-toggle,
body.light-theme .lang-toggle {
  background: rgba(15, 23, 42, 0.08);
  color: #102a43;
}

.header-controls {
  display: flex;
  align-items: center;
  gap: 10px;
}

@media (max-width: 992px) {
  .header-controls {
    justify-content: center;
    width: 100%;
    margin-top: 12px;
  }
}

/* Modern scrollbar */
::-webkit-scrollbar {
  width: 8px;
}
::-webkit-scrollbar-track {
  background: var(--color-bg-dark);
}
::-webkit-scrollbar-thumb {
  background: var(--color-green);
  border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
  background: var(--color-yellow);
}

/* 
---------------------------------------------
reset
--------------------------------------------- 
*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, div
pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, img, ins, kbd, q,
s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li,
figure, header, nav, section, article, aside, footer, figcaption {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
}

.clearfix:after {
  content: ".";
  display: block;
  clear: both;
  visibility: hidden;
  line-height: 0;
  height: 0;
}

.clearfix {
  display: inline-block;
}

html[xmlns] .clearfix {
  display: block;
}

* html .clearfix {
  height: 1%;
}

ul, li {
  padding: 0;
  margin: 0;
  list-style: none;
}

header, nav, section, article, aside, footer, hgroup {
  display: block;
}

* {
  box-sizing: border-box;
}

html, body {
  font-family: 'Poppins', sans-serif;
  font-weight: 400;
  background-color: #1e1e1e;
  font-size: 16px;
  -ms-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a {
	color: #CCC;
  text-decoration: none !important;
}
a:hover {
	color: #F99;
}

h1, h2, h3, h4, h5, h6 {
  margin-top: 0px;
  margin-bottom: 0px;
  color: #ffffff;
  font-weight: 700;
}

ul {
  margin-bottom: 0px;
}

p {
  font-size: 15px;
  line-height: 30px;
  color: #fff;
}

img {
  width: 100%;
  overflow: hidden;
}

/* 
---------------------------------------------
Global Styles
--------------------------------------------- 
*/
html,
body {
  background: var(--color-bg-gradient); /* fondo general*/
  font-family: 'Poppins', sans-serif;
}

body .page-content {
  margin-top: 110px;
  background-color: var(--color-bg-panel); backdrop-filter: blur(20px); border: 1px solid var(--color-border); box-shadow: 0 20px 50px rgba(0, 0, 0, 0.3);
  padding: 60px;
  border-radius: 23px;
}

p {
  font-size: 15px;
  color: #666;
  line-height: 30px;
  margin-bottom: 0px;
}

::selection {
  background: var(--color-green);
  color: #fff;
}

::-moz-selection {
  background: var(--color-green);
  color: #fff;
}

.templatemo-item {
	max-width: 80px; 
	border-radius: 23px;
}

.main-button a {
  font-size: 14px;
  color: #fff;
  background-color: var(--color-green); /* botones */
  padding: 12px 30px;
  display: inline-block;
  border-radius: 25px;
  font-weight: 400;
  text-transform: capitalize;
  letter-spacing: 0.5px;
  transition: all .3s;
  position: relative;
  overflow: hidden;
}

.main-button a:hover {
  background-color: #fff;
  color: var(--color-green);
}

.main-border-button a {
  font-size: 14px;
  color: var(--color-yellow);
  background-color: transparent;
  border: 1px solid var(--color-yellow);
  padding: 12px 30px;
  display: inline-block;
  border-radius: 25px;
  font-weight: 400;
  text-transform: capitalize;
  letter-spacing: 0.5px;
  transition: all .3s;
  position: relative;
  overflow: hidden;
}

.main-border-button a:hover {
  border-color: #fff;
  background-color: #fff;
  color: var(--color-green);
}

.border-no-active a {
  border-color: #666;
  color: #666;
}

.border-no-active a:hover{
  border-color: #666;
  color: #666;
  background-color: transparent;
}

section {
  margin-top: 120px;
}

.heading-section h4 {
  color: var(--color-yellow);
  font-size: 34px;
  text-decoration: none;
  margin-bottom: 30px;
}

.heading-section h4 em {
  color: #fff;
  font-style: normal;
  text-decoration: underline;
}

/* 
---------------------------------------------
Pre-loader Style
--------------------------------------------- 
*/

.js-preloader {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(0,0,0,0.99);
  display: -webkit-box;
  display: flex;
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: center;
  justify-content: center;
  opacity: 1;
  visibility: visible;
  z-index: 9999;
  -webkit-transition: opacity 0.25s ease;
  transition: opacity 0.25s ease;
}

.js-preloader.loaded {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

@-webkit-keyframes dot {
  50% {
      -webkit-transform: translateX(96px);
      transform: translateX(96px);
  }
}

@keyframes dot {
  50% {
      -webkit-transform: translateX(96px);
      transform: translateX(96px);
  }
}

@-webkit-keyframes dots {
  50% {
      -webkit-transform: translateX(-31px);
      transform: translateX(-31px);
  }
}

@keyframes dots {
  50% {
      -webkit-transform: translateX(-31px);
      transform: translateX(-31px);
  }
}

.preloader-inner {
  position: relative;
  width: 142px;
  height: 40px;
  background: transparent;
}

.preloader-inner .dot {
  position: absolute;
  width: 16px;
  height: 16px;
  top: 12px;
  left: 15px;
  background: var(--color-green);
  border-radius: 50%;
  -webkit-transform: translateX(0);
  transform: translateX(0);
  -webkit-animation: dot 2.8s infinite;
  animation: dot 2.8s infinite;
}

.preloader-inner .dots {
  -webkit-transform: translateX(0);
  transform: translateX(0);
  margin-top: 12px;
  margin-left: 31px;
  -webkit-animation: dots 2.8s infinite;
  animation: dots 2.8s infinite;
}

.preloader-inner .dots span {
  display: block;
  float: left;
  width: 16px;
  height: 16px;
  margin-left: 16px;
  background: var(--color-green);
  border-radius: 50%;
}



/* 
---------------------------------------------
Header Style
--------------------------------------------- 
*/ 
/*Color fondo responsibe */
 
.background-header {
  background-color: #000000 !important;
  height: 70px!important;
  position: fixed!important;
  top: 0!important;
  left: 0;
  right: 0;
  box-shadow: 0px 0px 10px rgba(0,0,0,0.15)!important;
  -webkit-transition: all .5s ease 0s;
  -moz-transition: all .5s ease 0s;
  -o-transition: all .5s ease 0s;
  transition: all .5s ease 0s;
  display: none;
}

.header-area {
  background-color: transparent;
  position: absolute;
  height: 70px;
  top: 15px;
  left: 0;
  right: 0;
  z-index: 100;
  -webkit-transition: all .5s ease 0s;
  -moz-transition: all .5s ease 0s;
  -o-transition: all .5s ease 0s;
  transition: all .5s ease 0s;
}

.header-area .main-nav {
  min-height: 80px;
  background: transparent;
  display: flex;
  padding: 15px 0px;
  border-radius: 50px;
}

.background-header .main-nav {
  padding: 0px;
  background-color: transparent;
}

.header-area .main-nav #search {
  position: relative;
}

.header-area .main-nav #search input {
  background-color: #27292a;
  height: 46px;
  border-radius: 23px;
  border: none;
  color: #666;
  font-size: 14px;
  padding: 0px 15px 0px 45px;
}

.header-area .main-nav #search i {
  position: absolute;
  color: #666;
  left: 20px;
  top: 16px;
  width: 18px;
  height: 18px;
  font-size: 16px;
}

.header-area .main-nav .logo {
  border-right: 1px solid #27292a;
  flex-basis: 25%;
  margin-right: 5%;
  -webkit-transition: all 0.3s ease 0s;
  -moz-transition: all 0.3s ease 0s;
  -o-transition: all 0.3s ease 0s;
  transition: all 0.3s ease 0s;
}

.header-area .main-nav .logo img {
  width: 200px;
}

.background-header .main-nav .logo {
  margin-top: 1px;
}

.background-header .main-nav .logo img {
  width: 200px;
}

.header-area .main-nav .nav {
  display: inline-flex;
  flex-basis: 70%;
  justify-content: flex-end;
  vertical-align: middle;
  text-align: right;
  margin-top: 0px;
  margin-right: 0px;
  -webkit-transition: all 0.3s ease 0s;
  -moz-transition: all 0.3s ease 0s;
  -o-transition: all 0.3s ease 0s;
  transition: all 0.3s ease 0s;
  position: relative;
  z-index: 999;
}

.header-area .main-nav .nav li {
  padding-left: 10px;
  padding-right: 10px;
  display: inline-block;
}

.header-area .main-nav .nav li a {
  display: block;
  font-weight: 400;
  font-size: 14px;
  text-transform: capitalize;
  color: #666;
  -webkit-transition: all 0.3s ease 0s;
  -moz-transition: all 0.3s ease 0s;
  -o-transition: all 0.3s ease 0s;
  transition: all 0.3s ease 0s;
  border: transparent;
  padding: 13px 10px;
  border-radius: 18px;
  letter-spacing: .3px;
}

.header-area .main-nav .nav li:last-child a {
  background-color: #27292a;
  padding: 8px 10px 8px 20px;
  border-radius: 23px;
}

.header-area .main-nav .nav li:last-child a img {
  max-width: 30px;
  border-radius: 50%;
  margin-left: 5px;
}

.header-area .main-nav .nav li.has-sub ul.sub-menu li:last-child a:hover,
.background-header .main-nav .nav li.has-sub ul.sub-menu li:last-child a:hover {
  padding-left: 25px !important;
}

.header-area .main-nav .nav li:hover a,
.header-area .main-nav .nav li a.active {
  color: var(--color-green) !important;
}

.header-area .main-nav .nav li:last-child:hover a,
.header-area .main-nav .nav li:last-child a.active {
  color: #fff !important;
  background-color: var(--color-green) !important;
}

.background-header .main-nav .nav li:hover a,
.background-header .main-nav .nav li a.active {
  color: #fff;
  opacity: 1;
}

.header-area .main-nav .nav li.has-sub {
  position: relative;
  padding-right: 15px;
}

.header-area .main-nav .menu-trigger {
  cursor: pointer;
  display: block;
  position: absolute;
  top: 23px;
  width: 32px;
  height: 40px;
  text-indent: -9999em;
  z-index: 99;
  right: 20px;
  display: none;
}

.background-header .main-nav .menu-trigger {
  top: 17px;
}

.header-area .main-nav .menu-trigger span,
.header-area .main-nav .menu-trigger span:before,
.header-area .main-nav .menu-trigger span:after {
  -moz-transition: all 0.4s;
  -o-transition: all 0.4s;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
  background-color: #fffb00;
  display: block;
  position: absolute;
  width: 30px;
  height: 2px;
  left: 0;
}

.background-header .main-nav .menu-trigger span,
.background-header .main-nav .menu-trigger span:before,
.background-header .main-nav .menu-trigger span:after {
  background-color: #00eeff;
}

.header-area .main-nav .menu-trigger span:before,
.header-area .main-nav .menu-trigger span:after {
  -moz-transition: all 0.4s;
  -o-transition: all 0.4s;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
  background-color: var(--color-yellow);
  display: block;
  position: absolute;
  width: 30px;
  height: 2px;
  left: 0;
  width: 75%;
}

.background-header .main-nav .menu-trigger span:before,
.background-header .main-nav .menu-trigger span:after {
  background-color: #38ee00;
}

.header-area .main-nav .menu-trigger span:before,
.header-area .main-nav .menu-trigger span:after {
  content: "";
}

.header-area .main-nav .menu-trigger span {
  top: 16px;
}

.header-area .main-nav .menu-trigger span:before {
  -moz-transform-origin: 33% 100%;
  -ms-transform-origin: 33% 100%;
  -webkit-transform-origin: 33% 100%;
  transform-origin: 33% 100%;
  top: -10px;
  z-index: 10;
}

.header-area .main-nav .menu-trigger span:after {
  -moz-transform-origin: 33% 0;
  -ms-transform-origin: 33% 0;
  -webkit-transform-origin: 33% 0;
  transform-origin: 33% 0;
  top: 10px;
}

.header-area .main-nav .menu-trigger.active span,
.header-area .main-nav .menu-trigger.active span:before,
.header-area .main-nav .menu-trigger.active span:after {
  background-color: transparent;
  width: 100%;
}
 /*Equis 1*/
.header-area .main-nav .menu-trigger.active span:before {
  -moz-transform: translateY(6px) translateX(1px) rotate(45deg);
  -ms-transform: translateY(6px) translateX(1px) rotate(45deg);
  -webkit-transform: translateY(6px) translateX(1px) rotate(45deg);
  transform: translateY(6px) translateX(1px) rotate(45deg);
  background-color: #fffb00;
}

.background-header .main-nav .menu-trigger.active span:before {
  background-color: #ffe602;
}
/*Equis 2*/
.header-area .main-nav .menu-trigger.active span:after {
  -moz-transform: translateY(-6px) translateX(1px) rotate(-45deg);
  -ms-transform: translateY(-6px) translateX(1px) rotate(-45deg);
  -webkit-transform: translateY(-6px) translateX(1px) rotate(-45deg);
  transform: translateY(-6px) translateX(1px) rotate(-45deg);
  background-color: var(--color-yellow);
}

.background-header .main-nav .menu-trigger.active span:after {
  background-color: var(--color-yellow);
}

.header-area.header-sticky {
  min-height: 70px;
}

.header-area.header-sticky .nav li a.active {
  color: var(--color-yellow);
}

@media (max-width: 1200px) {
  .header-area .main-nav .nav li {
    padding-left: 10px;
    padding-right: 10px;
  }
  .header-area .main-nav:before {
    display: none;
  }
}

@media (max-width: 992px) {
  .header-area {
    top: 0;
  }
  .header-area .main-nav {
    background-color: transparent;
    border-radius: 0px;
  }
  .header-area .main-nav .nav {
    height: auto;
    flex-basis: 100%;
  }
  .header-area .main-nav .logo {
    position: absolute;
    left: 30px;
    top: 15px;
  }
  .background-header .main-nav .logo {
    top: 0px;
  }
  .background-header .main-nav .border-button {
    top: 0px !important;
  }
  .header-area .main-nav .border-button {
    position: absolute;
    top: 15px;
    right: 70px;
  }
  .header-area.header-sticky .nav li a:hover,
  .header-area.header-sticky .nav li a.active {
    color: var(--color-green)!important;
    opacity: 1;
  }
  .header-area.header-sticky .nav li.search-icon a {
    width: 100%;
  }
  /*Menu responsibo 1ro*/
  .header-area {
    background-color: #000000;
    padding: 0px 15px;
    height: 80px;
    box-shadow: none;
    text-align: center;
  }
  .header-area .container {
    padding: 0px;
  }
  .header-area .logo {
    margin-left: 0px;
  }
  .header-area .menu-trigger {
    display: block !important;
  }
  .header-area .main-nav {
    overflow: hidden;
  }
  .header-area .main-nav .nav {
    float: none;
    width: 100%;
    display: none;
    -webkit-transition: all 0s ease 0s;
    -moz-transition: all 0s ease 0s;
    -o-transition: all 0s ease 0s;
    transition: all 0s ease 0s;
    margin-left: 0px;
  }
  .header-area.header-sticky .nav {
    margin-top: 65px !important;
    text-align: center;
  }
  .background-header.header-sticky .nav {
    margin-top: 70px !important;
  }
  .header-area .main-nav .nav li:first-child {
    border-top: 1px solid #eee;
  }
  .header-area .main-nav .nav li {
    width: 100%;
    background: #fff;
    border-bottom: 1px solid #eee;
    padding-left: 0px !important;
    padding-right: 0px !important;
  }
  .header-area .main-nav .nav li a {
    height: 50px !important;
    line-height: 50px !important;
    padding: 0px !important;
    border: none !important;
    background: #fff !important;
    color: #1e1e1e !important;
  }
  .header-area .main-nav .nav li a:hover {
    background: #fff !important;
    color: var(--color-green)!important;
  }
  .header-area .main-nav .nav li:last-child a img {
    display: none;
  }
  .header-area .main-nav .nav li:last-child a:hover {
    color: var(--color-yellow) !important;
    background-color: transparent !important;
  }
  .header-area .main-nav .nav li.has-sub ul.sub-menu {
    position: relative;
    visibility: inherit;
    opacity: 1;
    z-index: 1;
    transform: translateY(0%);
    top: 0px;
    width: 100%;
    box-shadow: none;
    height: 0px;
    transition: all 0s;
  }
  .header-area .main-nav .nav li.submenu ul li a {
    font-size: 12px;
    font-weight: 400;
  }
  .header-area .main-nav .nav li.submenu ul li a:hover:before {
    width: 0px;
  }
  .header-area .main-nav .nav li.has-sub ul.sub-menu {
    height: auto;
  }
  .header-area .main-nav .nav li.has-sub:after {
    color: #3B566E;
    right: 30px;
    font-size: 14px;
    top: 15px;
  }
  .header-area .main-nav .nav li.submenu:hover ul, .header-area .main-nav .nav li.submenu:focus ul {
    height: 0px;
  }
}

/* 
---------------------------------------------
Banner Style
--------------------------------------------- 
*/

.main-banner {
  background-image: url(../images/banner-bg.jpg);
  background-position: center center;
  background-size: cover;
  min-height: 380px;
  border-radius: 23px;
  padding: 80px 60px;
}

.main-banner h6 {
  font-size: 20px;
  color: #fff;
  font-weight: 400;
  margin-bottom: 25px;
}

.main-banner h4 {
  font-size: 45px;
  text-transform: uppercase;
  margin-bottom: 25px;
}

.main-banner h4 em { /*letra inicio*/
  font-style: normal;
  color: var(--color-yellow);
}

/* 
---------------------------------------------
Most Popular Style
--------------------------------------------- 
*/

.most-popular {
  margin-top: 60px;
  padding: 30px;
  background-color: #1f2122;
  border-radius: 23px;
}

.most-popular .item {
  background-color: #27292a;
  padding: 30px 15px;
  border-radius: 23px;
  margin-bottom: 30px;
}

.most-popular .item .item {
  padding: 0px;
  border-radius: 0px;
  background-color: transparent;
  margin-bottom: 0px;
}

.most-popular .item img {
  border-radius: 23px;
}

.most-popular .item h4 {
  font-size: 15px;
  margin-top: 20px;
  margin-bottom: 0px;
  display: inline-block;
}

.most-popular .item span {
  color: #666;
  display: block;
  margin-top: 7px;
  font-weight: 400;
}

.most-popular .item ul {
  float: right;
  margin-top: 20px;
}

.most-popular .item ul li {
  text-align: right;
  color: #fff;
  font-size: 14px;
}

.most-popular .item ul li:first-child i {
  color: yellow;
}

.most-popular .item ul li:last-child i {
  color: var(--color-yellow);
}

.most-popular .main-button {
  text-align: center;
  margin-bottom: -53px;
}

/* 
---------------------------------------------
Gaming Library Style
--------------------------------------------- 
*/

.gaming-library {
  margin-top: 60px;
  padding: 30px;
  background-color: #1f2122;
  border-radius: 23px;
}

.gaming-library .item {
  border-bottom: 1px solid #27292a;
  margin-bottom: 20px;
  padding-bottom: 20px;
}

.gaming-library .last-item {
  margin-bottom: 30px;
}

.profile-library .last-item {
  border-bottom: none;
  padding-bottom: 0px;
  margin-bottom: 0px;
}

.gaming-library .item ul li {
  margin-top: 15px;
}

.gaming-library .item ul li img {
  margin-top: -30px;
}

.gaming-library .item ul li {
  display: inline-block;
  width: 17%;
}

.gaming-library .item ul li:first-child {
  width: 110px;
}

.gaming-library .item ul li:last-child {
  width: 15%;
  text-align: right;
}

.gaming-library .item ul li h4 {
  font-size: 15px;
  margin-bottom: 5px;
}

.gaming-library .item ul li span {
  color: #666;
  font-size: 14px;
}

.gaming-library .main-button {
  text-align: center;
  margin-bottom: -53px;
}

/* 
---------------------------------------------
Footer Style
--------------------------------------------- 
*/

footer p {
  text-align: center;
  padding: 30px 0px;
  color: #fff;
  font-weight: 300;
}

footer p a {
  color: #fff;
  transition: all .3s;
}

footer p a:hover {
  color: var(--color-yellow);
}

/* 
---------------------------------------------
Featured Games Style
--------------------------------------------- 
*/

.featured-games {
  border-radius: 23px;
  background-color: #1f2122;
  padding: 30px;
}

.featured-games .item .thumb {
  position: relative;
  overflow: hidden;
}

.featured-games .item .thumb .hover-effect {
  position: absolute;
  bottom: -100px;
  text-align: center;
  width: 100%;
  opacity: 0;
  visibility: hidden;
  transition: all .4s;
}

.featured-games .item .thumb:hover .hover-effect {
  opacity: 1;
  visibility: visible;
  bottom: 15px;
}

.featured-games .item .thumb .hover-effect h6 {
  background-color: rgba(31,33,34,0.95);
  display: inline-block;
  color: var(--color-yellow);
  font-weight: 600;
  font-size: 14px;
  padding: 10px 20px;
  border-radius: 25px;
}

.featured-games .item img {
  border-radius: 23px;
}

.featured-games .item h4 {
  font-size: 15px;
  margin-top: 20px;
  margin-bottom: 0px;
  display: inline-block;
}

.featured-games .item span {
  color: #666;
  display: block;
  margin-top: 7px;
  font-weight: 400;
}

.featured-games .item ul {
  float: right;
  margin-top: 20px;
}

.featured-games .item ul li {
  text-align: right;
  color: #fff;
  font-size: 14px;
}

.featured-games .item ul li:first-child i {
  color: yellow;
}

.featured-games .item ul li:last-child i {
  color: var(--color-yellow);
}

.featured-games .owl-nav {
  position: absolute;
  margin: 0 auto;
  top: -70px;
  right: 0;
}

.featured-games .owl-nav .owl-prev {
  margin-right: 2.5px;
}

.featured-games .owl-nav .owl-next {
  margin-left: 2.5px;
}

.featured-games .owl-nav .owl-prev span,
.featured-games .owl-nav .owl-next span  {
  font-size: 36px;
  display: inline-block;
  color: #666;
  opacity: 1;
  transition: all .3s;
}

.featured-games .owl-nav .owl-prev span:hover,
.featured-games .owl-nav .owl-next span:hover {
  opacity: 1;
  color: var(--color-yellow);
}

.top-downloaded {
  border-radius: 23px;
  background-color: #1f2122;
  padding: 30px;
  max-height: 567px;
  min-height: 567px;
}

.top-downloaded ul li {
  position: relative;
  display: inline-block;
  width: 100%;
}

.top-downloaded ul li img {
  float: left;
  margin-right: 15px;
}

.top-downloaded ul li h4 {
  font-size: 15px;
  padding-top: 7px;
}

.top-downloaded ul li h6 {
  font-size: 15px;
  color: #666;
  font-weight: 400;
  margin-top: 5px;
  margin-bottom: 5px;
}

.top-downloaded ul li span {
  color: #fff;
  font-size: 15px;
  margin-right: 10px;
}

.top-downloaded ul li .download i {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-23px);
  width: 46px;
  height: 46px;
  text-align: center;
  line-height: 46px;
  color: var(--color-yellow);
  background-color: #27292a;
  border-radius: 50%;
}

.top-downloaded ul li {
  border-bottom: 1px solid #27292a;
  margin-bottom: 28px;
  padding-bottom: 28px;
}

.top-downloaded .text-button  {
  text-align: center;
}

.top-downloaded .text-button a {
  font-weight: 600;
  color: var(--color-yellow);
  font-size: 15px;
}

/* 
---------------------------------------------
Start Stream Style
--------------------------------------------- 
*/

.start-stream .heading-section {
  margin-top: 60px;
  text-align: center;
  margin-bottom: 60px;
}

.start-stream .item {
  padding: 30px;
  border: 1px solid #444;
  border-radius: 23px;
}

.start-stream .item h4 {
  font-size: 20px;
  margin-top: 20px;
  margin-bottom: 15px;
  font-weight: 600;
}

.start-stream .main-button {
  text-align: center;
  margin-top: 30px;
}

/* 
---------------------------------------------
Live Stream Style
--------------------------------------------- 
*/

.live-stream {
  margin-top: 60px;
  border-radius: 23px;
  background-color: #1f2122;
  padding: 30px;
}

.live-stream .item {
  margin-bottom: 30px;
}

.live-stream .thumb {
  position: relative;
  overflow: hidden;
  margin-bottom: 20px;
}

.live-stream .thumb img {
  border-radius: 23px; 
}

.live-stream .thumb:hover .hover-effect {
  opacity: 1;
  visibility: visible;
}

.live-stream .hover-effect {
  opacity: 0;
  visibility: hidden;
  transition: all .4s;
}

.live-stream .hover-effect .live a { 
  position: absolute;
  background-color: rgba(236, 96, 144, 0.9);
  padding: 5px 10px;
  border-radius: 23px;
  color: #fff;
  font-size: 14px;
  right: 15px;
  top: 15px;
}

.live-stream .hover-effect ul {
  position: absolute;
  bottom: 20px;
  text-align: center;
  width: 100%;
}

.live-stream .hover-effect ul li {
  display: inline-block;
  margin: 0px 5px;
}

.live-stream .hover-effect ul li a {
  background-color: rgba(236, 96, 144, 0.9);
  padding: 5px 10px;
  border-radius: 23px;
  color: #fff;
  font-size: 14px;
}

.live-stream .avatar img {
  margin-right: 15px;
}

.live-stream span i {
  color: #fff;
  background-color: var(--color-yellow);
  border-radius: 50%;
  font-size: 12px;
  width: 20px;
  height: 20px;
  display: inline-block;
  text-align: center;
  line-height: 20px;
  margin-right: 3px;
}

.live-stream span {
  font-size: 14px;
  color: var(--color-yellow);
}

.live-stream .down-content h4 {
  margin-top: 8px;
  font-size: 20px;
  font-weight: 700;
  margin-left: 61px;
}

.live-stream .main-button {
  text-align: center;
  margin-bottom: -53px;
}

/* 
---------------------------------------------
Featured Banner Style
--------------------------------------------- 
*/

.feature-banner .thumb {
  position: relative;
  max-height: 305px;
  overflow: hidden;
  border-radius: 23px;;
}

.feature-banner .thumb a {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-23px, -23px);
  width: 46px;
  height: 46px;
  background-color: #fff;
  border-radius: 50%;
  display: inline-block;
  text-align: center;
  line-height: 46px;
  color: var(--color-yellow);
}

/* 
---------------------------------------------
Game Details Style
--------------------------------------------- 
*/

.game-details h2 {
  font-size: 45px;
  text-transform: uppercase;
  text-align: center;
  margin: 60px 0px;
}

.game-details .content {
  border-radius: 23px;
  padding: 30px;
  background-color: #1f2122;
}

.game-details .content .left-info {
  background-color: #27292a;
  border-radius: 23px;
  padding: 30px;
  margin-bottom: 30px;
}

.game-details .content .left-info .left {
  float: left;
}

.game-details .content .left-info h4 {
  font-size: 15px;
  display: block;
}

.game-details .content .left-info span {
  color: #666;
  display: block;
  margin-top: 7px;
  font-weight: 400;
}

.game-details .content .left-info ul {
  text-align: right;
}

.game-details .content .left-info ul li {
  color: #fff;
  font-size: 14px;
  margin-bottom: 3px;
}

.game-details .content .left-info ul li:first-child i {
  color: yellow;
}

.game-details .content .left-info ul li:last-child i {
  color: var(--color-yellow);
}

.game-details .content .right-info {
  background-color: #27292a;
  border-radius: 23px;
  padding: 30px;
  margin-bottom: 30px;
}

.game-details .content .right-info ul li {
  display: inline-block;
  width: 23%;
  text-align: center;
  font-size: 14px;
  color: #fff;
}

.game-details .content .right-info ul li i {
  display: block;
  margin-bottom: 12px;
}

.game-details .content .right-info ul li:first-child i {
  color: yellow;
} 

.game-details .content .right-info ul li i {
  color: var(--color-yellow);
}

.game-details .main-border-button {
  margin-top: 35px;
}

.game-details .main-border-button a {
  text-align: center;
  width: 100%;
} 

/* 
---------------------------------------------
Other Related Style
--------------------------------------------- 
*/

.other-games {
  border-radius: 23px;
  padding: 30px 30px 0px 30px;
  background-color: #1f2122;
  margin-top: 60px;
}

.other-games .item {
  position: relative;
  border-bottom: 1px solid #27292a;
  padding-bottom: 52px;
  margin-bottom: 30px;
}

.other-games .item img {
  float: left;
  margin-right: 15px;
}

.other-games .item h4 {
  display: inline-block;
  font-size: 15px;
  margin-bottom: 5px;
  padding-top: 15px;
}

.other-games .item span {
  color: #666;
  font-size: 14px;
  display: block;
}

.other-games ul {
  position: absolute;
  right: 0;
  top: 15px;
}

.other-games ul li {
  color: #fff;
  font-size: 14px;
  margin-bottom: 3px;
}

.other-games ul li:first-child i {
  color: yellow;
}

.other-games ul li:last-child i {
  color: var(--color-yellow);
}

/* 
---------------------------------------------
Top Streamers Style
--------------------------------------------- 
*/

.top-streamers {
  border-radius: 23px;
  background-color: #1f2122;
  padding: 30px;
  max-height: 567px;
  min-height: 567px;
}

.top-streamers ul li {
  display: inline-block;
  width: 100%;
  border-bottom: 1px solid #353637;
  margin-bottom: 25px;
  padding-bottom: 25px;
}

.top-streamers ul li:last-child {
  border-bottom: none;
  padding-bottom: 0px;
  margin-bottom: 0px;
}

.top-streamers ul li span {
  float: left;
  font-size: 15px;
  color: #fff;
  font-weight: 700;
  padding-top: 12px;
  margin-right: 10px;
}

.top-streamers ul li h6 {
  display: inline;
  font-size: 14px;
  color: var(--color-yellow);
  font-weight: 400;
}

.top-streamers ul li h6 i {
  color: #fff;
  background-color: var(--color-yellow);
  border-radius: 50%;
  font-size: 12px;
  width: 20px;
  height: 20px;
  display: inline-block;
  text-align: center;
  line-height: 20px;
  margin-right: 3px;
}

.top-streamers ul li .main-button {
  float: right;
}

.top-streamers ul li .main-button a {
  padding: 8px 20px;
}

/* 
---------------------------------------------
Profile Style
--------------------------------------------- 
*/

.main-profile {
  border-radius: 23px;
  padding: 30px;
  background-color: #1f2122;
}

.main-profile .main-info span {
  font-size: 14px;
  color: #fff;
  background-color: var(--color-green);
  padding: 8px 20px;
  display: inline-block;
  border-radius: 25px;
  font-weight: 400;
  text-transform: capitalize;
  letter-spacing: 0.5px;
  margin-bottom: 15px;
}

.main-profile .main-info h4 {
  margin-bottom: 20px;
}

.main-profile .main-info .main-border-button {
  margin-top: 25px;
}

.main-profile ul {
  border-radius: 23px;
  padding: 30px;
  background-color: #27292a;
}

.main-profile ul li {
  width: 100%;
  font-size: 14px;
  color: #666;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid #666;
}

.main-profile ul li span {
  float: right;
  font-weight: 500;
  color: var(--color-yellow);
}

.main-profile ul li:last-child {
  border-bottom: none;
  padding-bottom: 0;
  margin-bottom: 0;
}

.clips {
  margin-top: 30px;
  border-top: 2px solid #27292a;
}

.clips .heading-section {
  margin-top: 30px;
}

.clips .item  {
  border-radius: 23px;
  padding: 30px 15px;
  background-color: #27292a;
  margin-bottom: 30px;
}

.clips .item .thumb {
  position: relative;
  margin-bottom: 15px;
}

.clips .item .thumb a {
  position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-23px, -23px);
    width: 46px;
    height: 46px;
    background-color: #fff;
    border-radius: 50%;
    display: inline-block;
    text-align: center;
    line-height: 46px;
    color: var(--color-yellow);
}

.clips .item h4 {
  font-size: 15px;
  display: inline-block;
}

.clips .item span i {
  color: var(--color-yellow);
}

.clips .item span {
  float: right;
  color: #fff;
  font-size: 14px;
}

.clips .main-button {
  margin-top: 10px;
  text-align: center;
}

/* 
---------------------------------------------
Responsive Style
--------------------------------------------- 
*/

body {
  overflow-x: hidden;
}

@media (max-width: 767px) {
  body .page-content {
    padding: 0px 30px;
  }
  .main-banner {
    text-align: center;
  }
  .main-banner h4 {
    font-size: 35px;
  }
  .gaming-library .item ul li,
  .gaming-library .item ul li:first-child,
  .gaming-library .item ul li:last-child {
    width: 100% !important;
    text-align: center !important;
  }
  .gaming-library .item ul li {
    margin-top: 30px;
  }
  .top-downloaded ul li .download i {
    top: 20px;
    width: 30px;
    height: 30px;
    line-height: 30px;
  }
  .top-downloaded ul li img {
    margin-right: 10px;
  }
  .top-downloaded ul li span {
    font-size: 14px;
  }
  .top-streamers ul li .main-button {
    float: none;
    margin-top: 10px;
  }
  .top-streamers ul li .main-button a {
    width: 100%;
    text-align: center;
  }
  .top-streamers,
  .top-downloaded {
    max-height: 100%;
    min-height: 100%;
  }
  .most-popular .item .inner-item {
    margin-bottom: 20px;
  }
}

@media (max-width: 992px) {
  .background-header {
  display: inline-block;
  }
  .header-area .main-nav #search {
    display: none;
  }
  .heading-section h4 {
    font-size: 20px;
  }
  .gaming-library .item ul li {
    width: 48% !important;
  }
  .gaming-library .item ul li:last-child {
    text-align: left;
  }
  .featured-games {
    margin-bottom: 60px;
  }
  .start-stream .item {
    margin: 15px 0px;
  }
  .feature-banner .thumb {
    margin-top: 30px;
  }
  .main-profile .main-info {
    margin: 45px 0px;
  }
}

@media (max-width: 1200px) {
  .header-area .main-nav .nav li {
    padding-right: 5px;
    padding-left: 5px;
  }
  .header-area .main-nav .logo {
    margin-right: 30px;
    border-right: none;
  }
  .gaming-library .item ul li {
    width: 16%;
  }
}

/* ==========================================================================
   Antigravity Premium Modern Overrides (Selva Viva Glassmorphism & Micro-animations)
   ========================================================================== */

/* Modernizing Headings with beautiful gradient */
.heading-section h4 {
  color: var(--color-green) !important;
  font-weight: 800 !important;
  letter-spacing: 0.5px;
  position: relative;
  display: inline-block;
}

.heading-section h4 em {
  color: var(--color-yellow) !important;
  font-style: normal !important;
  text-decoration: none !important;
  background: linear-gradient(135deg, var(--color-yellow) 0%, #fff 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 800;
}

/* Glassmorphism & Hover effects for Cards in dependencies/popular/library */
.most-popular .item, 
.gaming-library .item, 
.featured-games .item, 
.other-games .item, 
.start-stream .item, 
.live-stream .item,
.top-streamers ul li,
.top-downloaded ul li {
  background: rgba(255, 255, 255, 0.02) !important;
  border: 1px solid rgba(0, 149, 76, 0.12) !important;
  border-radius: 20px !important;
  padding: 24px !important;
  transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) !important;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
}

.most-popular .item:hover, 
.gaming-library .item:hover, 
.featured-games .item:hover, 
.other-games .item:hover, 
.start-stream .item:hover, 
.live-stream .item:hover {
  transform: translateY(-8px);
  background: rgba(0, 149, 76, 0.06) !important;
  border-color: var(--color-yellow) !important;
  box-shadow: 0 15px 35px var(--color-green-glow);
}

/* Item image adjustments */
.most-popular .item img, 
.featured-games .item img, 
.live-stream .item img {
  border-radius: 16px !important;
  transition: all 0.4s ease;
}

.most-popular .item:hover img, 
.featured-games .item:hover img, 
.live-stream .item:hover img {
  transform: scale(1.03);
}

/* Custom buttons premium overrides */
.main-button a {
  background: linear-gradient(135deg, var(--color-green) 0%, #007038 100%) !important;
  border: 1px solid rgba(242, 235, 11, 0.2) !important;
  box-shadow: 0 4px 15px var(--color-green-glow) !important;
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1) !important;
  color: #fff !important;
  font-weight: 600 !important;
}

.main-button a:hover {
  background: linear-gradient(135deg, var(--color-yellow) 0%, #d8d208 100%) !important;
  color: #07140e !important;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px var(--color-yellow-glow) !important;
  border-color: var(--color-yellow) !important;
}

.main-border-button a {
  border: 2px solid var(--color-green) !important;
  color: var(--color-green) !important;
  background: transparent !important;
  font-weight: 600 !important;
  transition: all 0.3s ease !important;
}

.main-border-button a:hover {
  background: var(--color-green) !important;
  color: #fff !important;
  box-shadow: 0 5px 15px var(--color-green-glow) !important;
}

/* Header links and sticky styling */
.header-area .main-nav .nav li a {
  color: #a4bfae !important;
  transition: all 0.3s ease !important;
}

.header-area .main-nav .nav li a.active,
.header-area .main-nav .nav li a:hover {
  color: var(--color-yellow) !important;
  background: rgba(0, 149, 76, 0.12) !important;
}

.background-header {
  background: rgba(7, 20, 14, 0.85) !important;
  backdrop-filter: blur(15px) !important;
  border-bottom: 1px solid var(--color-border) !important;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.4) !important;
}

/* Search bar styling */
.header-area .main-nav #search input {
  background-color: rgba(255, 255, 255, 0.05) !important;
  border: 1px solid var(--color-border) !important;
  color: var(--color-text-main) !important;
  transition: all 0.3s ease;
}

.header-area .main-nav #search input:focus {
  border-color: var(--color-yellow) !important;
  box-shadow: 0 0 10px var(--color-green-glow) !important;
  outline: none;
}

.header-area .main-nav #search i {
  color: var(--color-green) !important;
}

/* Preloader custom modern theme */
.preloader-inner .dot {
  background: var(--color-yellow) !important;
  box-shadow: 0 0 15px var(--color-yellow-glow);
}

.preloader-inner .dots span {
  background: var(--color-green) !important;
  box-shadow: 0 0 15px var(--color-green-glow);
}

/* Footer layout modernizer */
footer p {
  color: var(--color-text-muted) !important;
}

footer p a {
  color: var(--color-yellow) !important;
  transition: all 0.3s ease;
}

footer p a:hover {
  color: var(--color-green) !important;
  text-decoration: underline !important;
}

/* Main Banner Overrides with deep green overlay */
.main-banner {
  background: linear-gradient(rgba(7, 20, 14, 0.3), rgba(7, 20, 14, 0.85)), url("../images/banner-bg.jpg") !important;
  background-position: center center !important;
  background-size: cover !important;
  border: 1px solid var(--color-border);
  box-shadow: 0 15px 40px rgba(0,0,0,0.3);
}

.main-banner h4 {
  font-weight: 900 !important;
  letter-spacing: 1px;
}

.main-banner h4 em {
  font-style: normal;
  color: var(--color-yellow);
}

/* Top downloaded specific modernizations */
.top-downloaded ul li, .top-streamers ul li {
  margin-bottom: 15px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* Details page customized */
.game-details h2 {
  color: var(--color-yellow) !important;
  font-weight: 800;
}

.game-details .content {
  background-color: rgba(255, 255, 255, 0.02) !important;
  border: 1px solid var(--color-border) !important;
}

.game-details .left-info, .game-details .right-info {
  background-color: rgba(0, 149, 76, 0.05) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 15px;
  padding: 20px !important;
}

/* ==========================================================================
   Antigravity Premium Interactive Features Styling (Floating Contact Form, Sliders & Map)
   ========================================================================== */

/* Floating Contact Button */
#floating-contact-btn {
  position: fixed;
  bottom: 30px;
  right: 30px;
  width: 60px;
  height: 60px;
  background: linear-gradient(135deg, var(--color-green) 0%, #007038 100%);
  border: 2px solid var(--color-yellow);
  border-radius: 50%;
  color: #fff;
  font-size: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 9999;
  box-shadow: 0 5px 25px var(--color-green-glow);
  transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

#floating-contact-btn:hover {
  transform: scale(1.1) rotate(15deg);
  box-shadow: 0 8px 30px var(--color-yellow-glow);
  background: linear-gradient(135deg, var(--color-yellow) 0%, #d8d208 100%);
  color: #07140e;
}

#floating-whatsapp-btn {
  position: fixed;
  bottom: 170px;
  right: 30px;
  width: 60px;
  height: 60px;
  background: #25D366;
  border: 2px solid #128C7E;
  border-radius: 50%;
  color: #fff;
  font-size: 26px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 10000;
  box-shadow: 0 5px 25px rgba(37, 211, 102, 0.35);
  transition: all 0.3s ease;
  text-decoration: none;
}

#floating-whatsapp-btn:hover {
  transform: scale(1.08);
  box-shadow: 0 8px 30px rgba(37, 211, 102, 0.45);
}

/* Floating Contact Panel (Glassmorphism) */
#contact-floating-panel {
  position: fixed;
  bottom: 105px;
  right: 30px;
  width: 360px;
  max-width: 90vw;
  background: rgba(10, 20, 15, 0.92) !important;
  backdrop-filter: blur(25px) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 24px;
  padding: 30px;
  z-index: 9998;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.5);
  display: none;
  opacity: 0;
  transform: translateY(30px) scale(0.9);
  transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}

#contact-floating-panel.active {
  display: block;
  opacity: 1;
  transform: translateY(0) scale(1);
}

#contact-floating-panel h4 {
  font-size: 20px;
  margin-bottom: 5px;
  color: var(--color-yellow);
}

#contact-floating-panel p {
  font-size: 13px;
  color: #a4bfae;
  line-height: 20px;
  margin-bottom: 20px;
}

#contact-floating-panel .close-btn {
  position: absolute;
  top: 20px;
  right: 20px;
  color: #a4bfae;
  cursor: pointer;
  font-size: 18px;
  transition: color 0.3s ease;
}

#contact-floating-panel .close-btn:hover {
  color: var(--color-yellow);
}

#contact-floating-panel .form-group {
  margin-bottom: 15px;
}

#contact-floating-panel label {
  display: block;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: #a4bfae;
  margin-bottom: 5px;
}

#contact-floating-panel input,
#contact-floating-panel select,
#contact-floating-panel textarea {
  width: 100%;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--color-border);
  border-radius: 12px;
  padding: 10px 15px;
  color: var(--color-text-main);
  font-size: 14px;
  outline: none;
  transition: all 0.3s ease;
}

#contact-floating-panel input:focus,
#contact-floating-panel select:focus,
#contact-floating-panel textarea:focus {
  border-color: var(--color-yellow);
  box-shadow: 0 0 8px var(--color-green-glow);
  background: rgba(255, 255, 255, 0.08);
}

#contact-floating-panel textarea {
  resize: none;
  height: 80px;
}

#contact-floating-panel button {
  width: 100%;
  background: linear-gradient(135deg, var(--color-green) 0%, #007038 100%);
  border: 1px solid rgba(242, 235, 11, 0.2);
  color: #fff;
  border-radius: 14px;
  padding: 12px;
  font-weight: bold;
  cursor: pointer;
  transition: all 0.3s ease;
  box-shadow: 0 4px 15px var(--color-green-glow);
}

#contact-floating-panel button:hover {
  background: linear-gradient(135deg, var(--color-yellow) 0%, #d8d208 100%);
  color: #07140e;
  border-color: var(--color-yellow);
  box-shadow: 0 6px 20px var(--color-yellow-glow);
}

#contact-floating-panel .success-message {
  display: none;
  text-align: center;
  padding: 30px 10px;
}

#contact-floating-panel .success-message i {
  font-size: 48px;
  color: var(--color-yellow);
  margin-bottom: 15px;
  animation: scaleUp 0.5s ease;
}

@keyframes scaleUp {
  0% { transform: scale(0); }
  100% { transform: scale(1); }
}

/* Premium Range Sliders for Calculator */
.calc-card {
  background: rgba(255, 255, 255, 0.02) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 24px;
  padding: 30px;
  margin-top: 40px;
  box-shadow: 0 15px 40px rgba(0, 0, 0, 0.3);
}

.calc-title h3 {
  color: var(--color-yellow) !important;
  font-weight: 800;
  margin-bottom: 20px;
}

.slider-container {
  margin-bottom: 25px;
}

.slider-header {
  display: flex;
  justify-content: space-between;
  margin-bottom: 8px;
  font-size: 14px;
}

.slider-header span.label {
  color: #a4bfae;
  font-weight: 600;
}

.slider-header span.value {
  color: var(--color-yellow);
  font-weight: 800;
  font-size: 16px;
}

.calc-slider {
  -webkit-appearance: none;
  width: 100%;
  height: 8px;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.1);
  outline: none;
  transition: background 0.3s;
}

.calc-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--color-yellow);
  border: 2px solid var(--color-green);
  cursor: pointer;
  box-shadow: 0 0 10px var(--color-yellow-glow);
  transition: transform 0.2s;
}

.calc-slider::-webkit-slider-thumb:hover {
  transform: scale(1.2);
}

.calc-select {
  width: 100%;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--color-border);
  border-radius: 12px;
  padding: 12px 15px;
  color: var(--color-text-main);
  outline: none;
  cursor: pointer;
  font-weight: 600;
}

.calc-result-card {
  background: rgba(0, 149, 76, 0.05) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 20px;
  padding: 25px;
  text-align: center;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  transition: all 0.3s ease;
}

.calc-result-card:hover {
  border-color: var(--color-yellow) !important;
  box-shadow: 0 10px 25px var(--color-green-glow);
}

.calc-result-card h5 {
  font-size: 13px;
  color: #a4bfae;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 10px;
}

.calc-result-card span.main-num {
  font-size: 32px;
  font-weight: 900;
  color: var(--color-yellow);
  display: block;
}

.calc-result-card span.sub-unit {
  font-size: 12px;
  color: #8fa394;
  margin-top: 5px;
  display: block;
}

/* Pulsing map pin styling */
.map-container {
  background: rgba(255, 255, 255, 0.02) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 24px;
  padding: 30px;
  margin-top: 40px;
}

.map-svg {
  width: 100%;
  height: auto;
  max-height: 450px;
  border-radius: 15px;
  background: rgba(7, 20, 14, 0.3);
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.map-region {
  fill: rgba(0, 149, 76, 0.08);
  stroke: rgba(0, 149, 76, 0.3);
  stroke-width: 2px;
  transition: all 0.4s ease;
}

.map-region:hover {
  fill: rgba(0, 149, 76, 0.2);
  stroke: var(--color-yellow);
}

.map-pin {
  fill: var(--color-yellow);
  stroke: #07140e;
  stroke-width: 2px;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.map-pin:hover {
  fill: var(--color-green);
  transform: scale(1.3);
}

.map-pin-pulse {
  animation: mapPulse 2s infinite;
  transform-origin: center;
}

@keyframes mapPulse {
  0% {
    r: 6px;
    opacity: 1;
    stroke: var(--color-yellow);
    stroke-width: 1px;
  }
  100% {
    r: 20px;
    opacity: 0;
    stroke: var(--color-green);
    stroke-width: 3px;
  }
}

.map-tooltip {
  background: rgba(10, 20, 15, 0.9);
  backdrop-filter: blur(10px);
  border: 1px solid var(--color-border);
  border-radius: 16px;
  padding: 20px;
  margin-top: 15px;
  display: none;
  animation: fadeIn 0.3s ease;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ==========================================================================
   Portal de Software SV Lab Alignment Fix (Flexbox Modernization)
   ========================================================================== */

.gaming-library .item ul {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  width: 100% !important;
  flex-wrap: wrap !important; /* Allow wrapping on small mobile screens */
  padding: 0 !important;
  margin: 0 !important;
}

.gaming-library .item ul li {
  display: block !important;
  vertical-align: middle !important;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  padding: 5px !important;
}

.gaming-library .item ul li img {
  margin-top: 0 !important;
  vertical-align: middle !important;
}

.gaming-library .item ul li:last-child {
  text-align: right !important;
}

.gaming-library .item ul li:last-child a {
  padding: 8px 20px !important;
  font-size: 13px !important;
  white-space: nowrap !important;
}

@media (max-width: 768px) {
  .gaming-library .item ul {
    flex-direction: column !important;
    text-align: center !important;
    align-items: center !important;
  }
  .gaming-library .item ul li {
    width: 100% !important;
    text-align: center !important;
    margin-bottom: 10px !important;
  }
  .gaming-library .item ul li:last-child {
    text-align: center !important;
  }
}

/* ==========================================================================
   Portal de Software (Gaming Library) Container and Item Overrides
   ========================================================================== */

/* Outer container made into a unified premium glassmorphic card */
.gaming-library {
  background: rgba(255, 255, 255, 0.015) !important;
  border: 1px solid rgba(0, 149, 76, 0.15) !important;
  border-radius: 23px !important;
  padding: 40px 30px 30px 30px !important;
  margin-top: 60px !important;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.4) !important;
  position: relative !important;
}

/* Individual rows un-styled from cards to transparent rows with clean bottom dividers */
.gaming-library .item {
  background: transparent !important;
  border: none !important;
  border-bottom: 1px solid rgba(0, 149, 76, 0.12) !important;
  border-radius: 0 !important;
  padding: 20px 10px !important;
  margin-bottom: 0 !important;
  box-shadow: none !important;
  transition: all 0.3s ease !important;
  transform: none !important;
}

/* Force image backgrounds to be completely transparent to avoid any solid green/gray block glitches */
.gaming-library .item img,
.gaming-library .item ul li img {
  background: transparent !important;
  box-shadow: none !important;
}

/* Interactive highlight on row hover - subtle crystal glow instead of opaque green */
.gaming-library .item:hover {
  background: rgba(255, 255, 255, 0.04) !important;
  border-color: rgba(242, 235, 11, 0.2) !important;
  border-radius: 12px !important;
  transform: scale(1.01) !important;
  box-shadow: 0 5px 15px rgba(242, 235, 11, 0.03) !important;
}

/* Last item in the list removes border divider and has margins for the button */
.gaming-library .last-item {
  border-bottom: none !important;
  margin-bottom: 35px !important;
}

/* Keep profile specific last-item override clean */
.profile-library .last-item {
  border-bottom: none !important;
  padding-bottom: 10px !important;
  margin-bottom: 0px !important;
}

/* Add margin-top to the library main button when it sits under the profile-library styling */
.gaming-library .main-button {
  margin-top: 35px !important;
}

/* ==========================================================================
   Modernized Nuestros Servicios (Streams.html Grid Overrides)
   ========================================================================== */

/* Modern Grid Card for Services */
.service-card-modern {
  background: rgba(255, 255, 255, 0.015) !important;
  border: 1px solid rgba(0, 149, 76, 0.12) !important;
  border-radius: 24px !important;
  padding: 30px !important;
  height: 100% !important;
  position: relative !important;
  overflow: hidden !important;
  transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15) !important;
}

/* Floating Icon on the Top-Right */
.service-icon-floating {
  position: absolute !important;
  top: -10px !important;
  right: -10px !important;
  width: 70px !important;
  height: 70px !important;
  background: linear-gradient(135deg, rgba(0, 149, 76, 0.15) 0%, rgba(0, 149, 76, 0.02) 100%) !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: all 0.4s ease !important;
  border: 1px solid rgba(0, 149, 76, 0.08) !important;
}

.service-icon-floating i {
  font-size: 20px !important;
  color: var(--color-green) !important;
  margin-top: 10px !important;
  margin-right: 10px !important;
  transition: all 0.4s ease !important;
}

/* Logo image container */
.service-card-modern .thumb {
  text-align: center !important;
  margin-bottom: 25px !important;
}

.service-logo-img {
  height: 130px !important;
  object-fit: contain !important;
  background: rgba(255, 255, 255, 0.02) !important;
  border: 1px solid rgba(255, 255, 255, 0.05) !important;
  border-radius: 20px !important;
  padding: 15px !important;
  transition: all 0.4s ease !important;
  width: auto !important;
  display: inline-block !important;
}

/* Typography Inside Content */
.service-content h4 {
  font-size: 18px !important;
  font-weight: 700 !important;
  color: #fff !important;
  margin-bottom: 5px !important;
}

.service-sub {
  font-size: 12px !important;
  text-transform: uppercase !important;
  color: var(--color-yellow) !important;
  font-weight: 600 !important;
  letter-spacing: 0.5px !important;
  display: block !important;
  margin-bottom: 15px !important;
}

.service-content p {
  font-size: 13.5px !important;
  line-height: 22px !important;
  color: #a4bfae !important;
  margin-bottom: 20px !important;
}

/* ver detalles link */
.service-card-link {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--color-green) !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  transition: all 0.3s ease !important;
  text-decoration: none !important;
}

.service-card-link i {
  font-size: 11px !important;
  transition: transform 0.3s ease !important;
}

/* Hover effects */
.service-card-modern:hover {
  transform: translateY(-10px) !important;
  border-color: var(--color-yellow) !important;
  background: rgba(0, 149, 76, 0.04) !important;
  box-shadow: 0 15px 30px rgba(0, 149, 76, 0.08) !important;
}

.service-card-modern:hover .service-icon-floating {
  background: linear-gradient(135deg, var(--color-yellow) 0%, rgba(242, 235, 11, 0.1) 100%) !important;
  border-color: rgba(242, 235, 11, 0.3) !important;
}

.service-card-modern:hover .service-icon-floating i {
  color: #07140e !important;
  transform: scale(1.1) rotate(-15deg) !important;
}

.service-card-modern:hover .service-logo-img {
  transform: scale(1.05) !important;
  border-color: rgba(242, 235, 11, 0.15) !important;
}

.service-card-modern:hover .service-card-link {
  color: var(--color-yellow) !important;
}

.service-card-modern:hover .service-card-link i {
  transform: translateX(5px) !important;
}

/* ==========================================================================
   Peru Map & Zoom Components
   ========================================================================== */
.map-reset-btn {
  position: absolute !important;
  top: 95px !important;
  left: 45px !important;
  background: rgba(7, 20, 14, 0.9) !important;
  border: 1px solid var(--color-border) !important;
  padding: 8px 16px !important;
  border-radius: 12px !important;
  color: var(--color-yellow) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  z-index: 10 !important;
  transition: all 0.3s ease !important;
  display: none; /* Initially hidden */
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3) !important;
}

.map-reset-btn:hover {
  background: var(--color-yellow) !important;
  color: #07140e !important;
  border-color: var(--color-yellow) !important;
  transform: translateY(-1px) !important;
}

/* Peru Map Regions */
.map-region-peru {
  fill: rgba(0, 149, 76, 0.05);
  stroke: rgba(0, 149, 76, 0.2);
  stroke-width: 1.5px;
  transition: all 0.3s ease;
  cursor: pointer;
}

.map-region-peru:hover {
  fill: rgba(0, 149, 76, 0.15);
  stroke: var(--color-yellow);
}

.active-region-peru {
  fill: rgba(0, 149, 76, 0.1) !important;
  stroke: var(--color-green) !important;
  stroke-width: 2px !important;
  animation: borderGlow 2s infinite alternate;
}

@keyframes borderGlow {
  0% { stroke: rgba(0, 149, 76, 0.5); }
  100% { stroke: var(--color-yellow); }
}

/* Map project pins and layers */
.map-pins-layer {
  opacity: 0;
  transition: opacity 0.5s ease;
  pointer-events: none; /* Disabled when zoomed out */
}

.map-pins-layer.active {
  opacity: 1;
  pointer-events: auto; /* Enabled when zoomed in */
}

/* Regional outline overlay */
.map-peru-outline {
  stroke: rgba(255, 255, 255, 0.06);
  stroke-width: 1.5px;
  fill: none;
  pointer-events: none;
}

/* ==========================================================================
   Product Detail & G-Costos Modernization Styles
   ========================================================================== */

.product-hero-card {
  background: rgba(255, 255, 255, 0.015) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 30px !important;
  padding: 40px !important;
  margin-bottom: 40px !important;
  overflow: hidden !important;
  position: relative !important;
  background-image: linear-gradient(rgba(0, 149, 76, 0.03) 1px, transparent 1px), 
                    linear-gradient(90deg, rgba(0, 149, 76, 0.03) 1px, transparent 1px) !important;
  background-size: 20px 20px !important;
}

.product-badge-pill {
  display: inline-flex;
  align-items: center;
  background: rgba(0, 149, 76, 0.08) !important;
  border: 1px solid rgba(0, 149, 76, 0.2) !important;
  color: var(--color-green) !important;
  padding: 6px 16px !important;
  border-radius: 30px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  margin-bottom: 20px !important;
}

.product-hero-card h2 {
  font-size: 40px !important;
  font-weight: 800 !important;
  margin-bottom: 20px !important;
  color: #fff !important;
  line-height: 1.2 !important;
}

.product-hero-card h2 em {
  font-style: normal !important;
  color: var(--color-yellow) !important;
}

.product-hero-card p {
  color: #a4bfae !important;
  font-size: 15px !important;
  line-height: 28px !important;
  margin-bottom: 30px !important;
}

.product-metric-pill {
  display: inline-flex;
  align-items: center;
  background: rgba(255, 255, 255, 0.02) !important;
  border: 1px solid rgba(255, 255, 255, 0.05) !important;
  padding: 8px 16px !important;
  border-radius: 20px !important;
  margin-right: 12px !important;
  margin-bottom: 12px !important;
  font-size: 13px !important;
  color: #fff !important;
  font-weight: 500 !important;
}

.product-metric-pill i {
  margin-right: 8px !important;
}

/* Glassmorphic Dashboard Mockup */
.dashboard-mockup {
  background: rgba(10, 25, 18, 0.6) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  border-radius: 20px !important;
  padding: 20px !important;
  position: relative !important;
  box-shadow: 0 20px 45px rgba(0, 0, 0, 0.4) !important;
  height: 310px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  overflow: hidden !important;
}

.dashboard-mockup::before {
  content: '';
  position: absolute;
  top: -50px;
  right: -50px;
  width: 150px;
  height: 150px;
  background: rgba(242, 235, 11, 0.05);
  filter: blur(40px);
  border-radius: 50%;
  pointer-events: none;
}

.dashboard-mockup::after {
  content: '';
  position: absolute;
  bottom: -50px;
  left: -50px;
  width: 150px;
  height: 150px;
  background: rgba(0, 149, 76, 0.1);
  filter: blur(40px);
  border-radius: 50%;
  pointer-events: none;
}

.dashboard-header-mock {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
  padding-bottom: 10px !important;
  margin-bottom: 15px !important;
}

.dashboard-dots {
  display: flex !important;
  gap: 6px !important;
}

.dashboard-dot {
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
}

.dashboard-table-mock {
  width: 100% !important;
  font-size: 11px !important;
  color: #a4bfae !important;
  flex-grow: 1 !important;
}

.dashboard-row-mock {
  display: flex !important;
  justify-content: space-between !important;
  padding: 8px 0 !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.03) !important;
}

.dashboard-row-mock.header-mock {
  color: #fff !important;
  font-weight: 600 !important;
  border-bottom: 1px solid rgba(0, 149, 76, 0.2) !important;
}

.dashboard-chart-mock {
  height: 70px !important;
  display: flex !important;
  align-items: flex-end !important;
  gap: 8px !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
  padding-bottom: 5px !important;
  margin-top: 10px !important;
}

.dashboard-bar-mock {
  flex-grow: 1 !important;
  background: rgba(0, 149, 76, 0.15) !important;
  border: 1px solid rgba(0, 149, 76, 0.3) !important;
  border-radius: 3px 3px 0 0 !important;
  transition: all 0.5s ease !important;
}

.dashboard-bar-mock.active-bar {
  background: rgba(242, 235, 11, 0.2) !important;
  border-color: rgba(242, 235, 11, 0.5) !important;
}

.dashboard-video-overlay {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  background: rgba(7, 20, 14, 0.5) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  opacity: 0 !important;
  transition: all 0.3s ease !important;
  z-index: 5 !important;
  cursor: pointer !important;
}

.dashboard-mockup:hover .dashboard-video-overlay {
  opacity: 1 !important;
  backdrop-filter: blur(3px) !important;
}

.dashboard-video-overlay i {
  font-size: 50px !important;
  color: var(--color-yellow) !important;
  text-shadow: 0 0 15px rgba(242, 235, 11, 0.5) !important;
  transition: all 0.3s ease !important;
}

.dashboard-video-overlay:hover i {
  transform: scale(1.15) !important;
}

/* Core Features Modern Grid */
.product-feature-card-modern {
  background: rgba(255, 255, 255, 0.012) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 20px !important;
  padding: 30px !important;
  height: 100% !important;
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1) !important;
  text-align: center !important;
  position: relative !important;
  overflow: hidden !important;
}

.product-feature-card-modern::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, rgba(0,149,76,0.03) 0%, transparent 100%);
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
}

.product-feature-card-modern:hover::before {
  opacity: 1;
}

.product-feature-card-modern:hover {
  transform: translateY(-6px) !important;
  border-color: var(--color-yellow) !important;
  box-shadow: 0 8px 25px rgba(0, 149, 76, 0.08) !important;
}

.product-feature-card-modern i {
  font-size: 40px !important;
  transition: all 0.3s ease !important;
  display: inline-block !important;
}

.product-feature-card-modern:hover i {
  transform: scale(1.1) rotate(10deg) !important;
}

.product-feature-card-modern h5 {
  font-size: 18px !important;
  font-weight: 700 !important;
  color: #fff !important;
  margin-top: 20px !important;
  margin-bottom: 12px !important;
}

.product-feature-card-modern p {
  font-size: 13px !important;
  color: #8fa394 !important;
  line-height: 20px !important;
  margin-bottom: 0 !important;
}

/* Simulator Modern Card overrides */
.calc-card {
  background: rgba(255, 255, 255, 0.015) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 24px !important;
  padding: 40px !important;
  margin-top: 40px !important;
  margin-bottom: 40px !important;
}

.calc-slider {
  -webkit-appearance: none !important;
  width: 100% !important;
  height: 6px !important;
  border-radius: 3px !important;
  background: rgba(255, 255, 255, 0.1) !important;
  outline: none !important;
  margin: 15px 0 !important;
  transition: background 0.3s ease !important;
}

.calc-slider::-webkit-slider-thumb {
  -webkit-appearance: none !important;
  width: 16px !important;
  height: 16px !important;
  border-radius: 50% !important;
  background: var(--color-yellow) !important;
  cursor: pointer !important;
  box-shadow: 0 0 10px rgba(242, 235, 11, 0.8) !important;
  transition: transform 0.1s ease !important;
}

.calc-slider::-webkit-slider-thumb:hover {
  transform: scale(1.2) !important;
}

.calc-select {
  background: rgba(7, 20, 14, 0.6) !important;
  border: 1px solid var(--color-border) !important;
  color: #fff !important;
  border-radius: 12px !important;
  padding: 12px 20px !important;
  width: 100% !important;
  outline: none !important;
  font-size: 14px !important;
  margin-top: 10px !important;
  transition: all 0.3s ease !important;
}

.calc-select:focus {
  border-color: var(--color-green) !important;
  box-shadow: 0 0 8px rgba(0, 149, 76, 0.2) !important;
}

.calc-result-card-modern {
  background: rgba(0, 149, 76, 0.02) !important;
  border: 1px solid rgba(0, 149, 76, 0.12) !important;
  border-radius: 18px !important;
  padding: 20px !important;
  text-align: center !important;
  height: 100% !important;
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1) !important;
}

.calc-result-card-modern:hover {
  border-color: var(--color-yellow) !important;
  background: rgba(0, 149, 76, 0.05) !important;
  box-shadow: 0 8px 20px rgba(242, 235, 11, 0.04) !important;
  transform: translateY(-4px) !important;
}

.calc-result-card-modern h5 {
  font-size: 13px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  color: #8fa394 !important;
  margin-bottom: 8px !important;
}

.calc-result-card-modern .main-num {
  font-size: 22px !important;
  font-weight: 800 !important;
  color: #fff !important;
  display: block !important;
  margin-bottom: 4px !important;
}

.calc-result-card-modern .sub-unit {
  font-size: 11px !important;
  color: #a4bfae !important;
}

/* Related Systems Modern Grid */
.related-system-card-modern {
  background: rgba(255, 255, 255, 0.015) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 16px !important;
  padding: 20px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1) !important;
  height: 100% !important;
}

.related-system-card-modern:hover {
  transform: translateY(-4px) !important;
  border-color: var(--color-yellow) !important;
  background: rgba(255, 255, 255, 0.03) !important;
  box-shadow: 0 6px 20px rgba(242, 235, 11, 0.03) !important;
}

.related-system-card-modern img {
  border-radius: 10px !important;
  transition: transform 0.3s ease !important;
}

.related-system-card-modern:hover img {
  transform: scale(1.05) !important;
}

.related-system-card-modern h4 {
  font-size: 16px !important;
  font-weight: 700 !important;
  color: #fff !important;
  margin-bottom: 2px !important;
}

.related-system-card-modern span {
  font-size: 12px !important;
  color: #8fa394 !important;
}

/* Neon status LED indicators */
.status-led {
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  display: inline-block !important;
  margin-right: 6px !important;
  vertical-align: middle !important;
}

.led-green {
  background-color: var(--color-green) !important;
  box-shadow: 0 0 8px var(--color-green) !important;
}

.led-yellow {
  background-color: var(--color-yellow) !important;
  box-shadow: 0 0 8px var(--color-yellow) !important;
}

.led-pulse {
  animation: ledPulse 1.5s infinite alternate !important;
}

@keyframes ledPulse {
  0% { opacity: 0.4; }
  100% { opacity: 1; }
}

/* Glowing product badge tags */
.product-badge-tag {
  display: inline-block !important;
  font-size: 9px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  padding: 2px 8px !important;
  border-radius: 6px !important;
  letter-spacing: 0.5px !important;
  margin-left: 8px !important;
  vertical-align: middle !important;
  line-height: 1.2 !important;
}

.badge-new {
  background: rgba(242, 235, 11, 0.15) !important;
  color: var(--color-yellow) !important;
  border: 1px solid rgba(242, 235, 11, 0.3) !important;
  box-shadow: 0 0 8px rgba(242, 235, 11, 0.2) !important;
  animation: glowPulse 2s infinite alternate !important;
}

.badge-recommended {
  background: rgba(0, 149, 76, 0.15) !important;
  color: var(--color-green) !important;
  border: 1px solid rgba(0, 149, 76, 0.3) !important;
  box-shadow: 0 0 8px rgba(0, 149, 76, 0.2) !important;
}

.badge-exclusive {
  background: rgba(255, 255, 255, 0.08) !important;
  color: #fff !important;
  border: 1px solid rgba(255, 255, 255, 0.15) !important;
}

.badge-beta {
  background: rgba(242, 235, 11, 0.08) !important;
  color: rgba(242, 235, 11, 0.8) !important;
  border: 1px solid rgba(242, 235, 11, 0.2) !important;
}

@keyframes glowPulse {
  0% { box-shadow: 0 0 4px rgba(242, 235, 11, 0.2); }
  100% { box-shadow: 0 0 12px rgba(242, 235, 11, 0.5); }
}

/* Glassmorphic Filters Styles */
.filter-btn {
  background: transparent !important;
  border: 1px solid transparent !important;
  color: #8fa394 !important;
  padding: 8px 20px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  border-radius: 20px !important;
  cursor: pointer !important;
  transition: all 0.3s ease !important;
  outline: none !important;
}

.filter-btn:hover {
  color: #fff !important;
  background: rgba(255, 255, 255, 0.04) !important;
}

.filter-btn.active {
  background: var(--color-green) !important;
  color: #fff !important;
  border-color: var(--color-green) !important;
  box-shadow: 0 4px 15px rgba(0, 149, 76, 0.3) !important;
}
.related-system-item {
  transition: opacity 0.25s ease, transform 0.25s ease !important;
  transform: scale(1);
}

/* ==========================================================================
   Home Page Redesign & Animated Banner Styles
   ========================================================================== */

.main-banner {
  position: relative !important;
  overflow: hidden !important;
}

.main-banner::before {
  content: '' !important;
  position: absolute !important;
  top: -40% !important;
  right: -20% !important;
  width: 400px !important;
  height: 400px !important;
  background: radial-gradient(circle, rgba(0, 149, 76, 0.15) 0%, rgba(242, 235, 11, 0.05) 50%, transparent 100%) !important;
  filter: blur(60px) !important;
  pointer-events: none !important;
  animation: bannerGlowFloat 12s infinite alternate ease-in-out !important;
  z-index: 1 !important;
}

@keyframes bannerGlowFloat {
  0% {
    transform: translate(0, 0) scale(1);
  }
  100% {
    transform: translate(-60px, 40px) scale(1.15);
  }
}

.main-banner .header-text {
  position: relative !important;
  z-index: 2 !important;
}

/* Dependency Filtering Styles for Home Page */
.dependency-filter-item {
  transition: opacity 0.3s cubic-bezier(0.25, 0.8, 0.25, 1), 
              transform 0.3s cubic-bezier(0.25, 0.8, 0.25, 1) !important;
  transform: scale(1);
}

/* ==========================================================================
   Careers / Trabaja con Nosotros Page Styles
   ========================================================================== */

.careers-value-card {
  background: rgba(255, 255, 255, 0.012) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 20px !important;
  padding: 30px !important;
  text-align: center !important;
  height: 100% !important;
  transition: all 0.3s ease !important;
}

.careers-value-card:hover {
  transform: translateY(-5px) !important;
  border-color: var(--color-yellow) !important;
  box-shadow: 0 8px 25px rgba(0, 149, 76, 0.08) !important;
}

.careers-value-card i {
  font-size: 36px !important;
  margin-bottom: 15px !important;
  transition: transform 0.3s ease !important;
  display: inline-block !important;
}

.careers-value-card:hover i {
  transform: scale(1.1) rotate(10deg) !important;
}

.careers-job-card {
  background: rgba(255, 255, 255, 0.015) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 20px !important;
  padding: 25px !important;
  margin-bottom: 20px !important;
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1) !important;
}

.careers-job-card:hover {
  transform: translateY(-3px) !important;
  border-color: var(--color-yellow) !important;
  background: rgba(255, 255, 255, 0.03) !important;
  box-shadow: 0 6px 20px rgba(0, 149, 76, 0.04) !important;
}

.careers-form-container {
  background: rgba(255, 255, 255, 0.015) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 24px !important;
  padding: 40px !important;
}

.careers-progress-wrapper {
  background: rgba(255, 255, 255, 0.05) !important;
  height: 6px !important;
  border-radius: 3px !important;
  overflow: hidden !important;
  margin: 15px 0 !important;
  display: none;
}

.careers-progress-bar {
  height: 100% !important;
  width: 0% !important;
  background: var(--color-yellow) !important;
  border-radius: 3px !important;
  box-shadow: 0 0 10px rgba(242, 235, 11, 0.8) !important;
  transition: width 0.1s linear !important;
}




/* ==========================================================================
   High-Tech App Entrance Page Transition Animations
   ========================================================================== */

.page-entrance-active {
  animation: appPageEntrance 0.5s cubic-bezier(0.25, 1, 0.5, 1) forwards !important;
  opacity: 0;
}

@keyframes appPageEntrance {
  0% {
    opacity: 0;
    transform: translateY(18px) scale(0.985);
    filter: blur(8px);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
  }
}

/* ==========================================================================
   Sub-App Tab Transition Animations
   ========================================================================== */

.subapp-tab-content {
  transition: opacity 0.28s cubic-bezier(0.25, 0.8, 0.25, 1), 
              transform 0.28s cubic-bezier(0.25, 0.8, 0.25, 1) !important;
  transform: translateY(0) scale(1);
  opacity: 1;
}

.nav-tab-link {
  cursor: pointer !important;
  transition: all 0.3s ease !important;
}

.nav-tab-link:hover {
  color: var(--color-yellow) !important;
}

/* ==========================================================================
   Login & Dashboard Styles
   ========================================================================== */
.login-card { background: rgba(255, 255, 255, 0.015) !important; border: 1px solid var(--color-border) !important; border-radius: 24px !important; padding: 40px !important; backdrop-filter: blur(15px) !important; box-shadow: 0 15px 35px rgba(0, 0, 0, 0.4) !important; }
.login-tab-btn { background: transparent !important; border: none !important; color: #8fa394 !important; font-size: 16px !important; font-weight: 700 !important; padding: 10px 20px !important; cursor: pointer !important; transition: all 0.3s ease !important; border-bottom: 2px solid transparent !important; }
.login-tab-btn.active { color: var(--color-yellow) !important; border-bottom: 2px solid var(--color-yellow) !important; }
.dashboard-wrapper { display: flex !important; flex-wrap: wrap !important; gap: 30px !important; margin-top: 20px !important; }
.dashboard-sidebar { flex: 1 !important; min-width: 240px !important; background: rgba(255, 255, 255, 0.01) !important; border: 1px solid var(--color-border) !important; border-radius: 24px !important; padding: 25px !important; height: fit-content !important; backdrop-filter: blur(10px) !important; }
.dashboard-content { flex: 3 !important; min-width: 300px !important; }
.dashboard-sidebar-menu { list-style: none !important; padding: 0 !important; margin: 0 !important; }
.dashboard-sidebar-menu li { margin-bottom: 12px !important; }
.dashboard-sidebar-menu li a { display: flex !important; align-items: center !important; padding: 12px 20px !important; color: #a4bfae !important; border-radius: 14px !important; font-size: 14px !important; font-weight: 600 !important; transition: all 0.3s ease !important; cursor: pointer !important; text-decoration: none !important; }
.dashboard-sidebar-menu li a i { margin-right: 12px !important; font-size: 16px !important; }
.dashboard-sidebar-menu li a:hover, .dashboard-sidebar-menu li a.active { background: rgba(255, 255, 255, 0.04) !important; color: #fff !important; border: 1px solid rgba(242, 235, 11, 0.15) !important; }
.dashboard-sidebar-menu li a.active i { color: var(--color-yellow) !important; }
.dashboard-kpi-card { background: rgba(255, 255, 255, 0.015) !important; border: 1px solid var(--color-border) !important; border-radius: 20px !important; padding: 25px !important; display: flex !important; align-items: center !important; justify-content: space-between !important; transition: all 0.3s ease !important; height: 100% !important; }
.dashboard-kpi-card:hover { transform: translateY(-4px) !important; border-color: var(--color-yellow) !important; box-shadow: 0 8px 25px rgba(0, 149, 76, 0.06) !important; }
.dashboard-kpi-card h3 { font-size: 28px !important; font-weight: 800 !important; color: #fff !important; margin-top: 5px !important; margin-bottom: 0 !important; }
.dashboard-kpi-card span { font-size: 12px !important; color: #8fa394 !important; text-transform: uppercase !important; font-weight: 700 !important; letter-spacing: 0.5px !important; }
.dashboard-kpi-icon { width: 55px !important; height: 55px !important; border-radius: 16px !important; display: flex !important; align-items: center !important; justify-content: center !important; font-size: 22px !important; }
.dashboard-table-container { background: rgba(255, 255, 255, 0.012) !important; border: 1px solid var(--color-border) !important; border-radius: 24px !important; padding: 30px !important; margin-bottom: 30px !important; backdrop-filter: blur(10px) !important; }
.dashboard-table { width: 100% !important; border-collapse: collapse !important; margin-top: 15px !important; }
.dashboard-table th { border-bottom: 2px solid rgba(255, 255, 255, 0.08) !important; padding: 15px !important; color: #a4bfae !important; font-size: 12px !important; text-transform: uppercase !important; font-weight: 700 !important; letter-spacing: 0.5px !important; text-align: left !important; }
.dashboard-table td { border-bottom: 1px solid rgba(255, 255, 255, 0.04) !important; padding: 15px !important; color: #fff !important; font-size: 13px !important; }
.dashboard-table tr:hover td { background: rgba(255, 255, 255, 0.02) !important; }
.status-badge { padding: 6px 12px !important; border-radius: 20px !important; font-size: 11px !important; font-weight: 700 !important; text-transform: uppercase !important; letter-spacing: 0.5px !important; display: inline-block !important; }
.status-badge.status-admin { background: rgba(242, 235, 11, 0.1) !important; color: var(--color-yellow) !important; border: 1px solid rgba(242, 235, 11, 0.25) !important; }
.status-badge.status-engineer { background: rgba(0, 149, 76, 0.1) !important; color: var(--color-green) !important; border: 1px solid rgba(0, 149, 76, 0.25) !important; }
.status-badge.status-user { background: rgba(255, 255, 255, 0.05) !important; color: #fff !important; border: 1px solid rgba(255, 255, 255, 0.15) !important; }
.dashboard-log-console { background: #040c09 !important; border: 1px solid var(--color-border) !important; border-radius: 16px !important; padding: 20px !important; font-family: monospace !important; color: #39ff14 !important; font-size: 12px !important; min-height: 180px !important; max-height: 250px !important; overflow-y: auto !important; margin-top: 15px !important; box-shadow: inset 0 0 10px rgba(0,0,0,0.8) !important; }
.dashboard-log-line { margin-bottom: 6px !important; line-height: 18px !important; opacity: 0.9 !important; }
.role-permission-tag { padding: 4px 8px !important; border-radius: 8px !important; font-size: 10px !important; font-weight: 600 !important; background: rgba(0, 149, 76, 0.08) !important; color: var(--color-green) !important; border: 1px solid rgba(0, 149, 76, 0.18) !important; margin: 2px !important; display: inline-block !important; }

/* Dynamic Header Adjustments for Top Utility Bar */
header.header-area, header.background-header {
  height: 100px !important;
  display: block !important;
}
header.header-area .main-nav, header.background-header .main-nav {
  margin-top: 20px !important;
}
body .page-content {
  margin-top: 150px !important;
}
@media (max-width: 992px) {
  header.header-area, header.background-header {
    height: auto !important;
  }
  header.header-area .main-nav, header.background-header .main-nav {
    margin-top: 0 !important;
  }
  body .page-content {
    margin-top: 110px !important;
  }
}



/* ==========================================================================
   Interactive Corporate Dossier Deck
   ========================================================================== */
.dossier-modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(4, 12, 8, 0.96) !important;
  backdrop-filter: blur(15px) !important;
  z-index: 10000 !important;
  justify-content: center !important;
  align-items: center !important;
}
.dossier-container {
  width: 92% !important;
  max-width: 960px !important;
  height: 80vh !important;
  max-height: 580px !important;
  background: rgba(255, 255, 255, 0.015) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 28px !important;
  box-shadow: 0 25px 60px rgba(0,0,0,0.6) !important;
  position: relative !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
}
.dossier-slide {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  padding: 50px !important;
  display: none !important;
  flex-direction: column !important;
  justify-content: center !important;
  animation: slideFadeIn 0.6s cubic-bezier(0.25, 1, 0.5, 1) forwards !important;
}
.dossier-slide.active {
  display: flex !important;
}
@keyframes slideFadeIn {
  0% { opacity: 0; transform: translateX(35px) scale(0.98); filter: blur(5px); }
  100% { opacity: 1; transform: translateX(0) scale(1); filter: blur(0); }
}
.dossier-close {
  position: absolute !important;
  top: 25px !important;
  right: 35px !important;
  font-size: 28px !important;
  color: #8fa394 !important;
  cursor: pointer !important;
  z-index: 10100 !important;
  transition: all 0.3s ease !important;
}
.dossier-close:hover {
  color: var(--color-yellow) !important;
  transform: rotate(90deg) !important;
}
.dossier-controls {
  position: absolute !important;
  bottom: 25px !important;
  left: 0 !important;
  right: 0 !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  padding: 0 50px !important;
  z-index: 10100 !important;
}
.dossier-nav-btn {
  background: rgba(255, 255, 255, 0.03) !important;
  border: 1px solid var(--color-border) !important;
  color: #fff !important;
  border-radius: 50% !important;
  width: 45px !important;
  height: 45px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  transition: all 0.3s ease !important;
}
.dossier-nav-btn:hover {
  background: var(--color-yellow) !important;
  color: #07140e !important;
  border-color: var(--color-yellow) !important;
  box-shadow: 0 0 15px rgba(242, 235, 11, 0.3) !important;
}
.dossier-dots {
  display: flex !important;
  gap: 8px !important;
}
.dossier-dot {
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  background: rgba(255, 255, 255, 0.2) !important;
  cursor: pointer !important;
  transition: all 0.3s ease !important;
}
.dossier-dot.active {
  background: var(--color-yellow) !important;
  width: 24px !important;
  border-radius: 10px !important;
  box-shadow: 0 0 10px rgba(242, 235, 11, 0.4) !important;
}
.dossier-title {
  font-size: 32px !important;
  font-weight: 800 !important;
  color: #fff !important;
  margin-bottom: 8px !important;
}
.dossier-subtitle {
  color: var(--color-yellow) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  margin-bottom: 20px !important;
}
.dossier-card {
  background: rgba(255, 255, 255, 0.012) !important;
  border: 1px solid rgba(255, 255, 255, 0.04) !important;
  border-radius: 20px !important;
  padding: 25px !important;
  transition: all 0.3s ease !important;
}
.dossier-card:hover {
  border-color: rgba(242, 235, 11, 0.15) !important;
  background: rgba(255, 255, 255, 0.02) !important;
}
.dossier-timeline {
  display: flex !important;
  justify-content: space-between !important;
  position: relative !important;
  margin-top: 30px !important;
}
.dossier-timeline::before {
  content: '' !important;
  position: absolute !important;
  top: 15px !important;
  left: 0 !important;
  right: 0 !important;
  height: 2px !important;
  background: rgba(255,255,255,0.08) !important;
  z-index: 1 !important;
}
.timeline-node {
  position: relative !important;
  z-index: 5 !important;
  text-align: center !important;
  flex: 1 !important;
}
.timeline-circle {
  width: 32px !important;
  height: 32px !important;
  border-radius: 50% !important;
  background: #07140e !important;
  border: 2px solid var(--color-green) !important;
  margin: 0 auto 12px auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #fff !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  transition: all 0.3s ease !important;
}
.timeline-node:hover .timeline-circle {
  border-color: var(--color-yellow) !important;
  box-shadow: 0 0 12px rgba(242, 235, 11, 0.3) !important;
  transform: scale(1.15) !important;
}

/* ==========================================================================
   Consolidated Header Configuration Dropdown (Theme & Language)
   ========================================================================== */
#top-config-dropdown {
  animation: authFadeIn 0.25s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  transform-origin: top right;
}

@keyframes authFadeIn {
  from {
    opacity: 0;
    transform: translateY(-8px) scale(0.95);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* Hover highlights for dropdown options */
#top-config-dropdown a {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 500 !important;
  border-radius: 8px;
  margin: 2px 6px;
  border: 1px solid transparent;
  transition: all 0.25s ease !important;
}

#top-config-dropdown a:hover {
  background: rgba(0, 149, 76, 0.15) !important;
  color: var(--color-yellow) !important;
  border-color: rgba(0, 149, 76, 0.2) !important;
  padding-left: 18px !important; /* Elegant slide effect on hover */
}

/* Style for Light Theme overrides inside dropdown */
body.light-theme #top-config-dropdown {
  background: rgba(255, 255, 255, 0.98) !important;
  border-color: rgba(0, 149, 76, 0.15) !important;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15) !important;
}

body.light-theme #top-config-dropdown a {
  color: #1a3a2a !important;
}

body.light-theme #top-config-dropdown a:hover {
  background: rgba(0, 149, 76, 0.08) !important;
  color: var(--color-green) !important;
}

/* Responsive adjustment for Mobile viewports */
@media (max-width: 576px) {
  #top-config-dropdown {
    right: auto !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    transform-origin: top center !important;
  }
  @keyframes authFadeIn {
    from {
      opacity: 0;
      transform: translate(-50%, -8px) scale(0.95);
    }
    to {
      opacity: 1;
      transform: translate(-50%, 0) scale(1);
    }
  }
}

/* ==========================================================================
   Restructured Projects Showcase Grid & Category Filter Bar
   ========================================================================== */

.project-filter-btn {
  background: rgba(255, 255, 255, 0.04) !important;
  border: 1px solid rgba(0, 149, 76, 0.15) !important;
  color: #a4bfae !important;
  padding: 8px 20px !important;
  border-radius: 30px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  transition: all 0.3s ease !important;
  cursor: pointer !important;
}

.project-filter-btn:hover,
.project-filter-btn.active {
  background: var(--color-green) !important;
  color: #fff !important;
  border-color: var(--color-green) !important;
  box-shadow: 0 4px 15px rgba(0, 149, 76, 0.3) !important;
}

.project-filter-btn.active {
  background: var(--color-green) !important;
  border-color: var(--color-green) !important;
}

/* Glassmorphic Project Card */
.project-card-item {
  transition: all 0.3s ease-out !important;
}

.project-card {
  background: rgba(255, 255, 255, 0.015) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 24px !important;
  overflow: hidden !important;
  transition: all 0.35s cubic-bezier(0.16, 1, 0.3, 1) !important;
  cursor: pointer !important;
  height: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2) !important;
}

.project-card:hover {
  transform: translateY(-8px) !important;
  border-color: rgba(242, 235, 11, 0.3) !important;
  box-shadow: 0 15px 40px rgba(0, 149, 76, 0.18), 0 0 15px rgba(242, 235, 11, 0.08) !important;
}

.project-card-thumb {
  position: relative !important;
  height: 180px !important;
  background: rgba(0, 0, 0, 0.15) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 20px !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.03) !important;
}

.project-card-thumb img {
  max-height: 120px !important;
  max-width: 80% !important;
  object-fit: contain !important;
  transition: all 0.4s ease !important;
}

.project-card:hover .project-card-thumb img {
  transform: scale(1.08) !important;
}

/* Specialized Badges for Division Branding */
.project-card-badge {
  position: absolute !important;
  bottom: 15px !important;
  right: 15px !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  padding: 4px 10px !important;
  border-radius: 12px !important;
  letter-spacing: 0.5px !important;
  border: 1px solid rgba(255,255,255,0.1) !important;
}

.project-card-badge.inmobiliaria {
  background: rgba(0, 149, 76, 0.15) !important;
  color: #58d68d !important;
  border-color: rgba(0, 149, 76, 0.3) !important;
}

.project-card-badge.construccion {
  background: rgba(242, 235, 11, 0.1) !important;
  color: var(--color-yellow) !important;
  border-color: rgba(242, 235, 11, 0.3) !important;
}

.project-card-badge.software {
  background: rgba(52, 152, 219, 0.15) !important;
  color: #5dade2 !important;
  border-color: rgba(52, 152, 219, 0.3) !important;
}

.project-card-badge.retail {
  background: rgba(155, 89, 182, 0.15) !important;
  color: #af7ac5 !important;
  border-color: rgba(155, 89, 182, 0.3) !important;
}

.project-card-badge.travel {
  background: rgba(26, 188, 156, 0.15) !important;
  color: #48c9b0 !important;
  border-color: rgba(26, 188, 156, 0.3) !important;
}

.project-card-badge.agro {
  background: rgba(230, 126, 34, 0.15) !important;
  color: #f5b041 !important;
  border-color: rgba(230, 126, 34, 0.3) !important;
}

.project-card-content {
  padding: 24px !important;
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
}

.project-card-content h5 {
  color: #fff !important;
  font-weight: 700 !important;
  font-size: 16px !important;
  margin-bottom: 8px !important;
}

.project-location {
  font-size: 12px !important;
  color: #8fa394 !important;
  display: block !important;
  margin-bottom: 12px !important;
}

.project-location i {
  color: var(--color-green) !important;
  margin-right: 4px !important;
}

.project-card-content p {
  color: #a4bfae !important;
  font-size: 13px !important;
  line-height: 20px !important;
  margin-bottom: 20px !important;
}

.project-card-footer {
  border-top: 1px solid rgba(255, 255, 255, 0.04) !important;
  padding-top: 15px !important;
  margin-top: auto !important;
}

.project-status-label {
  font-size: 10px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  padding: 2px 8px !important;
  border-radius: 20px !important;
  border: 1px solid transparent !important;
}

.project-status-label.status-presale {
  background: rgba(242, 235, 11, 0.12) !important;
  color: var(--color-yellow) !important;
  border-color: rgba(242, 235, 11, 0.25) !important;
}

.project-status-label.status-active {
  background: rgba(0, 149, 76, 0.12) !important;
  color: #58d68d !important;
  border-color: rgba(0, 149, 76, 0.25) !important;
}

.project-status-label.status-building {
  background: rgba(230, 126, 34, 0.1) !important;
  color: #eb984e !important;
  border-color: rgba(230, 126, 34, 0.2) !important;
}

.project-status-label.status-delivered {
  background: rgba(255, 255, 255, 0.05) !important;
  color: #fff !important;
  border-color: rgba(255, 255, 255, 0.15) !important;
}

.btn-dossier-card {
  color: var(--color-green) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  transition: all 0.3s ease !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
}

.project-card:hover .btn-dossier-card {
  color: var(--color-yellow) !important;
  transform: translateX(3px) !important;
}

/* ==========================================================================
   Animated Technical Dossier Modal
   ========================================================================== */

.dossier-modal {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  z-index: 200000 !important;
  display: none;
  align-items: center !important;
  justify-content: center !important;
}

.dossier-modal-backdrop {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  background: rgba(4, 12, 8, 0.7) !important;
  backdrop-filter: blur(15px) !important;
  transition: all 0.3s ease !important;
}

.dossier-modal-content {
  position: relative !important;
  width: 90% !important;
  max-width: 1100px !important;
  height: 85vh !important;
  background: rgba(15, 26, 20, 0.95) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 28px !important;
  box-shadow: 0 25px 60px rgba(0,0,0,0.8), 0 0 30px rgba(0, 149, 76, 0.15) !important;
  z-index: 10 !important;
  overflow: hidden !important;
  transform: translateY(30px) scale(0.98) !important;
  opacity: 0 !important;
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.dossier-modal.active .dossier-modal-content {
  transform: translateY(0) scale(1) !important;
  opacity: 1 !important;
}

.dossier-close-btn {
  position: absolute !important;
  top: 20px !important;
  right: 25px !important;
  font-size: 32px !important;
  color: #8fa394 !important;
  cursor: pointer !important;
  z-index: 100 !important;
  transition: all 0.25s ease !important;
}

.dossier-close-btn:hover {
  color: #ff6b6b !important;
  transform: scale(1.1) rotate(90deg) !important;
}

.dossier-modal .text-panel {
  overflow-y: auto !important;
  max-height: 85vh !important;
}

.dossier-modal .spec-item-block {
  border-left: 2px solid var(--color-green) !important;
  padding-left: 12px !important;
  transition: border-color 0.3s !important;
}

.dossier-modal .spec-item-block:hover {
  border-color: var(--color-yellow) !important;
}

/* Blueprint laser scan effect */
@keyframes laserScan {
  0% {
    top: 0%;
  }
  50% {
    top: 100%;
  }
  100% {
    top: 0%;
  }
}

body.light-theme .dossier-modal-content {
  background: rgba(255, 255, 255, 0.98) !important;
  border-color: rgba(0, 149, 76, 0.15) !important;
  box-shadow: 0 25px 60px rgba(0,0,0,0.15) !important;
}

body.light-theme .dossier-modal h2,
body.light-theme .dossier-modal strong,
body.light-theme .dossier-modal .blueprint-legend {
  color: #1a3a2a !important;
}

body.light-theme .dossier-modal p {
  color: #2c4d3b !important;
}

body.light-theme .technical-specs-wrapper {
  background: rgba(0, 149, 76, 0.03) !important;
  border-color: rgba(0, 149, 76, 0.15) !important;
}

body.light-theme .dossier-progress-section {
  border-top-color: rgba(0, 149, 76, 0.1) !important;
}

/* Light Theme overrides for filter buttons */
body.light-theme .project-filter-bar {
  background: rgba(255, 255, 255, 0.8) !important;
  border-color: rgba(0, 149, 76, 0.15) !important;
}

body.light-theme .project-filter-btn {
  background: rgba(0, 149, 76, 0.05) !important;
  color: #1a3a2a !important;
  border-color: rgba(0, 149, 76, 0.15) !important;
}

body.light-theme .project-filter-btn:hover,
body.light-theme .project-filter-btn.active {
  background: var(--color-green) !important;
  color: #fff !important;
}





