
/*
====================================================

* 	[Master Stylesheet]
	
	Theme Name :  
	Version    :  
	Author     :  
	Author URI :  

====================================================

	TOC
	
	1. PRIMARY STYLES
	2. COMMONS FOR PAGE DESIGN
		JQUERY LIGHT BOX
	3. MAIN SECTION

====================================================

/* ---------------------------------
1. PRIMARY STYLES
--------------------------------- */

html{ font-size: 100%; height: 100%; width: 100%; overflow-x: hidden; margin: 0px;  padding: 0px; touch-action: manipulation; }


body{ font-size: 16px; font-family: 'Inter', 'Open Sans', system-ui, -apple-system, sans-serif; width: 100%; height: 100%; margin: 0; font-weight: 400;
	-webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; word-wrap: break-word; overflow-x: hidden; 
	color: #000000; background-color: #FFFFFF; }

h1, h2, h3, h4, h5, h6, p, a, ul, span, li, img, inpot, button{ margin: 0; padding: 0; }

h1,h2,h3,h4,h5,h6{ line-height: 1.5; font-weight: inherit; }

h1,h2,h3{ font-family: 'IBM Plex Sans', 'Poppins', system-ui, sans-serif; }

p{ line-height: 1.7; font-size: 1.05em; font-weight: 400; color: #495057; }

h1{ font-size: 3.5em; line-height: 1.2; font-weight: 700; letter-spacing: -0.025em; }
h2{ font-size: 3em; line-height: 1.1; font-weight: 600; }
h3{ font-size: 2.5em; }
h4{ font-size: 1.5em; }
h5{ font-size: 1.2em; }
h6{ font-size: .9em; letter-spacing: 1px; }

a, button{ display: inline-block; text-decoration: none; color: inherit; transition: all .3s; line-height: 1; }

a:focus, a:active, a:hover,
button:focus, button:active, button:hover,
a b.light-color:hover{ text-decoration: none; color: #8B0000; }

b{ font-weight: 600; }

img{ width: 100%; }

li{ list-style: none; display: inline-block; }

span{ display: inline-block; }

button{ outline: 0; border: 0; background: none; cursor: pointer; }

b.light-color{ color: #343A40; }

.icon{ font-size: 1.1em; display: inline-block; line-height: inherit; }

[class^="icon-"]:before, [class*=" icon-"]:before{ line-height: inherit; }

*, *::before, *::after {
    -webkit-box-sizing: inherit;
    box-sizing: inherit;
}

*, *::before, *::after {
    -webkit-box-sizing: inherit;
	box-sizing: inherit;} 

	
/* ---------------------------------
2. COMMONS FOR PAGE DESIGN
--------------------------------- */

.center-text{ text-align: center; } 

.display-table{ display: table; height: 100%; width: 100%; }

.display-table-cell{ display: table-cell; vertical-align: middle; }



::-webkit-input-placeholder { font-size: .9em; letter-spacing: 1px; }

::-moz-placeholder { font-size: .9em; letter-spacing: 1px; }

:-ms-input-placeholder { font-size: .9em; letter-spacing: 1px; }

:-moz-placeholder { font-size: .9em; letter-spacing: 1px; }


.full-height{ height: 100%; }

.position-static{ position: static; }

.font-white{ color: #fff; }


/* ---------------------------------
3. MAIN SECTION - SERVIN CORPORATE COLORS
--------------------------------- */

.main-area{ position: relative; height: 100vh; z-index: 1; padding: 0 20px; background-size: cover; 
	background-position: center; color: #FFFFFF; }

.main-area:after{ content:''; position: absolute; top: 0; bottom: 0; left: 0; right: 0; z-index: -1;  
	opacity: 0.97; background: linear-gradient(135deg, #210C20 0%, rgba(33, 12, 32, 0.98) 30%, rgba(139, 0, 0, 0.95) 100%); }

.main-area .desc{ margin: 20px auto; max-width: 600px; font-size: 1.125rem; line-height: 1.75; }

/* Logo SERVIN */
.logo-container {
	position: absolute;
	top: 30px;
	left: 30px;
	z-index: 100;
}

.logo-servin {
	max-width: 180px;
	height: auto;
	filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.3));
	transition: transform 0.3s ease;
}

.logo-servin:hover {
	transform: scale(1.05);
}

@media (max-width: 768px) {
	.logo-container {
		top: 20px;
		left: 20px;
	}
	
	.logo-servin {
		max-width: 140px;
	}
}

/* Social Icons Center - SERVIN Corporate */
.social-icons-center {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 20px;
	margin: 40px auto;
}

.social-icon-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	background: rgba(255, 255, 255, 0.1);
	backdrop-filter: blur(10px);
	border: 2px solid rgba(255, 255, 255, 0.3);
	border-radius: 50%;
	color: #FFFFFF;
	transition: all 0.3s ease;
	cursor: pointer;
}

.social-icon-btn:hover {
	background: rgba(255, 255, 255, 0.25);
	border-color: rgba(255, 255, 255, 0.6);
	transform: translateY(-4px) scale(1.1);
	box-shadow: 0 8px 20px rgba(255, 255, 255, 0.2);
}

.social-icon-btn svg {
	width: 24px;
	height: 24px;
	transition: transform 0.3s ease;
}

.social-icon-btn:hover svg {
	transform: scale(1.1);
}

/* Scrollbar corporativo */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: rgba(255, 255, 255, 0.1); border-radius: 3px; }
::-webkit-scrollbar-thumb { background: rgba(139, 0, 0, 0.8); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: rgba(139, 0, 0, 1); }

/* Text shadow profesional */
.text-shadow { text-shadow: 0 4px 8px rgba(0,0,0,0.3); }

/* Focus visible para accesibilidad */
:focus-visible { outline: 2px solid #8B0000; outline-offset: 2px; }

/* Language Switcher - SERVIN Corporate */
.language-switcher {
	position: absolute;
	top: 30px;
	right: 30px;
	z-index: 100;
	display: flex;
	gap: 8px;
	background: rgba(255, 255, 255, 0.1);
	backdrop-filter: blur(10px);
	padding: 6px;
	border-radius: 12px;
	border: 1px solid rgba(255, 255, 255, 0.2);
}

.lang-btn {
	display: flex;
	align-items: center;
	gap: 6px;
	padding: 10px 16px;
	background: transparent;
	color: #FFFFFF;
	border: none;
	border-radius: 8px;
	font-size: 0.875rem;
	font-weight: 600;
	font-family: 'Inter', sans-serif;
	cursor: pointer;
	transition: all 0.3s ease;
	letter-spacing: 0.5px;
}

.lang-btn:hover {
	background: rgba(255, 255, 255, 0.15);
	transform: translateY(-1px);
}

.lang-btn.active {
	background: linear-gradient(to right, #8B0000, #8B0000);
	color: #FFFFFF;
	box-shadow: 0 4px 12px rgba(139, 0, 0, 0.4);
}

.lang-flag {
	width: 24px;
	height: 24px;
	border-radius: 50%;
	object-fit: cover;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

/* Responsive para móviles */
@media (max-width: 768px) {
	.language-switcher {
		top: 20px;
		right: 20px;
		padding: 4px;
	}
	
	.lang-btn {
		padding: 8px 12px;
		font-size: 0.8rem;
	}
	
	.lang-flag {
		font-size: 1em;
	}
}


