seguricam.com.ar
https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&family=Montserrat:wght@700;800;900&display=swaphttps://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.csshttps://cdn.jsdelivr.net/npm/[email protected]/font/bootstrap-icons.csshttps://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.0/css/all.min.css:root {
/* Paleta mejorada */
--brand: #0a1a2e; /* azul oscuro premium */
--brand-2: #1a3a6a; /* azul medio */
--accent: #00c2ff; /* celeste marca */
--accent-dark: #0085b2; /* celeste oscuro */
--ok: #19c37d;
--error: #f87171;
--text: #0f172a;
--text-light: #4b5563;
--muted: #6b7280;
--light: #f8fafc;
--bg: #ffffff;
--bg-alt: #f6f7fb;
/* Ticker */
--ticker-size-desktop: 500px;
--ticker-size-mobile: 320px;
--ticker-gap: 1rem;
--radius: 16px;
--radius-lg: 24px;
--shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
--shadow-lg: 0 15px 40px rgba(0, 0, 0, 0.15);
--shadow-hover: 0 8px 30px rgba(0, 0, 0, 0.18);
/* Transiciones */
--transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}
/* Base */
html {
scroll-behavior: smooth;
scroll-padding-top: 90px;
}
body {
font-family: 'Poppins', system-ui, -apple-system, sans-serif;
color: var(--text);
background: var(--bg);
line-height: 1.6;
overflow-x: hidden;
}
h1, h2, h3, h4, h5, h6 {
font-family: 'Montserrat', sans-serif;
font-weight: 800;
line-height: 1.2;
}
a {
color: var(--brand-2);
text-decoration: none;
transition: var(--transition);
}
a:hover {
color: var(--accent);
}
.text-gradient {
background: linear-gradient(90deg, var(--brand-2), var(--accent));
-webkit-background-clip: text;
background-clip: text;
color: transparent;
}
/* Navbar premium */
.navbar {
box-shadow: 0 5px 20px rgba(0, 0, 0, 0.08);
background: rgba(255, 255, 255, 0.95);
backdrop-filter: blur(10px);
-webkit-backdrop-filter: blur(10px);
padding: 0.75rem 0;
transition: var(--transition);
}
.navbar.scrolled {
padding: 0.5rem 0;
box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12);
}
.navbar-brand {
font-weight: 900;
font-size: 1.5rem;
color: var(--brand-2);
display: flex;
align-items: center;
gap: 0.5rem;
}
.navbar-brand i {
color: var(--accent);
font-size: 1.4rem;
}
.nav-link {
font-weight: 600;
padding: 0.5rem 1rem !important;
position: relative;
}
.nav-link::after {
content: '';
position: absolute;
bottom: 0;
left: 1rem;
width: calc(100% - 2rem);
height: 2px;
background: var(--accent);
transform: scaleX(0);
transform-origin: right;
transition: transform 0.3s ease;
}
.nav-link:hover::after {
transform: scaleX(1);
transform-origin: left;
}
.btn-cta {
background: linear-gradient(135deg, var(--accent), var(--accent-dark));
color: white;
font-weight: 700;
border: none;
padding: 0.6rem 1.5rem;
border-radius: 50px;
box-shadow: 0 4px 15px rgba(0, 194, 255, 0.3);
transition: var(--transition);
position: relative;
overflow: hidden;
}
.btn-cta:hover {
transform: translateY(-3px);
box-shadow: 0 8px 25px rgba(0, 194, 255, 0.4);
color: white;
}
.btn-cta:active {
transform: translateY(1px);
}
.btn-cta::before {
content: '';
position: absolute;
top: 0;
left: -100%;
width: 100%;
height: 100%;
background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
transition: 0.5s;
}
.btn-cta:hover::before {
left: 100%;
}
/* Hero section premium */
#inicio {
position: relative;
padding-top: 120px;
padding-bottom: 100px;
background: linear-gradient(135deg, rgba(246, 247, 251, 1) 0%, rgba(255, 255, 255, 1) 100%);
overflow: hidden;
}
#inicio::before {
content: '';
position: absolute;
top: -50%;
right: -20%;
width: 100%;
height: 200%;
background: radial-gradient(circle at 70% 50%, rgba(0, 194, 255, 0.1) 0%, transparent 60%);
z-index: 0;
}
.hero-content {
position: relative;
z-index: 2;
}
.hero-title {
font-size: 3.2rem;
font-weight: 900;
line-height: 1.1;
margin-bottom: 1.5rem;
background: linear-gradient(90deg, var(--brand-2), var(--accent));
-webkit-background-clip: text;
background-clip: text;
color: transparent;
}
.hero-subtitle {
font-size: 1.2rem;
color: var(--text-light);
margin-bottom: 2rem;
max-width: 600px;
}
.hero-badges {
display: flex;
gap: 0.75rem;
flex-wrap: wrap;
margin-bottom: 2rem;
}
.hero-badge {
background: rgba(0, 194, 255, 0.1);
color: var(--brand-2);
border: 1px solid rgba(0, 194, 255, 0.25);
padding: 0.6rem 1rem;
border-radius: 50px;
font-weight: 600;
font-size: 0.9rem;
display: flex;
align-items: center;
gap: 0.5rem;
transition: var(--transition);
}
.hero-badge i {
font-size: 1rem;
color: var(--accent);
}
.hero-badge:hover {
transform: translateY(-3px);
box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
}
.hero-buttons {
display: flex;
gap: 1rem;
flex-wrap: wrap;
}
.btn-outline-brand {
border: 2px solid var(--brand-2);
color: var(--brand-2);
font-weight: 600;
padding: 0.6rem 1.5rem;
border-radius: 50px;
transition: var(--transition);
}
.btn-outline-brand:hover {
background: var(--brand-2);
color: white;
border-color: var(--brand-2);
transform: translateY(-3px);
box-shadow: 0 5px 15px rgba(26, 58, 106, 0.2);
}
.hero-shot {
border-radius: var(--radius-lg);
box-shadow: var(--shadow-lg);
overflow: hidden;
transform: perspective(1000px) rotateY(-5deg) rotateX(2deg);
transition: var(--transition);
border: 10px solid white;
position: relative;
z-index: 1;
}
.hero-shot:hover {
transform: perspective(1000px) rotateY(0) rotateX(0);
box-shadow: var(--shadow-hover);
}
.hero-shot img {
width: 100%;
height: 100%;
object-fit: cover;
display: block;
}
.hero-location {
display: inline-flex;
align-items: center;
gap: 0.5rem;
color: var(--text-light);
margin-top: 1.5rem;
font-size: 0.95rem;
}
.hero-location i {
color: var(--accent);
}
/* Secciones */
section {
scroll-margin-top: 90px;
padding: 6rem 0;
position: relative;
}
.section-bg {
background: var(--bg-alt);
}
.section-title {
margin-bottom: 3rem;
text-align: center;
position: relative;
}
.section-title h2 {
font-weight: 900;
font-size: 2.5rem;
margin-bottom: 1rem;
position: relative;
display: inline-block;
}
.section-title h2::after {
content: '';
position: absolute;
bottom: -10px;
left: 50%;
transform: translateX(-50%);
width: 80px;
height: 4px;
background: linear-gradient(90deg, var(--accent), var(--brand-2));
border-radius: 2px;
}
.section-subtitle {
color: var(--text-light);
font-size: 1.1rem;
max-width: 700px;
margin: 0
/* ...cortado... */
.img-zoom-wrap{position:relative;}
.img-zoom-wrap img{
display:block;width:100%;height:auto;
border-top-left-radius:.5rem;border-top-right-radius:.5rem;
}
.zoom-trigger{
position:absolute;right:.5rem;bottom:.5rem;
border:0;border-radius:999px;padding:.4rem .8rem;
background:rgba(255,255,255,.92);
font-size:.9rem;font-weight:600;cursor:pointer;
box-shadow:0 6px 20px rgba(0,0,0,.15);
display:flex;align-items:center;gap:.4rem;
backdrop-filter:saturate(140%) blur(6px);
}
.zoom-trigger:hover{background:#fff}
.zoom-trigger i{font-size:1rem}
/* Modal liviano */
.img-modal{
position:fixed;inset:0;display:none;
align-items:center;justify-content:center;
background:rgba(0,0,0,.85);z-index:1050;padding:2rem;
}
.img-modal.open{display:flex}
.img-modal__img{
max-width:90vw;max-height:85vh;object-fit:contain;
border-radius:14px;box-shadow:0 16px 50px rgba(0,0,0,.5)
}
.img-modal__close{
position:fixed;top:14px;right:14px;
width:42px;height:42px;border-radius:50%;
border:0;background:#fff;font-size:1.4rem;line-height:1;
cursor:pointer;box-shadow:0 8px 30px rgba(0,0,0,.2)
}
.img-modal__caption{
color:#fff;margin-top:.8rem;text-align:center;font-size:.95rem;opacity:.9
}
/* ====== Ticker ====== */
#trabajos .ticker-wrap{
--desktop-size: 500px;
--img-fit: cover;
--img-pos: 50% 50%;
--ratio: 1 / 1;
--gap: 16px;
--speed: 38s;
position: relative;
overflow: hidden;
padding-block: 8px;
}
#trabajos .ticker-track{
display: flex;
width: max-content;
gap: var(--gap);
will-change: transform;
animation: ticker-scroll var(--speed) linear infinite;
}
#trabajos .ticker-wrap:hover .ticker-track,
#trabajos .ticker-wrap:focus-within .ticker-track{
animation-play-state: paused;
}
#trabajos .ticker-group{
display: flex;
gap: var(--gap);
}
#trabajos .ticker-card{
position: relative;
width: clamp(200px, 28vw, var(--desktop-size));
aspect-ratio: var(--ratio);
border-radius: 14px;
overflow: hidden;
background: #111;
box-shadow: 0 6px 18px rgba(0,0,0,.35);
flex: 0 0 auto;
}
#trabajos .ticker-card img{
width: 100%;
height: 100%;
object-fit: var(--img-fit);
object-position: var(--img-pos);
display: block;
user-select: none;
-webkit-user-drag: none;
}
#trabajos .ticker-wrap::before,
#trabajos .ticker-wrap::after{
content: "";
position: absolute;
inset: 0 auto 0 0;
width: 80px;
pointer-events: none;
background: linear-gradient(to right, rgba(0,0,0,.55), transparent);
}
#trabajos .ticker-wrap::after{
inset: 0 0 0 auto;
transform: scaleX(-1);
}
@media (max-width: 992px){
#trabajos .ticker-wrap{ --speed: 34s; }
}
@media (max-width: 576px){
#trabajos .ticker-wrap{ --gap: 12px; --speed: 30s; }
}
@media (prefers-reduced-motion: reduce){
#trabajos .ticker-track{ animation: none; }
}
@keyframes ticker-scroll{
to { transform: translateX(-50%); }
}
/* Contenedor de botones flotantes */
.social-float-container {
position: fixed;
bottom: 30px;
right: 30px;
z-index: 9999;
display: flex;
flex-direction: column-reverse;
gap: 15px;
align-items: flex-end;
}
/* Estilos base para todos los botones sociales */
.social-float {
position: relative;
transition: all 0.3s ease;
transform-style: preserve-3d;
}
.social-float:hover {
transform: translateY(-5px) rotate(5deg) scale(1.1);
}
.social-button {
display: block;
width: 70px;
height: 70px;
border-radius: 50%;
box-shadow: 0 10px 25px rgba(0, 0, 0, 0.2);
position: relative;
transition: all 0.3s ease;
animation: float 3s ease-in-out infinite;
color: white;
text-decoration: none;
}
.social-button:hover {
transform: scale(1.1);
box-shadow: 0 15px 30px rgba(0, 0, 0, 0.3);
}
.social-icon {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
font-size: 30px;
}
.social-pulse {
position: absolute;
width: 100%;
height: 100%;
border-radius: 50%;
opacity: 0;
animation: pulse 2s infinite;
}
.social-pulse-delayed {
position: absolute;
width: 100%;
height: 100%;
border-radius: 50%;
opacity: 0;
animation: pulse 2s infinite 0.5s;
}
.social-tooltip {
position: absolute;
right: 90px;
top: 50%;
transform: translateY(-50%);
background: white;
color: #333;
padding: 12px 15px;
border-radius: 10px;
font-size: 14px;
font-weight: 600;
box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
opacity: 0;
visibility: hidden;
transition: all 0.3s ease;
width: 200px;
text-align: center;
}
.social-tooltip small {
display: block;
font-size: 12px;
color: #666;
font-weight: normal;
margin-top: 3px;
}
.tooltip-arrow {
position: absolute;
right: -10px;
top: 50%;
transform: translateY(-50%);
width: 0;
height: 0;
border-top: 10px solid transparent;
border-bottom: 10px solid transparent;
border-left: 10px solid white;
}
.social-float:hover .social-tooltip {
opacity: 1;
visibility: visible;
right: 80px;
}
/* Estilos específicos para cada botón */
.whatsapp-button {
background: #25D366;
box-shadow: 0 10px 25px rgba(37, 211, 102, 0.3);
}
.whatsapp-button:hover {
background: #128C7E;
box-shadow: 0 15px 30px rgba(37, 211, 102, 0.4);
}
.whatsapp-pulse {
background: rgba(37, 211, 102, 0.6);
}
.whatsapp-pulse-delayed {
background: rgba(37, 211, 102, 0.4);
}
.instagram-button {
background: #E1306C;
box-shadow: 0 10px 25px rgba(225, 48, 108, 0.3);
}
.instagram-button:hover {
background: #C13584;
box-shadow: 0 15px 30px rgba(193, 53, 132, 0.4);
}
.instagram-pulse {
background: rgba(225, 48, 108, 0.6);
}
.instagram-pulse-delayed {
background: rgba(193, 53, 132, 0.4);
}
.facebook-button {
background: #1877F2;
box-shadow: 0 10px 25px rgba(24, 119, 242, 0.3);
}
.facebook-button:hover {
background: #166FE5;
box-shadow: 0 15px 30px rgba(22, 111, 229, 0.4);
}
.facebook-pulse {
background: rgba(24, 119, 242, 0.6);
}
.facebook-pulse-delayed {
background: rgba(22, 111, 229, 0.4);
}
/* Animaciones */
@keyframes float {
0% { transform: translateY(0px); }
50% { transform: translateY(-10px); }
100% { transform: translateY(0px); }
}
@keyframes pulse {
0% { transform: scale(0.8); opacity: 0; }
70% { transform: scale(1.3); opacity: 0.4; }
100% { transform: scale(1.4); opacity: 0; }
}
/* Efecto de latido al cargar */
@keyframes heartbeat {
0% { transform: scale(1); }
25% { transform: scale(1.1); }
50% { transform: scale(1); }
75% { transform: scale(1.1); }
100% { transform: scale(1); }
}
/* Animación inicial para los botones */
.social-button {
animation: heartbeat 1.5s ease 2s 2, float 3s ease-in-out infinite 3s;
}
/* Mostrar botones con un pequeño retraso entre ellos */
.instagram-float { animation: fadeInUp 0.5s ease 0.2s both; }
.facebook-float { animation: fadeInUp 0.5s ease 0.4s both; }
.whatsapp-float { animation: fadeInUp 0.5s ease 0.6s both; }
@keyframes fadeInUp {
from { opacity: 0; transform: translateY(20px); }
to { opacity: 1; transform: translateY(0); }
}
/* Responsive */
@media (max-width: 768px) {
.social-float-container {
bottom: 20px;
right: 20px;
}
.social-button {
width: 60px;
height: 60px;
}
.social-icon {
font-size: 25px;
}
.social-tooltip {
display: none;
}
}
hvpiscinas.com.ar
https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swaphttps://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.csshttps://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css:root {
--ink: #0f172a;
--muted: #64748b;
--line: #e5e7eb;
--bg: #ffffff;
--soft: #f8fafc;
--brand: #22C1F1;
--brand-dark: #0B84D9;
--brand-light: #ECF8FF;
--cta: #22C1F1;
--cta-dark: #0B84D9;
--cta-light: #E6F4FF;
--accent: #FFD54F;
--max: 1200px;
--radius: 16px;
--shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
--shadow-lg: 0 10px 40px rgba(0, 0, 0, 0.12);
--transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
/* Prevent media overflow on small screens */
img, video, iframe { max-width: 100%; height: auto; }
* {
box-sizing: border-box;
margin: 0;
padding: 0;
}
html {
scroll-behavior: smooth;
}
body {
font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
color: var(--ink);
background: var(--bg);
line-height: 1.6;
overflow-x: hidden;
}
a {
color: var(--brand);
text-decoration: none;
transition: var(--transition);
}
a:hover {
color: var(--brand-dark);
}
.container {
max-width: var(--max);
margin: 0 auto;
padding: 0 20px;
}
.btn {
display: inline-flex;
align-items: center;
gap: .5rem;
border: 1px solid transparent;
border-radius: 999px;
padding: .85rem 1.5rem;
font-weight: 600;
line-height: 1;
cursor: pointer;
transition: var(--transition);
position: relative;
overflow: hidden;
z-index: 1;
}
.btn::before {
content: '';
position: absolute;
top: 0;
left: 0;
width: 0%;
height: 100%;
background: rgba(255, 255, 255, 0.1);
transition: var(--transition);
z-index: -1;
}
.btn:hover::before {
width: 100%;
}
.btn-primary {
background: linear-gradient(135deg, var(--cta), #0ea171);
color: #fff;
box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3);
}
.btn-primary:hover {
transform: translateY(-2px);
box-shadow: 0 6px 16px rgba(16, 185, 129, 0.4);
}
.btn-outline {
border-color: var(--brand);
color: var(--brand);
background: transparent;
}
.btn-outline:hover {
background: var(--brand-light);
transform: translateY(-2px);
box-shadow: 0 4px 12px rgba(14, 165, 233, 0.2);
}
.eyebrow {
font-size: .8rem;
letter-spacing: .12em;
text-transform: uppercase;
color: var(--muted);
font-weight: 700;
display: inline-block;
margin-bottom: 8px;
}
.section {
padding: 80px 0;
}
.section-soft {
background: linear-gradient(135deg, var(--soft) 0%, #f1f5f9 100%);
}
.section-title {
font-size: clamp(1.8rem, 4vw, 2.8rem);
line-height: 1.15;
margin: 8px 0 16px;
font-weight: 800;
background: linear-gradient(135deg, var(--ink) 0%, var(--brand-dark) 100%);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
}
.lead {
font-size: clamp(1.1rem, 1.8vw, 1.25rem);
color: var(--ink);
opacity: 0.9;
}
.grid {
display: grid;
gap: 40px;
}
.grid-2 {
grid-template-columns: 1fr;
}
@media (min-width: 900px) {
.grid-2 {
grid-template-columns: 1.1fr .9fr;
}
}
/* Navbar */
.nav {
position: sticky;
top: 0;
z-index: 100;
background: rgba(255, 255, 255, 0.95);
backdrop-filter: blur(10px);
border-bottom: 1px solid rgba(229, 231, 235, 0.8);
transition: var(--transition);
}
.nav.scrolled {
box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}
.nav-inner {
display: flex;
align-items: center;
justify-content: space-between;
height: 80px;
}
.logo {
font-weight: 800;
letter-spacing: .2px;
font-size: 1.4rem;
background: linear-gradient(135deg, var(--brand) 0%, var(--cta) 100%);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
}
.nav-links {
display: none;
gap: 28px;
align-items: center;
}
.nav-links a {
color: var(--ink);
font-weight: 500;
position: relative;
}
.nav-links a::after {
content: '';
position: absolute;
width: 0;
height: 2px;
bottom: -4px;
left: 0;
background: var(--brand);
transition: var(--transition);
}
.nav-links a:hover::after {
width: 100%;
}
.nav-cta {
display: none;
}
.nav-toggle {
display: inline-flex;
align-items: center;
justify-content: center;
width: 44px;
height: 44px;
border: 1px solid var(--line);
border-radius: 12px;
background: #fff;
cursor: pointer;
transition: var(--transition);
}
.nav-toggle:hover {
background: var(--soft);
}
@media (min-width: 900px) {
.nav-toggle {
display: none;
}
.nav-cta {
display: inline-flex;
}
}
#mobileMenu {
display: none;
border-top: 1px solid var(--line);
padding: 20px 0;
background: rgba(255, 255, 255, 0.98);
backdrop-filter: blur(10px);
}
#mobileMenu a {
display: block;
padding: 12px 0;
color: var(--ink);
font-weight: 500;
border-bottom: 1px solid rgba(229, 231, 235, 0.5);
}
#mobileMenu a:last-child {
border-bottom: none;
}
@media (min-width: 900px) {
#mobileMenu {
display: none !important;
}
}
/* Hero */
.hero {
padding: 100px 0 80px;
background:
radial-gradient(ellipse at 80% 20%, rgba(14, 165, 233, 0.08) 0%, transparent 60%),
radial-gradient(ellipse at 20% 80%, rgba(16, 185, 129, 0.08) 0%, transparent 60%),
linear-gradient(135deg, #f8fafc 0%, #ffffff 100%);
position: relative;
overflow: hidden;
}
.hero::before {
content: '';
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11 18c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm48 25c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm-43-7c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zm63 31c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zM34 90c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zm56-76c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zM12 86c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm28-65c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm23-11c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm-6 60c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm29 22c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zM32 63c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm57-13c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm-9-21c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM60 91c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM35 41c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM12 60c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2z' fill='%230ea5e9' fill-opacity='0.03' fill-rule='evenodd'/%3E%3C/svg%3E");
opacity: 0.5;
}
.hero h1 {
font-size: clamp(2.2rem, 5.5vw, 3.5rem);
line
/* ...cortado... */
/* ===== Overrides HV celeste-first ===== */
:root {
--detail-red: #E5483B;
--detail-yellow: #FFD54F;
}
/* Botones principales en celeste */
.btn-primary,
.btn.brand,
.btn.btn-brand {
background: var(--cta);
border-color: var(--cta-dark);
color: #fff;
}
.btn-primary:hover,
.btn.brand:hover,
.btn.btn-brand:hover {
background: var(--cta-dark);
border-color: var(--cta-dark);
}
/* Líneas divisorias más pro en celeste */
.rule, .divider, .hr, .nt-rule {
height: 2px !important;
background: linear-gradient(90deg, var(--brand), var(--brand-dark));
border: 0;
opacity: 1;
}
/* Eyebrow con mini detalle rojo */
.eyebrow {
letter-spacing: .18em;
color: var(--brand-dark);
position: relative;
padding-left: 14px;
}
.eyebrow::before {
content: "";
width: 6px; height: 6px;
border-radius: 999px;
background: var(--detail-red);
position: absolute; left: 0; top: .55em;
}
/* Links y focos en celeste */
a:focus, button:focus { outline: 2px solid var(--brand); outline-offset: 2px; }
a:hover { color: var(--brand-dark); }
/* Badges sutiles en amarillo */
.badge, .tag, .pill { background: var(--detail-yellow); color: #2a2a2a; }
/* Cards con halo suave celeste */
.card { border:1px solid rgba(13,163,255,.15); box-shadow: 0 6px 24px rgba(11,132,217,.08); }
/* Hero compactado en mobile */
@media (max-width: 576px){
.hero, .section-hero { padding-top: 48px; padding-bottom: 48px; }
}
header.hero .eyebrow::before {
content: none !important;
}
.section-soft {
background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%);
padding: 80px 0;
}
.container {
max-width: 1200px;
margin: 0 auto;
padding: 0 20px;
}
.eyebrow {
display: inline-block;
color: #3b82f6;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.1em;
margin-bottom: 12px;
font-size: 0.875rem;
}
.section-title {
font-size: 2.5rem;
font-weight: 700;
color: #1e293b;
margin-bottom: 24px;
line-height: 1.2;
}
.content-grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 60px;
align-items: center;
}
.text-content p {
color: #475569;
line-height: 1.6;
margin-bottom: 20px;
}
.lead {
font-size: 1.25rem;
}
.features-list {
margin: 24px 0 0;
list-style: none;
padding: 0;
}
.feature-item {
display: flex;
align-items: center;
gap: 12px;
padding: 12px 0;
border-bottom: 1px solid #e2e8f0;
color: #475569;
}
.feature-item:last-child {
border-bottom: none;
}
.feature-icon {
font-size: 1.25rem;
flex-shrink: 0;
width: 24px;
}
.image-gallery {
display: flex;
flex-direction: column;
gap: 16px;
}
.main-image {
height: 300px;
border-radius: 16px;
box-shadow: 0 20px 40px rgba(0,0,0,0.1);
overflow: hidden;
}
.main-image img {
width: 100%;
height: 100%;
object-fit: cover;
transition: transform 0.3s ease;
}
.main-image:hover img {
transform: scale(1.05);
}
.thumbnails {
display: flex;
gap: 12px;
}
.thumb {
flex: 1;
height: 80px;
border-radius: 8px;
overflow: hidden;
cursor: pointer;
transition: transform 0.2s ease;
}
.thumb:hover {
transform: translateY(-4px);
}
.thumb img {
width: 100%;
height: 100%;
object-fit: cover;
}
@media (max-width: 768px) {
.content-grid {
grid-template-columns: 1fr;
gap: 40px;
}
.section-title {
font-size: 2rem;
}
.main-image {
height: 250px;
}
}
.gal-gallery .carousel{max-width:980px;margin-inline:auto;position:relative}
.gal-frame{
height: clamp(220px, 48vh, 440px);
background:#fff;border-radius:16px;overflow:hidden;
box-shadow:0 12px 28px rgba(0,0,0,.12);
display:flex;align-items:center;justify-content:center;padding:8px
}
.gal-img{
width:auto !important;max-width:100%;
height:auto !important;max-height:100%;
object-fit:contain !important;object-position:center;display:block;cursor:zoom-in
}
/* Controles circulares con más contraste */
.gal-gallery .carousel-control-prev,
.gal-gallery .carousel-control-next{
z-index:20;width:50px;height:50px;top:50%;transform:translateY(-50%);
opacity:1;background:rgba(0,0,0,.55);border-radius:50%;margin:0 12px
}
.gal-gallery .carousel-control-prev{left:0}
.gal-gallery .carousel-control-next{right:0}
.gal-gallery .gal-ctrl-icon{width:2.6rem;height:2.6rem;background-size:60% 60%}
/* Indicadores: se sitúan fuera; agregamos espacio inferior para que no se corten */
.gal-gallery .carousel-indicators{z-index:10;bottom:-50px}
.gal-gallery .carousel-indicators button{
width:10px;height:10px;border-radius:50%;
background:rgba(0,0,0,.5);border:none
}
.gal-gallery .carousel-indicators button.active{background:#000}
.gal-gallery{padding-bottom:56px} /* espacio para indicadores */
/* Modal */
#galLightbox .modal-content{background:#000}
#galLightboxImg{max-height:86vh;width:100%;height:auto;object-fit:contain;background:#000}
.gal-lightbox-nav{
position:absolute;top:50%;transform:translateY(-50%);
border:0;width:44px;height:44px;border-radius:999px;
background:rgba(255,255,255,.18);color:#fff;font-size:30px;line-height:44px;text-align:center;z-index:5;cursor:pointer
}
.gal-lightbox-nav:hover{background:rgba(255,255,255,.28)}
.gal-lightbox-nav.gal-prev{left:10px}
.gal-lightbox-nav.gal-next{right:10px}
/* Pequeños ajustes móviles */
@media (max-width: 575.98px){
.gal-frame{height: clamp(200px, 40vh, 360px)}
}
/* --- Scope exclusivo footer --- */
#pro-footer{background:#0f172a;color:#e5e7eb;padding:48px 0 0;border-top:1px solid #0b1426}
#pro-footer .container{max-width:1200px;margin:0 auto;padding:0 20px}
#pro-footer .grid{display:grid;gap:28px}
#pro-footer .grid-3{grid-template-columns:1fr}
@media(min-width:900px){#pro-footer .grid-3{grid-template-columns:1.2fr .9fr .9fr}}
#pro-footer h4{margin:0 0 12px;font-size:1.05rem;color:#fff;font-weight:800;letter-spacing:.2px}
#pro-footer p,#pro-footer li,#pro-footer a{font-size:.95rem;line-height:1.55}
#pro-footer a{color:#9bd2ff;text-decoration:none}
#pro-footer a:hover{text-decoration:underline}
#pro-footer .brand{display:flex;align-items:flex-start;gap:14px}
#pro-footer .brand-logo{width:56px;height:56px;border-radius:12px;object-fit:contain;background:#0b1426;border:1px solid #15223a}
#pro-footer .muted{color:#94a3b8}
#pro-footer .list{list-style:none;margin:0;padding:0;display:grid;gap:8px}
#pro-footer .chip{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid #20314f;border-radius:999px;background:#0b1426;color:#cfe7ff}
#pro-footer .bar{margin-top:32px;border-top:1px solid #15223a}
#pro-footer .bar-in{display:flex;flex-direction:column;gap:10px;justify-content:space-between;align-items:flex-start;padding:16px 0;color:#9fb3d1}
@media(min-width:900px){#pro-footer .bar-in{flex-direction:row;align-items:center}}
:root{
--wa:#25D366; --wa-dark:#128C7E; --wa-darker:#075E54;
--dark-bg:#0b0f18; --darker-bg:#0a1324;
--light-text:#ffffff; --muted-text:rgba(255,255,255,.7);
}
.wa-float{ position:fixed; right:18px; bottom:18px; z-index:9999; font-family:inherit; }
.wa-btn{
background:linear-gradient(135deg,var(--wa),var(--wa-dark));
color:#fff; border:0; width:60px; height:60px; border-radius:50%;
display:grid; place-items:center; box-shadow:0 10px 30px rgba(0,0,0,.25);
cursor:pointer; transition:transform .3s, box-shadow .3s, background .3s; position:relative; overflow:hidden;
}
.wa-btn::after{ content:""; position:absolute; inset:0;
background:radial-gradient(circle at 50% 50%, rgba(255,255,255,.18), rgba(255,255,255,0) 70%);
opacity:0; transition:opacity .3s;
}
.wa-btn:hover{ transform:translateY(-3px) scale(1.05); box-shadow:0 14px 36px rgba(0,0,0,.35); }
.wa-btn:hover::after{ opacity:1; }
.wa-card{
position:absolute; right:0; bottom:74px; width:min(360px,92vw);
background:var(--dark-bg); color:var(--light-text); border-radius:18px; overflow:hidden;
box-shadow:0 18px 60px rgba(0,0,0,.5); border:1px solid rgba(255,255,255,.08);
transform:translateY(10px); opacity:0; transition:transform .3s, opacity .3s;
}
.wa-card[aria-modal="true"]{ transform:translateY(0); opacity:1; }
.wa-head{ display:flex; align-items:center; gap:12px; padding:14px;
background:linear-gradient(180deg,#0d162c,var(--darker-bg)); border-bottom:1px solid rgba(255,255,255,.06);
}
.wa-avatar{ width:40px; height:40px; border-radius:8px; background:#0e1a33;
display:grid; place-items:center; border:1px solid rgba(255,255,255,.08); overflow:hidden; }
.wa-title{ font-weight:700; font-size:1.05rem; }
.wa-status{ font-size:.85rem; color:var(--muted-text); display:flex; align-items:center; gap:6px; }
.wa-status::before{ content:""; width:8px; height:8px; border-radius:50%; background:var(--wa); }
.wa-close{ margin-left:auto; background:transparent; color:#fff; border:0; font-size:24px; cursor:pointer; opacity:.7;
width:32px; height:32px; border-radius:50%; display:flex; align-items:center; justify-content:center; transition:.2s; }
.wa-close:hover{ opacity:1; background:rgba(255,255,255,.1); }
.wa-body{ padding:12px 14px; max-height:40vh; overflow:auto; background:var(--dark-bg);
display:flex; flex-direction:column; gap:8px; }
.wa-bubble{ max-width:88%; padding:10px 12px; border-radius:14px; line-height:1.35; box-shadow:0 4px 14px rgba(0,0,0,.25); animation:fadeIn .25s ease; }
@keyframes fadeIn{ from{opacity:0; transform:translateY(5px)} to{opacity:1; transform:none} }
.wa-bot{ background:#0c1428; border:1px solid rgba(255,255,255,.06); align-self:flex-start; border-bottom-left-radius:4px; }
.wa-user{ background:var(--wa-darker); align-self:flex-end; border-bottom-right-radius:4px; }
.wa-compose{ display:grid; grid-template-columns:1fr auto; gap:8px; padding:10px; background:var(--dark-bg); border-top:1px solid rgba(255,255,255,.08); }
.wa-compose textarea{
resize:none; border-radius:12px; padding:10px 12px; border:1px solid rgba(255,255,255,.12);
background:#0a1324; color:var(--light-text); outline:none; min-height:44px; font-family:inherit; transition:.2s;
}
.wa-compose textarea:focus{ border-color:var(--wa); box-shadow:0 0 0 2px rgba(37,211,102,.15); }
.wa-send{ background:var(--wa); color:#0b1220; border:0; border-radius:12px; padding:0 16px; font-weight:700; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:.2s; }
.wa-send:hover{ background:var(--wa-dark); transform:scale(1.05); }
/* Scrollbar */
.wa-body::-webkit-scrollbar{ width:6px; }
.wa-body::-webkit-scrollbar-track{ background:rgba(255,255,255,.05); border-radius:3px; }
.wa-body::-webkit-scrollbar-thumb{ background:rgba(255,255,255,.2); border-radius:3px; }
.wa-body::-webkit-scrollbar-thumb:hover{ background:rgba(255,255,255,.3); }
/* Responsive */
@media (max-width:480px){
.wa-float{ right:12px; bottom:12px; }
.wa-card{ width:calc(100vw - 24px); right:0; }
}
zepolrepuestos.com.ar
https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.csshttps://cdn.jsdelivr.net/npm/[email protected]/font/bootstrap-icons.csshttps://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap:root {
--zp-white: #ffffff;
--zp-black: #111111;
--zp-yellow: #ffde32;
--zp-yellow-light: #fff8d6;
--zp-yellow-dark: #e6c82d;
--zp-ink: #111111;
--zp-muted: #6b7280;
--zp-line: #e5e7eb;
--zp-bg-light: #f9fafb;
--zp-card-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
--zp-card-shadow-hover: 0 10px 30px rgba(0, 0, 0, 0.1);
--zp-radius: 16px;
--zp-radius-lg: 24px;
--transition: all 0.3s ease;
}
* {
box-sizing: border-box;
}
html, body {
font-family: 'Inter', sans-serif;
background: var(--zp-white);
color: var(--zp-ink);
scroll-behavior: smooth;
line-height: 1.6;
overflow-x: hidden;
}
a {
color: var(--zp-ink);
text-decoration: none;
transition: var(--transition);
}
a:hover {
color: var(--zp-yellow-dark);
}
.btn-zp {
background: var(--zp-yellow);
color: #111;
font-weight: 600;
border: none;
border-radius: 8px;
padding: 12px 24px;
transition: var(--transition);
box-shadow: 0 4px 12px rgba(255, 222, 50, 0.3);
}
.btn-zp:hover {
background: var(--zp-yellow-dark);
transform: translateY(-2px);
box-shadow: 0 6px 16px rgba(255, 222, 50, 0.4);
}
.btn-outline-zp {
border: 2px solid var(--zp-yellow);
color: var(--zp-ink);
background: transparent;
font-weight: 600;
border-radius: 8px;
padding: 10px 22px;
transition: var(--transition);
}
.btn-outline-zp:hover {
background: var(--zp-yellow);
color: var(--zp-ink);
transform: translateY(-2px);
box-shadow: 0 4px 12px rgba(255, 222, 50, 0.3);
}
.section {
padding: 100px 0;
}
.section-soft {
background: var(--zp-bg-light);
position: relative;
}
.section-soft::before {
content: '';
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: linear-gradient(135deg, rgba(255, 222, 50, 0.03) 0%, transparent 100%);
pointer-events: none;
}
.eyebrow {
letter-spacing: 0.15em;
color: var(--zp-muted);
text-transform: uppercase;
font-size: 0.85rem;
font-weight: 600;
display: inline-block;
margin-bottom: 12px;
}
.rule {
height: 1px;
background: var(--zp-line);
margin: 20px 0 30px;
}
.nt-container {
max-width: 1200px;
margin: 0 auto;
padding: 0 20px;
}
/* Navbar mejorada */
.navbar {
background: rgba(255, 255, 255, 0.95);
backdrop-filter: blur(10px);
border-bottom: 1px solid var(--zp-line);
padding: 15px 0;
transition: var(--transition);
}
.navbar.scrolled {
padding: 10px 0;
box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}
.brand-zepol {
font-weight: 800;
letter-spacing: 0.06em;
color: var(--zp-ink);
font-size: 1.5rem;
display: flex;
align-items: center;
}
.brand-zepol .z {
color: var(--zp-yellow);
background: var(--zp-ink);
padding: 4px 8px;
border-radius: 6px;
margin-right: 4px;
}
.navbar .nav-link {
color: #334155 !important;
font-weight: 500;
padding: 8px 16px !important;
border-radius: 8px;
transition: var(--transition);
margin: 0 4px;
}
.navbar .nav-link:hover {
color: var(--zp-ink) !important;
background: var(--zp-yellow-light);
}
.navbar-toggler {
border: none;
padding: 4px 8px;
}
.navbar-toggler:focus {
box-shadow: none;
}
.navbar-toggler-icon {
background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(17,17,17,.8)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
width: 1.2em;
height: 1.2em;
}
.whats-cta {
background: var(--zp-yellow);
color: #111;
font-weight: 700;
border-radius: 8px;
padding: 10px 20px;
transition: var(--transition);
box-shadow: 0 4px 12px rgba(37, 211, 102, 0.3);
}
.whats-cta:hover {
background: #25d366;
color: white;
transform: translateY(-2px);
box-shadow: 0 6px 16px rgba(37, 211, 102, 0.4);
}
.whats-cta i {
margin-right: 8px;
}
/* Hero mejorado */
.hero {
padding: 160px 0 100px;
background:
radial-gradient(ellipse at 50% -10%, rgba(255, 222, 50, 0.15) 0%, transparent 60%),
linear-gradient(180deg, #ffffff 0%, #fefefe 100%);
position: relative;
overflow: hidden;
}
.hero::before {
content: '';
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11 18c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm48 25c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm-43-7c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zm63 31c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zM34 90c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zm56-76c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zM12 86c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm28-65c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm23-11c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm-6 60c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm29 22c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zM32 63c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm57-13c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm-9-21c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM60 91c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM35 41c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM12 60c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2z' fill='%23ffde32' fill-opacity='0.03' fill-rule='evenodd'/%3E%3C/svg%3E");
opacity: 0.5;
z-index: 0;
}
.hero-content {
position: relative;
z-index: 1;
}
.hero h1 {
font-weight: 800;
line-height: 1.1;
font-size: 3.5rem;
margin-bottom: 1.5rem;
}
.hero .lead {
color: #4b5563;
font-size: 1.25rem;
margin-bottom: 2rem;
}
.hero-bullets {
list-style: none;
padding: 0;
margin: 1.5rem 0;
}
.hero-bullets li {
margin: 0.5rem 0;
color: #4b5563;
display: flex;
align-items: center;
}
.hero-bullets li::before {
content: '';
display: inline-block;
width: 8px;
height: 8px;
background: var(--zp-yellow);
border-radius: 50%;
margin-right: 12px;
}
.hero-actions {
display: flex;
gap: 16px;
margin-top: 2rem;
flex-wrap: wrap;
}
/* Card mejorada */
.card-zp {
background: #fff;
border: 1px solid var(--zp-line);
border-radius: var(--zp-radius);
padding: 24px;
transition: var(--transition);
height: 100%;
box-shadow: var(--zp-card-shadow);
}
.card-zp:hover {
transform: translateY(-5px);
box-shadow: var(--zp-card-shadow-hover);
}
.card-zp .icon {
font-size: 2.5rem;
color: var(--zp-yellow);
margin-bottom: 1rem;
}
.grid-3 {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 24px;
}
@media (max-width: 992px) {
.grid
/* ...cortado... */
/* ====== Scope hero ====== */
.hero .nt-container{position:relative}
.hero .hero-media{
display:flex; justify-content:center; align-items:center;
margin-bottom:18px;
}
.hero .hero-media img{
width:100%; max-width:480px; height:auto;
border-radius:14px;
border:3px solid var(--zp-yellow);
box-shadow:0 14px 36px rgba(0,0,0,.12);
object-fit:contain;
background:#fff;
padding:10px; /* margen interno para logos */
}
.hero .hero-info.card{
background:#fff; border-radius:14px; border:1px solid #e5e7eb;
box-shadow:0 10px 28px rgba(0,0,0,.08);
}
.hero .rule{border:0; border-top:1px solid #e5e7eb; margin:14px 0}
/* Botón mini amarillo bordeado */
.hero .btn-mini{
display:inline-flex; align-items:center; gap:8px;
padding:8px 12px; font-size:.92rem; font-weight:600;
border:2px solid var(--zp-yellow); border-radius:10px; background:#fff;
text-decoration:none; color:#111827; transition:.15s ease;
}
.hero .btn-mini:hover{transform:translateY(-1px); background:rgba(241,196,15,.08)}
.hero .btn-mini .bi{font-size:1rem}
/* Tipos dentro de la card */
.hero .info-title{font-size:1.05rem; font-weight:800; margin:0}
.hero .info-sub{color:#6b7280; margin:2px 0 0}
/* ====== Responsive ====== */
@media (max-width: 991.98px){
.hero .hero-media img{max-width:420px}
}
@media (max-width: 575.98px){
.hero .hero-media img{max-width:360px; padding:8px}
}
#trabajos .ticker-wrap{position:relative}
#trabajos .ticker-track{
display:flex; gap:14px;
overflow-x:auto; overflow-y:hidden;
scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch;
padding-bottom:6px;
}
#trabajos .ticker-track::-webkit-scrollbar{height:8px}
#trabajos .ticker-track::-webkit-scrollbar-thumb{background:#e5e7eb; border-radius:6px}
#trabajos .ticker-item{flex:0 0 auto; scroll-snap-align:start; display:flex; align-items:center; justify-content:center}
#trabajos .ticker-item img{
/* clave para NO estirar imágenes */
width:auto !important; height:auto !important;
max-height:clamp(140px,22vw,260px);
max-width:100%;
object-fit:contain; aspect-ratio:auto;
display:block; background:#fff; padding:6px;
border:1px solid #ececec; border-radius:14px;
box-shadow:0 10px 24px rgba(0,0,0,.08);
}
#trabajos .ticker-controls{
position:absolute; inset:0; pointer-events:none;
display:flex; align-items:center; justify-content:space-between; padding:0 4px;
}
#trabajos .ticker-btn{
pointer-events:auto; width:42px; height:42px; border-radius:999px;
border:2px solid var(--zp-yellow); background:#fff;
box-shadow:0 6px 18px rgba(0,0,0,.12);
display:grid; place-items:center; cursor:pointer;
transition:transform .08s ease, background .2s ease;
}
#trabajos .ticker-btn:hover{transform:translateY(-1px); background:rgba(241,196,15,.08)}
@media (max-width:575.98px){
#trabajos .ticker-item img{max-height:clamp(120px,36vw,220px); padding:5px}
}
/* ===== Modal ===== */
#trabajos .gal-modal{position:fixed; inset:0; z-index:1050; display:none}
#trabajos .gal-backdrop{position:absolute; inset:0; background:rgba(0,0,0,.78)}
#trabajos .gal-stage{position:absolute; inset:48px 20px 20px; display:grid; place-items:center}
#trabajos .gal-img{max-width:100%; max-height:100%; width:auto; height:auto; border-radius:12px; background:#fff; padding:10px}
#trabajos .gal-btn{position:absolute; width:42px; height:42px; border-radius:999px; border:2px solid #fff; background:transparent; color:#fff; display:grid; place-items:center; cursor:pointer}
#trabajos .gal-close{top:10px; right:12px}
#trabajos .gal-prev{top:50%; left:12px; transform:translateY(-50%)}
#trabajos .gal-next{top:50%; right:12px; transform:translateY(-50%)}
@media (max-width:575.98px){ #trabajos .gal-stage{inset:72px 10px 10px} }
.zp-footer-dark{
--ink:#fff;
--muted:#cbd5e1;
--edge:#21262d;
background:#0b0b0b; color:var(--ink);
border-top:1px solid var(--edge);
padding:44px 0 26px;
}
.zp-footer-dark a{color:var(--ink); text-decoration:none}
.zp-footer-dark a:hover{color:#fff; text-decoration:underline}
.zp-footer-dark .brand{
display:flex; align-items:center; gap:12px;
}
.zp-footer-dark .brand-chip{
display:inline-flex; align-items:center; justify-content:center;
background:#111; border:2px solid var(--zp-yellow); border-radius:10px;
padding:6px 8px; box-shadow:0 6px 18px rgba(0,0,0,.4);
}
.zp-footer-dark .brand-chip img{height:28px; width:auto; display:block}
.zp-footer-dark .brand h5{font-weight:800; margin:0; color:#fff}
.zp-footer-dark .muted{color:var(--muted)}
.zp-footer-dark .ft-title{
font-weight:800; letter-spacing:.02em; margin-bottom:10px;
font-size:.95rem; color:#fff;
}
.zp-footer-dark .link-list a{
display:flex; align-items:center; gap:8px; padding:6px 0;
color:var(--muted);
}
.zp-footer-dark .link-list a:hover{color:#fff}
/* Botones */
.zp-footer-dark .wa-btn{
display:inline-flex; align-items:center; gap:10px;
background:var(--zp-yellow); color:#0b0b0b; font-weight:700;
border-radius:12px; padding:10px 14px; border:2px solid var(--zp-yellow);
}
.zp-footer-dark .wa-btn:hover{filter:brightness(0.98)}
.zp-footer-dark .to-top{
display:inline-flex; align-items:center; gap:8px;
border:2px solid var(--zp-yellow); color:#fff; background:transparent;
border-radius:999px; padding:8px 12px; font-weight:700;
}
.zp-footer-dark .to-top:hover{background:rgba(241,196,15,.12)}
.zp-footer-dark .rule{border:0; border-top:1px solid var(--edge); margin:20px 0}
.zp-footer-dark .mini{font-size:.92rem}
:root{
--wa: #25D366; --wa-dark: #128C7E; --wa-darker: #075E54;
--fb1:#1877F2; --fb2:#0d5adf;
--dark-bg: #0b0f18; --darker-bg: #0a1324;
--light-text: #ffffff; --muted-text: rgba(255,255,255,.7);
}
.wa-float{
position: fixed; right: 18px; bottom: 18px; z-index: 2147483647; font-family: inherit;
display:flex; flex-direction:column; gap:10px; align-items:flex-end;
}
/* FB arriba */
.fb-btn{
width:56px;height:56px;border-radius:50%;display:grid;place-items:center;
text-decoration:none;background:linear-gradient(135deg,var(--fb1),var(--fb2));color:#fff;
box-shadow:0 10px 28px rgba(0,0,0,.18);transition:transform .25s, box-shadow .25s;
}
.fb-btn:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(0,0,0,.24)}
/* WA botón */
.wa-btn{
background: linear-gradient(135deg, var(--wa), var(--wa-dark));
color:#fff; border:0; width:60px; height:60px; border-radius:50%;
display:grid; place-items:center; box-shadow:0 10px 30px rgba(0,0,0,.25);
cursor:pointer; transition:transform .3s, box-shadow .3s, background .3s; position:relative; overflow:hidden;
}
.wa-btn::after{ content:""; position:absolute; inset:0;
background: radial-gradient(circle at 50% 50%, rgba(255,255,255,.18), rgba(255,255,255,0) 70%); opacity:0; transition:opacity .3s;
}
.wa-btn:hover{ transform: translateY(-3px) scale(1.05); box-shadow:0 14px 36px rgba(0,0,0,.35); }
.wa-btn:hover::after{ opacity:1; }
/* WA card (conversación) */
.wa-card{
position:absolute; right:0; bottom:74px; width:min(360px, 92vw);
background: var(--dark-bg); color: var(--light-text); border-radius:18px; overflow:hidden;
box-shadow: 0 18px 60px rgba(0,0,0,.5); border:1px solid rgba(255,255,255,.08);
transform: translateY(10px); opacity:0; transition: transform .25s, opacity .25s;
}
.wa-card[aria-modal="true"]{ transform: translateY(0); opacity:1; }
.wa-head{ display:flex; align-items:center; gap:12px; padding:14px;
background: linear-gradient(180deg, #0d162c, var(--darker-bg)); border-bottom:1px solid rgba(255,255,255,.06);
}
.wa-avatar{
width:40px; height:40px; border-radius:8px; background:#0e1a33;
display:grid; place-items:center; border:1px solid rgba(255,255,255,.08); overflow:hidden;
}
.wa-title{ font-weight:700; font-size:1.05rem; }
.wa-status{ font-size:.85rem; color:var(--muted-text); display:flex; align-items:center; gap:6px; }
.wa-status::before{ content:""; width:8px; height:8px; border-radius:50%; background: var(--wa); }
.wa-close{
margin-left:auto; background:transparent; color:#fff; border:0; font-size:24px; cursor:pointer; opacity:.7;
width:32px; height:32px; border-radius:50%; display:flex; align-items:center; justify-content:center; transition:.2s;
}
.wa-close:hover{ opacity:1; background: rgba(255,255,255,.1); }
.wa-body{ padding:12px 14px; max-height:40vh; overflow:auto; background: var(--dark-bg);
display:flex; flex-direction:column; gap:8px; }
.wa-bubble{ max-width:88%; padding:10px 12px; border-radius:14px; line-height:1.35; box-shadow:0 4px 14px rgba(0,0,0,.25); animation:fadeIn .25s ease; }
@keyframes fadeIn{ from{opacity:0; transform:translateY(5px)} to{opacity:1; transform:none} }
.wa-bot{ background:#0c1428; border:1px solid rgba(255,255,255,.06); align-self:flex-start; border-bottom-left-radius:4px; }
.wa-user{ background: var(--wa-darker); align-self:flex-end; border-bottom-right-radius:4px; }
.wa-compose{ display:grid; grid-template-columns:1fr auto; gap:8px; padding:10px; background: var(--dark-bg); border-top:1px solid rgba(255,255,255,.08); }
.wa-compose textarea{
resize:none; border-radius:12px; padding:10px 12px; border:1px solid rgba(255,255,255,.12);
background:#0a1324; color:var(--light-text); outline:none; min-height:44px; font-family:inherit; transition:.2s;
}
.wa-compose textarea:focus{ border-color: var(--wa); box-shadow: 0 0 0 2px rgba(37,211,102,.15); }
.wa-send{ background: var(--wa); color:#0b1220; border:0; border-radius:12px; padding:0 16px; font-weight:700; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:.2s; }
.wa-send:hover{ background: var(--wa-dark); transform: scale(1.05); }
/* Scrollbar */
.wa-body::-webkit-scrollbar{ width:6px; } .wa-body::-webkit-scrollbar-track{ background: rgba(255,255,255,.05); border-radius:3px; }
.wa-body::-webkit-scrollbar-thumb{ background: rgba(255,255,255,.2); border-radius:3px; } .wa-body::-webkit-scrollbar-thumb:hover{ background: rgba(255,255,255,.3); }
/* Responsive */
@media (max-width: 480px){
.wa-float{ right:12px; bottom:12px; }
.wa-card{ width: calc(100vw - 24px); right:0; }
}
radioeadtc.com/admin
<link rel="stylesheet"> en el archivo.body{font-family:system-ui,Segoe UI,Roboto,Arial,sans-serif;margin:0}
.header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #eee}
.container{max-width:1100px;margin:16px auto;padding:0 16px}
a.btn{display:inline-block;background:#1f72b6;color:#fff;padding:10px 14px;border-radius:10px;text-decoration:none;font-weight:700}
table{width:100%;border-collapse:collapse} th,td{padding:10px;border-bottom:1px solid #eee;text-align:left}
.badge{padding:4px 8px;border-radius:6px;font-size:12px}
.badge.pub{background:#e6f6ec;color:#136c2e}.badge.bor{background:#fcefe6;color:#874400}
construccionesfrank.com.ar
https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.csshttps://cdn.jsdelivr.net/npm/[email protected]/font/bootstrap-icons.csshttps://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap/* === HOTFIX: centrar todo y eliminar cualquier overflow residual sin mover tu layout === */
html, body { width:100%; overflow-x:hidden; }
.container { margin-inline:auto; max-width:1140px; }
.hero-box { margin-inline:auto; }
/* botones del ticker INSIDE el frame para que no empujen el viewport */
.gallery-prev{ left:12px; }
.gallery-next{ right:12px; }
/* tarjetas de la galería se ajustan un poco más en móviles angostos */
.gallery-item{ max-width:86vw; }
/* elementos fijos sin desbordar */
#fc-fabs, #fc-waCard, footer, .navbar { overflow-x:hidden; }
/* asegurar que filas no generen margen negativo fuera del container */
main .row { margin-left: calc(var(--bs-gutter-x) * -0.5); margin-right: calc(var(--bs-gutter-x) * -0.5); }
@media (max-width: 576px){
main .row { margin-left: 0; margin-right: 0; }
}
/* ====== Base palette (naranja) ====== */
:root {
--primary: #ff601a;
--primary-dark: #e05515;
--primary-light: #ff7a3d;
--secondary: #f59e0b;
--dark: #0f172a;
--darker: #0a0f1c;
--light: #f8fafc;
--muted: #64748b;
--card: #ffffff;
--soft: #fef6f2;
--gradient-primary: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
--gradient-dark: linear-gradient(135deg, var(--dark) 0%, var(--darker) 100%);
--shadow-sm: 0 2px 4px rgba(0,0,0,0.05);
--shadow: 0 4px 6px -1px rgba(0,0,0,0.1), 0 2px 4px -1px rgba(0,0,0,0.06);
--shadow-lg: 0 10px 15px -3px rgba(0,0,0,0.1), 0 4px 6px -2px rgba(0,0,0,0.05);
--shadow-xl: 0 20px 25px -5px rgba(0,0,0,0.1), 0 10px 10px -5px rgba(0,0,0,0.04);
--radius: 12px;
--radius-lg: 16px;
--transition: all 0.3s ease;
}
* { box-sizing: border-box; }
html, body { height: 100%; scroll-behavior: smooth; }
body {
display: flex; flex-direction: column; min-height: 100vh;
font-family: 'Inter', sans-serif; color: var(--dark); background-color: var(--light);
overflow-x: hidden; /* evita scroll horizontal */
}
main { flex: 1 0 auto; }
/* ====== Navbar (fix: toggler visible + sin overflow) ====== */
.navbar.navbar-light { /* usar .navbar-light para que el ícono hamburguesa se vea */
background-color: rgba(255,255,255,0.95);
backdrop-filter: blur(10px);
box-shadow: var(--shadow-sm);
padding: 1rem 0;
transition: var(--transition);
}
.navbar-brand {
font-weight: 800; font-size: 1.5rem;
background: var(--gradient-primary);
-webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.navbar .nav-link { font-weight: 500; position: relative; padding: .5rem 1rem; transition: var(--transition); }
.navbar .nav-link:after {
content: ''; position: absolute; bottom: 0; left: 50%; width: 0; height: 2px;
background: var(--gradient-primary); transition: var(--transition); transform: translateX(-50%);
}
.navbar .nav-link:hover:after, .navbar .nav-link.active:after { width: 80%; }
.navbar-toggler { border: 0; }
.navbar-toggler:focus { box-shadow: 0 0 0 .15rem rgba(255,96,26,.35); }
.btn-cta { white-space: nowrap; background: var(--gradient-primary); border: none; font-weight: 600;
padding: .6rem 1.2rem; border-radius: var(--radius); transition: var(--transition); box-shadow: var(--shadow); }
.btn-cta:hover { transform: translateY(-2px); box-shadow: var(--shadow-lg); }
/* ====== Hero blanco delimitado, logo a la derecha ====== */
#inicio { position: relative; min-height: 100vh; display:flex; align-items:center; padding-top:5rem; padding-bottom:3rem; overflow: clip; }
.hero-white{ background:#fff; }
.hero-box{ background:#fff; border:1px solid #e5e7eb; border-radius:16px; box-shadow:0 10px 25px rgba(0,0,0,.06);
padding: clamp(1.25rem, 3vw, 2.25rem); }
.hero-grid{ display:grid; grid-template-columns: 1.1fr 0.9fr; align-items:center; gap: clamp(1rem, 3vw, 3rem); }
.hero-content { color: var(--dark); max-width: 800px; }
.hero-badge{ display:inline-block; background: rgba(255,96,26,.1); padding:.5rem 1rem; border-radius: 50px; font-size:.875rem;
font-weight:600; margin-bottom:1.5rem; letter-spacing:.05em; color: var(--primary-dark); }
.hero-title{ font-size: clamp(2.5rem, 5vw, 4rem); font-weight: 800; line-height:1.1; margin-bottom:1.5rem; color:#111; }
.hero-subtitle{ font-size: clamp(1.1rem, 2vw, 1.25rem); opacity:.95; margin-bottom:2rem; line-height:1.6; color:#1f2937; }
.hero-actions{ display:flex; gap:1rem; flex-wrap:wrap; }
.btn-hero-primary{ background: var(--primary); color:#fff; font-weight:600; padding:.75rem 1.5rem; border-radius: var(--radius);
transition: var(--transition); box-shadow: var(--shadow); }
.btn-hero-primary:hover{ background: var(--primary-dark); transform: translateY(-2px); box-shadow: var(--shadow-lg); }
.btn-hero-secondary{ background: transparent; color: var(--primary); font-weight:600; padding:.75rem 1.5rem; border-radius: var(--radius);
border:1px solid var(--primary); transition: var(--transition); }
.btn-hero-secondary:hover{ background: var(--primary); color:#fff; transform: translateY(-2px); }
.hero-media{ display:flex; justify-content:center; align-items:center; }
.hero-logo-xl{ width: clamp(240px, 32vw, 440px); max-height: 520px; object-fit: contain; display:block; }
/* ====== Sections ====== */
.section { padding: 5rem 0; }
.section-soft{ background: var(--soft); }
.section-dark{ background: var(--gradient-dark); color:#fff; }
.eyebrow{ display:inline-block; letter-spacing:.08em; text-transform:uppercase; font-size:.875rem; font-weight:700; color: var(--primary);
margin-bottom:1rem; position: relative; }
.eyebrow:after{ content:''; position:absolute; bottom:-5px; left:0; width:40px; height:2px; background: var(--primary); }
.section-title{ font-size: clamp(2rem, 4vw, 2.5rem); font-weight:800; margin-bottom: 1rem; }
.section-subtitle{ font-size:1.125rem; color: var(--muted); max-width: 600px; margin: 0 auto 3rem; }
.section-dark .section-subtitle{ color: rgba(255,255,255,.8); }
/* ====== Cards ====== */
.card-modern{ background: var(--card); border-radius: var(--radius-lg); border:none; box-shadow: var(--shadow);
transition: var(--transition); overflow:hidden; height:100%; }
.card-modern:hover{ transform: translateY(-5px); box-shadow: var(--shadow-xl); }
.card-icon{ display:inline-flex; align-items:center; justify-content:center; width:60px; height:60px;
background: var(--gradient-primary); color:#fff; border-radius: var(--radius); font-size:1.5rem; margin-bottom:1.5rem; }
.card-title{ font-weight:700; margin-bottom: 1rem; }
.card-text{ color: var(--muted); }
/* ====== Gallery/Ticker (fix: sin desplazamiento lateral) ====== */
.gallery-frame{ position:relative; overflow:hidden; }
.gallery-viewport{ display:flex; gap:12px; overflow:auto; scroll-snap-type:x mandatory; padding-bottom: 2px;
-webkit-overflow-scrolling:touch; }
.gallery-viewport::-webkit-scrollbar{ height:8px; }
.gallery-viewport::-webkit-scrollbar-thumb{ background:#cbd5e1; border-radius:8px; }
.gallery-item{ flex:0 0 auto; width:500px; max-width:80vw; aspect-ratio:1/1; scroll-snap-align:center; border-radius:14px;
overflow:hidden; border:1px solid rgba(16,24,40,.08); position:relative; background:#eee; }
.gallery-item img{ width:100%; height:100%; object-fit:cover; display:block; }
.gallery-btn{ position:absolute; top:50%; transform:translateY(-50%);
background:rgba(255,255,255,.9); border:1px solid rgba(0,0,0,.1);
width:42px; height:42px; border-radius:50%; display:grid; place-items:center; }
.gallery-btn:focus{ outline:2px solid var(--primary);
/* ...cortado... */
:root{ --wa:#25D366; --wa-dark:#128C7E; --wa-darker:#075E54; --fb:#1877F2; --fb-dark:#0f5fcc; --dark:#0b0f18; --darker:#0a1324; --light:#fff; --muted:rgba(255,255,255,.7); --fab:60px; }
.fc-fabs{ position:fixed; right:clamp(12px,2vw,18px); bottom:clamp(12px,2vw,18px); z-index:2147483000; display:flex; flex-direction:column; gap:10px; align-items:flex-end; font-family:inherit }
.fc-backdrop{ position:fixed; inset:0; background:transparent; z-index:-1 }
.fc-btn{ width:var(--fab); height:var(--fab); border-radius:50%; display:grid; place-items:center; color:#fff; border:0; cursor:pointer; text-decoration:none; box-shadow:0 10px 30px rgba(0,0,0,.25); transition:.25s }
.fc-btn:hover{ transform:translateY(-3px) scale(1.05); box-shadow:0 14px 36px rgba(0,0,0,.35) }
.fc-wa{ background:linear-gradient(135deg,var(--wa),var(--wa-dark)) }
.fc-fb{ background:linear-gradient(135deg,var(--fb),var(--fb-dark)) }
.fc-card{ position:absolute; right:0; bottom:calc(var(--fab) + 14px); width:min(360px,92vw); background:var(--dark); color:var(--light); border-radius:18px; border:1px solid rgba(255,255,255,.08); box-shadow:0 18px 60px rgba(0,0,0,.5); transform:translateY(10px); opacity:0; transition:.22s; overflow:hidden }
.fc-card[aria-modal="true"]{ transform:translateY(0); opacity:1 }
.fc-head{ display:flex; align-items:center; gap:12px; padding:14px; background:linear-gradient(180deg,#0d162c,var(--darker)); border-bottom:1px solid rgba(255,255,255,.06) }
.fc-avatar{ width:40px; height:40px; border-radius:8px; background:#0e1a33; display:grid; place-items:center; border:1px solid rgba(255,255,255,.08); overflow:hidden }
.fc-title{ font-weight:700 }
.fc-status{ font-size:.85rem; color:var(--muted); display:flex; align-items:center; gap:6px }
.fc-status::before{ content:""; width:8px; height:8px; border-radius:50%; background:var(--wa) }
.fc-close{ margin-left:auto; background:transparent; color:#fff; border:0; font-size:24px; cursor:pointer; opacity:.75; width:32px; height:32px; border-radius:50% }
.fc-close:hover{ opacity:1; background:rgba(255,255,255,.08) }
.fc-body{ padding:12px 14px; max-height:40vh; overflow:auto; background:var(--dark); display:flex; flex-direction:column; gap:8px }
.fc-bubble{ max-width:88%; padding:10px 12px; border-radius:14px; line-height:1.35; box-shadow:0 4px 14px rgba(0,0,0,.25); animation:fcIn .2s ease }
@keyframes fcIn{ from{opacity:0; transform:translateY(5px)} to{opacity:1; transform:none} }
.fc-bot{ background:#0c1428; border:1px solid rgba(255,255,255,.06); align-self:flex-start; border-bottom-left-radius:4px }
.fc-user{ background:var(--wa-darker); align-self:flex-end; border-bottom-right-radius:4px }
.fc-compose{ display:grid; grid-template-columns:1fr auto; gap:8px; padding:10px; background:var(--dark); border-top:1px solid rgba(255,255,255,.08) }
.fc-compose textarea{ resize:none; border-radius:12px; padding:10px 12px; border:1px solid rgba(255,255,255,.12); background:#0a1324; color:#fff; min-height:44px; outline:none }
.fc-compose textarea:focus{ border-color:var(--wa); box-shadow:0 0 0 2px rgba(37,211,102,.15) }
.fc-send{ background:var(--wa); color:#0b1220; border:0; border-radius:12px; padding:0 16px; font-weight:700; cursor:pointer }
@media (max-width:480px){ :root{--fab:56px} .fc-card{ width:calc(100vw - 24px); right:0 } }
acquapiletas.com.ar
https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.csshttps://cdn.jsdelivr.net/npm/[email protected]/font/bootstrap-icons.csshttps://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800&family=Open+Sans:wght@300;400;500;600&display=swap:root {
--primary: #008dca;
--primary-dark: #006fa3;
--secondary: #00b3e3;
--accent: #00c9b7;
--dark: #0d1117;
--darker: #0a0e14;
--text: #1e293b;
--muted: #64748b;
--light: #f3f6fb;
--white: #ffffff;
--gradient-primary: linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);
--gradient-dark: linear-gradient(135deg, var(--dark) 0%, #1a2238 100%);
--shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
--shadow-lg: 0 20px 50px rgba(0, 0, 0, 0.12);
--radius: 16px;
--transition: all 0.3s ease;
}
* {
box-sizing: border-box;
}
body {
font-family: 'Open Sans', sans-serif;
color: var(--text);
background: var(--white);
line-height: 1.6;
scroll-behavior: smooth;
overflow-x: hidden;
}
h1, h2, h3, h4, h5, h6, .title {
font-family: 'Montserrat', sans-serif;
font-weight: 700;
line-height: 1.2;
}
.btn {
font-weight: 600;
border-radius: 50px;
padding: 12px 28px;
transition: var(--transition);
font-family: 'Montserrat', sans-serif;
}
.btn-primary {
background: var(--gradient-primary);
border: none;
box-shadow: 0 4px 15px rgba(0, 141, 202, 0.3);
}
.btn-primary:hover {
transform: translateY(-3px);
box-shadow: 0 8px 20px rgba(0, 141, 202, 0.4);
}
.btn-outline-primary {
border: 2px solid var(--primary);
color: var(--primary);
}
.btn-outline-primary:hover {
background: var(--primary);
color: white;
transform: translateY(-3px);
}
.text-muted {
color: var(--muted) !important;
}
.section {
padding: 100px 0;
}
.section-sm {
padding: 60px 0;
}
.section-soft {
background: var(--light);
position: relative;
}
.section-dark {
background: var(--gradient-dark);
color: white;
}
.eyebrow {
letter-spacing: 0.12em;
text-transform: uppercase;
font-size: 0.8rem;
color: var(--primary);
font-weight: 600;
display: inline-block;
margin-bottom: 12px;
font-family: 'Montserrat', sans-serif;
}
.title {
font-weight: 800;
margin-bottom: 1.5rem;
}
.lead-sm {
font-size: 1.1rem;
color: var(--text);
}
.card-soft {
background: var(--white);
border: none;
border-radius: var(--radius);
padding: 30px;
box-shadow: var(--shadow);
transition: var(--transition);
height: 100%;
}
.card-soft:hover {
transform: translateY(-10px);
box-shadow: var(--shadow-lg);
}
.badge-soft {
background: rgba(0, 141, 202, 0.1);
color: var(--primary-dark);
font-weight: 600;
padding: 8px 16px;
border-radius: 50px;
font-size: 0.85rem;
}
/* Navbar */
.navbar {
padding: 1rem 0;
background: rgba(255, 255, 255, 0.95);
backdrop-filter: saturate(1.8) blur(12px);
box-shadow: 0 2px 20px rgba(0, 0, 0, 0.05);
transition: var(--transition);
}
.navbar.scrolled {
padding: 0.5rem 0;
box-shadow: 0 5px 20px rgba(0, 0, 0, 0.08);
}
.navbar-brand {
font-weight: 800;
font-size: 1.8rem;
}
.navbar .nav-link {
font-weight: 600;
color: var(--text);
margin: 0 8px;
position: relative;
font-family: 'Montserrat', sans-serif;
}
.navbar .nav-link::after {
content: '';
position: absolute;
width: 0;
height: 2px;
bottom: 0;
left: 0;
background: var(--gradient-primary);
transition: var(--transition);
}
.navbar .nav-link:hover::after,
.navbar .nav-link.active::after {
width: 100%;
}
.navbar .btn {
padding: 8px 20px;
font-size: 0.9rem;
}
/* Hero */
.hero {
position: relative;
min-height: 100vh;
display: flex;
align-items: center;
isolation: isolate;
overflow: hidden;
}
.hero::before{content:none;}
.hero::after {
content: "";
position: absolute;
inset: 0;
background: linear-gradient(135deg, rgba(0, 0, 0, 0.6) 0%, rgba(0, 0, 0, 0.3) 100%);
z-index: -1;
}
.hero-content {
color: white;
max-width: 800px;
padding-top: 80px;
}
.hero h1 {
font-size: 3.5rem;
font-weight: 800;
margin-bottom: 1.5rem;
line-height: 1.1;
}
.hero p {
font-size: 1.2rem;
margin-bottom: 2rem;
opacity: 0.9;
}
.hero-badges {
display: flex;
flex-wrap: wrap;
gap: 10px;
margin-top: 2rem;
}
.hero-badge {
background: rgba(255, 255, 255, 0.15);
backdrop-filter: blur(10px);
border-radius: 50px;
padding: 8px 20px;
font-size: 0.9rem;
font-weight: 500;
}
/* Icon Boxes */
.icon-xl {
font-size: 2.5rem;
color: var(--primary);
margin-bottom: 1.5rem;
display: inline-block;
padding: 15px;
border-radius: 50%;
background: rgba(0, 141, 202, 0.1);
}
/* Gallery */
.gallery-frame {
position: relative;
margin-top: 2rem;
}
.gallery-viewport {
overflow: hidden;
scroll-snap-type: x mandatory;
display: flex;
gap: 20px;
scroll-behavior: smooth;
padding-bottom: 10px;
}
.gallery-item {
flex: 0 0 500px;
max-width: 500px;
scroll-snap-align: center;
border-radius: var(--radius);
overflow: hidden;
box-shadow: var(--shadow);
transition: var(--transition);
}
.gallery-item:hover {
transform: scale(1.03);
box-shadow: var(--shadow-lg);
}
.gallery-item img {
width: 100%;
height: 100%;
object-fit: cover;
aspect-ratio: 1/1;
}
.gallery-ctrl {
position: absolute;
inset: 0;
display: flex;
align-items: center;
justify-content: space-between;
pointer-events: none;
}
.gallery-ctrl .btn {
pointer-events: auto;
border-radius: 50%;
width: 50px;
height: 50px;
display: flex;
align-items: center;
justify-content: center;
background: rgba(255, 255, 255, 0.9);
box-shadow: var(--shadow);
border: none;
color: var(--primary);
}
.gallery-ctrl .btn:hover {
background: var(--white);
transform: scale(1.1);
}
.dots {
display: flex;
gap: 10px;
justify-content: center;
margin-top: 20px;
}
.dot {
width: 12px;
height: 12px;
border-radius: 50%;
background: #cbd5e1;
cursor: pointer;
transition: var(--transition);
}
.dot.active {
background: var(--primary);
transform: scale(1.2);
}
/* Accordion */
.accordion-item {
border: none;
border-radius: var(--radius) !important;
margin-bottom: 15px;
box-shadow: var(--shadow);
overflow: hidden;
}
.accordion-button {
font-weight: 600;
padding: 20px 25px;
background: var(--white);
border: none;
box-shadow: none;
}
.accordion-button:not(.collapsed) {
background: var(--white);
color: var(--primary);
box-shadow: none;
}
.accordion-button:focus {
box-shadow: none;
border: none;
}
.accordion-body {
padding: 0 25px 25px;
}
/* Form */
.form-control {
padding: 12px 18px;
borde
/* ...cortado... */
/* ===== Scope local de la sección ===== */
#servicios .feature-card{
text-align:center;
border-radius:16px;
background:#fff;
box-shadow:0 6px 22px rgba(2,12,34,.06);
padding:28px 22px;
height:100%;
}
#servicios .icon-wrap{
width:72px;height:72px;margin:0 auto 12px;
border-radius:50%;
display:flex;align-items:center;justify-content:center;
background:#e9f6ff; /* celeste suave */
}
#servicios .icon-wrap svg{
width:36px;height:36px;display:block;
stroke:#0ea5e9; /* azul acorde al logo */
fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;
}
#servicios .title{margin:0 0 6px;font-weight:700}
#servicios p{margin:0;color:#5f6b7a}
html, body {
height: 100%;
}
body {
display: flex;
flex-direction: column;
min-height: 100vh;
}
#site-footer {
margin-top: auto;
}
.hover-primary:hover {
color: var(--primary) !important;
}
/* ====== Paleta y layout ====== */
:root{
--ig: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
--fb: #1877F2;
--wa: #25D366;
--wa-dark: #128C7E;
--wa-darker: #075E54;
--dark-bg: #0b0f18;
--darker-bg: #0a1324;
--light: #ffffff;
--muted: rgba(255,255,255,.72);
}
#social-floats{
position: fixed;
right: 18px;
bottom: 18px;
z-index: 9999;
font-family: system-ui, -apple-system, sans-serif;
}
.sf-stack{
position: absolute;
right: 0;
bottom: 84px;
display: flex;
flex-direction: column;
gap: 10px;
}
.sf-btn{
width: 46px;
height: 46px;
border-radius: 999px;
display: grid;
place-items: center;
color: #fff;
text-decoration: none;
box-shadow: 0 8px 24px rgba(0,0,0,.28);
transform: translateZ(0);
transition: transform .25s, box-shadow .25s, opacity .25s;
}
.sf-btn:hover{
transform: translateY(-2px);
box-shadow: 0 12px 30px rgba(0,0,0,.34);
}
.sf-ig{
background: var(--ig);
}
.sf-fb{
background: var(--fb);
}
.wa-float{
position: relative;
}
.wa-btn{
background: var(--wa);
color: #fff;
border: 0;
width: 64px;
height: 64px;
border-radius: 50%;
display: grid;
place-items: center;
box-shadow: 0 12px 36px rgba(0,0,0,.28);
cursor: pointer;
transition: transform .3s, box-shadow .3s, background .3s;
position: relative;
overflow: hidden;
}
.wa-btn::after{
content: "";
position: absolute;
inset: 0;
background: radial-gradient(circle at 50% 50%, rgba(255,255,255,.18), rgba(255,255,255,0) 70%);
opacity: 0;
transition: opacity .3s;
}
.wa-btn:hover{
transform: translateY(-3px) scale(1.04);
box-shadow: 0 16px 42px rgba(0,0,0,.36);
background: var(--wa-dark);
}
.wa-btn:hover::after{
opacity: 1;
}
.wa-card{
position: absolute;
right: 0;
bottom: 78px;
width: min(380px, 92vw);
background: var(--dark-bg);
color: var(--light);
border-radius: 18px;
overflow: hidden;
box-shadow: 0 18px 60px rgba(0,0,0,.5);
border: 1px solid rgba(255,255,255,.08);
transform: translateY(10px);
opacity: 0;
transition: transform .3s, opacity .3s;
}
.wa-card[aria-modal="true"]{
transform: translateY(0);
opacity: 1;
}
.wa-head{
display: flex;
align-items: center;
gap: 12px;
padding: 14px;
background: linear-gradient(180deg, #0d162c, var(--darker-bg));
border-bottom: 1px solid rgba(255,255,255,.06);
}
.wa-avatar{
width: 40px;
height: 40px;
border-radius: 8px;
background: #0e1a33;
display: grid;
place-items: center;
border: 1px solid rgba(255,255,255,.08);
overflow: hidden;
}
.wa-title{
font-weight: 700;
font-size: 1.05rem;
}
.wa-status{
font-size: .85rem;
color: var(--muted);
display: flex;
align-items: center;
gap: 6px;
}
.wa-status::before{
content: "";
width: 8px;
height: 8px;
border-radius: 50%;
background: var(--wa);
}
.wa-close{
margin-left: auto;
background: transparent;
color: #fff;
border: 0;
font-size: 24px;
cursor: pointer;
opacity: .7;
width: 32px;
height: 32px;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
transition: .2s;
}
.wa-close:hover{
opacity: 1;
background: rgba(255,255,255,.1);
}
.wa-line{
margin-left: auto;
margin-right: 8px;
}
.wa-select{
appearance: none;
background: #0d1a33;
color: #fff;
border: 1px solid rgba(255,255,255,.12);
border-radius: 10px;
padding: 6px 8px;
font-size: .85rem;
}
.sr-only{
position: absolute;
width: 1px;
height: 1px;
padding: 0;
margin: -1px;
overflow: hidden;
clip: rect(0,0,0,0);
border: 0;
}
.wa-body{
padding: 12px 14px;
max-height: 40vh;
overflow: auto;
background: var(--dark-bg);
display: flex;
flex-direction: column;
gap: 8px;
}
.wa-bubble{
max-width: 88%;
padding: 10px 12px;
border-radius: 14px;
line-height: 1.35;
box-shadow: 0 4px 14px rgba(0,0,0,.25);
animation: fadeIn .25s ease;
}
@keyframes fadeIn{
from{
opacity: 0;
transform: translateY(5px);
}
to{
opacity: 1;
transform: none;
}
}
.wa-bot{
background: #0c1428;
border: 1px solid rgba(255,255,255,.06);
align-self: flex-start;
border-bottom-left-radius: 4px;
}
.wa-user{
background: var(--wa-darker);
align-self: flex-end;
border-bottom-right-radius: 4px;
}
.wa-compose{
display: grid;
grid-template-columns: 1fr auto;
gap: 8px;
padding: 10px;
background: var(--dark-bg);
border-top: 1px solid rgba(255,255,255,.08);
}
.wa-compose textarea{
resize: none;
border-radius: 12px;
padding: 10px 12px;
border: 1px solid rgba(255,255,255,.12);
background: #0a1324;
color: var(--light);
outline: none;
min-height: 44px;
font-family: inherit;
transition: .2s;
}
.wa-compose textarea:focus{
border-color: var(--wa);
box-shadow: 0 0 0 2px rgba(37,211,102,.15);
}
.wa-send{
background: var(--wa);
color: #fff;
border: 0;
border-radius: 12px;
padding: 0 16px;
font-weight: 700;
cursor: pointer;
display: flex;
align-items: center;
justify-content: center;
transition: .2s;
}
.wa-send:hover{
background: var(--wa-dark);
transform: scale(1.04);
}
.wa-body::-webkit-scrollbar{
width: 6px;
}
.wa-body::-webkit-scrollbar-track{
background: rgba(255,255,255,.05);
border-radius: 3px;
}
.wa-body::-webkit-scrollbar-thumb{
background: rgba(255,255,255,.2);
border-radius: 3px;
}
.wa-body::-webkit-scrollbar-thumb:hover{
background: rgba(255,255,255,.3);
}
@media (max-width: 480px){
#social-floats{
right: 12px;
bottom: 12px;
}
.sf-stack{
bottom: 78px;
}
.wa-card{
width: calc(100vw - 24px);
right: 0;
}
}