bataindustrials.com.ar
https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.csshttps://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swaphttps://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.1/css/all.min.css/* ===== Variables y configuración global ===== */
:root {
--primary: #009cde;
--primary-dark: #0085c7;
--secondary: #ff6b6b;
--dark: #1e293b;
--light: #f8fafc;
--gray: #64748b;
--gray-light: #e2e8f0;
--success: #10b981;
--border-radius: 12px;
--box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
--transition: all 0.3s ease;
}
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
body {
font-family: 'Inter', sans-serif;
color: var(--dark);
background-color: var(--light);
line-height: 1.6;
overflow-x: hidden;
}
h1, h2, h3, h4, h5, h6 {
font-weight: 700;
line-height: 1.2;
}
a {
text-decoration: none;
color: var(--primary);
transition: var(--transition);
}
img {
max-width: 100%;
height: auto;
}
.section {
padding: 100px 0;
position: relative;
}
.section-title {
font-size: 2.5rem;
margin-bottom: 1.5rem;
position: relative;
display: inline-block;
}
.section-title::after {
content: '';
position: absolute;
left: 0;
bottom: -10px;
width: 60px;
height: 4px;
background: var(--primary);
border-radius: 2px;
}
.section-subtitle {
color: var(--gray);
font-size: 1.2rem;
margin-bottom: 3rem;
max-width: 700px;
}
.btn {
padding: 12px 28px;
border-radius: 50px;
font-weight: 600;
transition: var(--transition);
border: none;
cursor: pointer;
display: inline-flex;
align-items: center;
gap: 8px;
}
.btn-primary {
background: var(--primary);
color: white;
box-shadow: 0 4px 15px rgba(0, 156, 222, 0.3);
}
.btn-primary:hover {
background: var(--primary-dark);
transform: translateY(-2px);
box-shadow: 0 6px 20px rgba(0, 156, 222, 0.4);
}
.btn-outline {
background: transparent;
border: 2px solid var(--primary);
color: var(--primary);
}
.btn-outline:hover {
background: var(--primary);
color: white;
transform: translateY(-2px);
}
/* ===== Navbar ===== */
.navbar {
padding: 20px 0;
background: rgba(255, 255, 255, 0.95) !important;
backdrop-filter: blur(10px);
box-shadow: 0 5px 20px rgba(0, 0, 0, 0.05);
transition: var(--transition);
}
.navbar-brand {
font-weight: 800;
font-size: 1.8rem;
color: var(--primary) !important;
display: flex;
align-items: center;
gap: 10px;
}
.navbar-brand i {
font-size: 1.5rem;
}
.nav-link {
font-weight: 500;
color: var(--dark) !important;
margin: 0 10px;
position: relative;
padding: 8px 0 !important;
}
.nav-link::after {
content: '';
position: absolute;
width: 0;
height: 2px;
bottom: 0;
left: 0;
background-color: var(--primary);
transition: var(--transition);
}
.nav-link:hover::after,
.nav-link.active::after {
width: 100%;
}
.navbar-toggler {
border: none;
padding: 0;
font-size: 1.5rem;
}
.navbar-toggler:focus {
box-shadow: none;
}
/* ===== Hero Section ===== */
#inicio {
padding: 150px 0 100px;
background: linear-gradient(135deg, rgba(0,156,222,0.1) 0%, rgba(255,255,255,1) 100%);
position: relative;
overflow: hidden;
}
#inicio::before {
content: '';
position: absolute;
width: 500px;
height: 500px;
border-radius: 50%;
background: linear-gradient(135deg, rgba(0,156,222,0.15) 0%, rgba(0,156,222,0.05) 100%);
top: -250px;
right: -250px;
z-index: 0;
}
#inicio::after {
content: '';
position: absolute;
width: 300px;
height: 300px;
border-radius: 50%;
background: linear-gradient(135deg, rgba(0,156,222,0.1) 0%, rgba(0,156,222,0.05) 100%);
bottom: -150px;
left: -150px;
z-index: 0;
}
.hero-content {
position: relative;
z-index: 2;
}
.hero-title {
font-size: 3.5rem;
font-weight: 800;
margin-bottom: 1.5rem;
color: var(--dark);
}
.hero-subtitle {
font-size: 1.2rem;
color: var(--gray);
margin-bottom: 2.5rem;
max-width: 600px;
}
.hero-buttons {
display: flex;
gap: 15px;
margin-bottom: 3rem;
}
.brand-badges {
display: flex;
flex-wrap: wrap;
gap: 20px;
align-items: center;
}
.brand-badge {
background: white;
padding: 15px 20px;
border-radius: var(--border-radius);
box-shadow: var(--box-shadow);
display: flex;
align-items: center;
transition: var(--transition);
}
.brand-badge:hover {
transform: translateY(-5px);
box-shadow: 0 15px 35px rgba(0, 0, 0, 0.1);
}
.brand-badge img {
height: 35px;
filter: grayscale(100%);
opacity: 0.7;
transition: var(--transition);
}
.brand-badge:hover img {
filter: grayscale(0);
opacity: 1;
}
.hero-image {
position: relative;
z-index: 2;
}
.hero-image img {
border-radius: var(--border-radius);
box-shadow: var(--box-shadow);
transform: perspective(1000px) rotateY(-10deg);
transition: var(--transition);
}
.hero-image:hover img {
transform: perspective(1000px) rotateY(0);
}
/* ===== About Section ===== */
#quienes {
background: white;
}
/* ===== Services Section ===== */
#servicios {
background: var(--light);
}
.service-card {
background: white;
padding: 30px;
border-radius: var(--border-radius);
box-shadow: var(--box-shadow);
transition: var(--transition);
height: 100%;
border-bottom: 4px solid transparent;
}
.service-card:hover {
transform: translateY(-10px);
border-bottom: 4px solid var(--primary);
}
.service-icon {
font-size: 2.5rem;
color: var(--primary);
margin-bottom: 20px;
}
.service-title {
font-size: 1.3rem;
margin-bottom: 15px;
}
.service-desc {
color: var(--gray);
}
/* ===== Why Choose Us Section ===== */
#elegirnos {
background: white;
}
.feature-card {
background: var(--light);
padding: 25px;
border-radius: var(--border-radius);
transition: var(--transition);
height: 100%;
display: flex;
flex-direction: column;
align-items: center;
text-align: center;
}
.feature-card:hover {
background: var(--primary);
color: white;
transform: translateY(-5px);
}
.feature-card:hover * {
color: white;
}
.feature-icon {
font-size: 2rem;
margin-bottom: 15px;
color: var(--primary);
transition: var(--transition);
}
.feature-card:hover .feature-icon {
color: white;
}
.feature-title {
font-size: 1.2rem;
margin-bottom: 10px;
}
.feature-desc {
font-size: 0.9rem;
}
/* ===== Portfolio Section ===== */
#trabajos {
background: linear-gradient(to bottom, var(--light) 0%, white 100%);
}
.portfolio-filter {
display: flex;
justify-content: center;
flex-wrap: wrap;
gap: 10px;
margin-bottom: 40px;
}
.filter-btn
/* ...cortado... */
/* Scale titles subtly on all sizes */
#tienda .tienda-head h2{
font-size: clamp(1.3rem, 1.05rem + 1.4vw, 2rem);
line-height: 1.2;
}
#tienda .tienda-sub{
font-size: clamp(0.95rem, 0.9rem + 0.4vw, 1.05rem);
}
/* Tablet adjustments */
@media (min-width: 577px) and (max-width: 991.98px){
#tienda iframe.store-frame{ min-height: 75vh; }
}
/* Phone-only adjustments */
@media (max-width: 576px){
#tienda{ padding-top: 24px; padding-bottom: 24px; }
#tienda .tienda-head h2{ margin-bottom: 4px; }
#tienda .tienda-sub{ color:#6a7680; }
/* Toolbar wraps & centers */
#tienda .tienda-toolbar{
justify-content:center; flex-wrap:wrap; gap:.5rem;
margin: 10px 0 12px;
}
#tienda .btn{ padding:.45rem .85rem; font-size:.95rem; line-height:1.1; }
/* Frame/container: softer radius & not-too-tall default */
#tienda .store-wrap{ border-radius:12px; }
#tienda iframe.store-frame{ min-height: 65vh; }
}
/* ==== Hero: tamaños rápidos ==== */
:root{
--hero-img-max: 760px; /* tamaño máximo de la imagen grande */
--hero-logo-h: 80px; /* alto de logos de marcas */
}
/* Imagen grande del hero */
.hero-image{ text-align:center; }
.hero-image img{
width: 100%;
max-width: var(--hero-img-max); /* << subí o bajá este valor */
height: auto;
}
/* Logos de marcas */
.brand-badges{
display:flex; flex-wrap:wrap; gap:16px 22px; align-items:center; margin-top:16px;
}
.brand-badge img{
height: var(--hero-logo-h); /* << ajustá acá el tamaño de cada logo */
width: auto; display:block;
filter: grayscale(100%); opacity:.9; transition:opacity .2s, filter .2s;
}
.brand-badge img:hover{ filter:none; opacity:1; }
/* En mobile los bajo un toque si querés */
@media (max-width: 991.98px){
:root{ --hero-img-max: 92vw; --hero-logo-h: 56px; }
}
/* ===== Estilos scoped a #tienda ===== */
#tienda{
--accent:#009cde;
--brd:#e8eef3;
--radius:16px;
--shadow:0 12px 30px rgba(0,0,0,.06);
}
#tienda .tienda-head h2{ font-weight:800; margin-bottom:6px; }
#tienda .tienda-sub{ color:#5f6b76; }
#tienda .tienda-toolbar{
display:flex; gap:.5rem; align-items:center; justify-content:flex-end;
margin:12px 0 8px;
}
#tienda .btn{
border-radius:999px; padding:.5rem .9rem;
}
#tienda .btn-accent{
background:var(--accent); color:#fff; border:0;
}
#tienda .btn-accent:hover{ filter:brightness(.95); }
#tienda .btn-outline{
background:#fff; color:#111; border:1px solid var(--brd);
}
#tienda .btn-outline:hover{ background:#f8fafc; }
/* Iframe contenedor */
#tienda .store-wrap{
border:1px solid var(--brd); border-radius:var(--radius); box-shadow:var(--shadow);
overflow:hidden; background:#fff;
}
#tienda iframe.store-frame{
width:100%; border:0; min-height:75vh; /* fallback inicial */
display:block;
}
@media (min-width: 992px){
#tienda iframe.store-frame{ min-height:900px; }
}
/* ====== Ajustes del ticker (scoped a #trabajos) ====== */
#trabajos{
--accent:#009cde;
--ticker-size: 500px; /* tamaño base desktop (tipo 500x500) */
--ticker-gap: 16px;
--brd:#e8eef3;
--tile-bg:#fff;
--ticker-fit: contain; /* ← mostrarlas completas según su contenido (cambiar a 'cover' si querés llenar) */
}
#trabajos .alx-ticker{
position:relative; border:1px solid var(--brd); border-radius:18px; background:#fff;
padding:16px; overflow:hidden;
}
#trabajos .alx-viewport{ overflow:hidden; }
#trabajos .alx-track{
display:flex; align-items:center; gap:var(--ticker-gap); will-change: transform;
}
/* Caja cuadrada que escala: ancho manda, alto se calcula por aspect-ratio */
#trabajos .tile{
width:var(--ticker-size);
aspect-ratio: 1 / 1; /* cuadrado flexible */
flex:0 0 auto;
border:1px solid var(--brd); border-radius:14px; overflow:hidden; background:var(--tile-bg);
user-select:none;
}
/* Mostrar imagen completa según su contenido (no recorta) */
#trabajos .tile img{
width:100%; height:100%; object-fit: var(--ticker-fit); object-position:center;
display:block;
}
#trabajos .alx-controls{
position:absolute; inset:auto 12px 12px 12px; display:flex; gap:8px; justify-content:space-between; pointer-events:none;
}
#trabajos .alx-controls .btn{
pointer-events:all; border-radius:999px; padding:.5rem .9rem; backdrop-filter:blur(6px);
border:1px solid rgba(255,255,255,.5); background:rgba(255,255,255,.9);
}
#trabajos .alx-controls .btn:hover{ background:#fff; }
/* Mobile: que el ancho de pantalla mande */
@media (max-width: 991.98px){
#trabajos .tile{ width: min(88vw, var(--ticker-size)); }
}
/* ====== Estilos scoped a #testimonios ====== */
#testimonios{
--accent: #009cde;
--bg-dark: #0b1420;
--card-bg: #0f1a28;
--card-brd: rgba(255,255,255,.08);
--text: #e2e8f0;
--text-muted: #9fb0c3;
--avatar-size: 64px; /* ⇐ cambiá tamaño de las fotos acá */
--card-radius: 16px; /* ⇐ radio de las tarjetas */
}
#testimonios{ background: var(--bg-dark); padding: 64px 0; }
#testimonios .section-title{ color:#fff; font-weight:800; margin-bottom:6px; }
#testimonios .section-subtitle{ color:#cbd5e1; }
#testimonios .testimonial-card{
background: var(--card-bg);
border: 1px solid var(--card-brd);
border-radius: var(--card-radius);
padding: 20px;
height: 100%;
color: var(--text);
box-shadow: 0 10px 30px rgba(0,0,0,.15);
}
#testimonios .testimonial-text{ color:#dbe3ec; margin-bottom: 14px; }
#testimonios .testimonial-author{
display:flex; align-items:center; gap:12px; margin-top:16px;
}
#testimonios .author-img{
width: var(--avatar-size);
height: var(--avatar-size);
border-radius: 50%;
object-fit: cover;
display: block;
flex-shrink: 0;
background: var(--accent);
border: 2px solid #fff; /* contraste con fondo oscuro */
}
#testimonios .author-name{ margin:0; color:#fff; font-weight:700; }
#testimonios .author-position{ margin:0; color:var(--text-muted); font-size:.95rem; }
/* Responsive */
@media (max-width: 991.98px){
#testimonios{ padding: 56px 0; }
#testimonios .testimonial-card{ padding:18px; }
}
:root{
/* —— Ajustes rápidos —— */
--wa-size: 72px; /* tamaño del botón (subí/bajá) */
--wa-x: 22px; /* separación horizontal al borde */
--wa-y: 22px; /* separación inferior */
--wa-z: 9999; /* z-index por encima de todo */
--wa-green: #25D366; /* color oficial */
--wa-green-2: #1ebe57; /* variante hover */
--wa-ring: #009cde; /* aro/acento de tu marca */
--wa-shadow: 0 14px 38px rgba(0,0,0,.28);
}
.wa-float{
position: fixed; right: var(--wa-x); bottom: var(--wa-y); z-index: var(--wa-z);
display: grid; place-items: center;
-webkit-tap-highlight-color: transparent;
}
.wa-btn{
position: relative; display: grid; place-items: center;
width: var(--wa-size); height: var(--wa-size);
border-radius: 50%;
background: radial-gradient(120% 120% at 30% 20%, #36e07a 0%, var(--wa-green) 45%, #18a54a 100%);
color:#fff; text-decoration:none; outline: none; border: 2px solid #fff;
box-shadow: var(--wa-shadow);
transform: translateZ(0); /* nitidez en GPU */
transition: transform .15s ease, filter .15s ease, background .2s ease;
isolation: isolate;
}
.wa-btn:hover{ transform: scale(1.04); filter: saturate(1.05); }
.wa-btn:active{ transform: scale(0.98); }
/* Halo/acento sutil (vector, no pixelado) */
.wa-btn::after{
content:""; position:absolute; inset:-8px; border-radius:50%;
border: 3px solid color-mix(in srgb, var(--wa-ring) 55%, transparent);
opacity:.65;
}
@media (prefers-reduced-motion: no-preference){
.wa-btn::after{
animation: wa-ring 1.8s ease-out infinite;
}
@keyframes wa-ring{
0%{ transform: scale(1); opacity:.55; }
70%{ transform: scale(1.22); opacity:0; }
100%{ transform: scale(1.22); opacity:0; }
}
}
/* SVG ultra nítido */
.wa-icon{
width: 58%; height: 58%;
display:block;
shape-rendering: geometricPrecision;
vector-effect: non-scaling-stroke;
}
/* Tooltip minimal */
.wa-tip{
position:absolute; right: calc(100% + 10px); top:50%;
transform: translateY(-50%); background:#111; color:#fff;
font-size:.86rem; padding:.38rem .6rem; border-radius:10px; white-space:nowrap;
opacity:0; pointer-events:none; transition:opacity .15s ease, transform .15s ease;
box-shadow: 0 10px 26px rgba(0,0,0,.25);
}
.wa-btn:hover .wa-tip, .wa-btn:focus-visible .wa-tip{
opacity:1; transform: translate(-2px,-50%);
}
/* Opción: lado izquierdo → descomentá */
/* .wa-float{ right:auto; left: var(--wa-x); } */
bendecidosparabendecirrosario.com.ar
https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.csshttps://cdnjs.cloudflare.com/ajax/libs/bootstrap-icons/1.11.3/font/bootstrap-icons.min.csshttps://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swaphttps://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.0/css/all.min.css:root {
--primary: #4361ee;
--primary-dark: #3a56d4;
--secondary: #7b2cbf;
--accent: #f72585;
--success: #06d6a0;
--warning: #ffd166;
--info: #118ab2;
--dark: #0f172a;
--darker: #070b15;
--light: #f8f9fa;
--lighter: #ffffff;
--gray: #64748b;
--gray-light: #e2e8f0;
--card-bg: rgba(255, 255, 255, 0.85);
--footer-bg: #070b15;
--radius-sm: 8px;
--radius: 16px;
--radius-lg: 24px;
--radius-xl: 32px;
--shadow-sm: 0 4px 6px rgba(2, 6, 23, 0.05);
--shadow: 0 10px 25px rgba(2, 6, 23, 0.1);
--shadow-lg: 0 20px 40px rgba(2, 6, 23, 0.15);
--shadow-xl: 0 25px 50px rgba(2, 6, 23, 0.25);
--transition: all 0.3s ease;
--transition-slow: all 0.5s ease;
--nav-height: 80px;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
html {
scroll-behavior: smooth;
scroll-padding-top: calc(var(--nav-height) + 20px);
}
body {
font-family: 'Inter', -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Ubuntu, sans-serif;
color: var(--dark);
background: var(--light);
line-height: 1.6;
overflow-x: hidden;
position: relative; /* necesario para Scrollspy */
}
h1, h2, h3, h4, h5, h6 { font-weight: 800; line-height: 1.2; margin-bottom: 0.5em; }
/* Custom Scrollbar */
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--gray-light); }
::-webkit-scrollbar-thumb { background: var(--primary); border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: var(--primary-dark); }
/* Navbar */
.navbar {
height: var(--nav-height);
backdrop-filter: blur(10px) saturate(180%);
background: rgba(255, 255, 255, 0.92);
box-shadow: var(--shadow-sm);
transition: var(--transition);
padding: 0.5rem 0;
}
.navbar.scrolled { box-shadow: var(--shadow); }
.navbar-brand { font-weight: 900; font-size: 1.5rem; display: flex; align-items: center; gap: 0.5rem; }
.navbar-brand span {
background: linear-gradient(135deg, var(--primary), var(--secondary));
-webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.nav-link { font-weight: 600; position: relative; padding: 0.5rem 1rem !important; transition: var(--transition); }
.nav-link::after {
content: ''; position: absolute; bottom: 0; left: 50%; width: 0; height: 2px;
background: linear-gradient(to right, var(--primary), var(--secondary));
transition: var(--transition); transform: translateX(-50%);
}
.nav-link:hover::after, .nav-link.active::after { width: 70%; }
.navbar-toggler { border: none; padding: 0.5rem; }
.navbar-toggler:focus { box-shadow: none; }
/* Buttons */
.btn { border-radius: var(--radius); font-weight: 600; padding: 0.75rem 1.5rem; transition: var(--transition); display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem; }
.btn-brand {
background: linear-gradient(135deg, var(--primary), var(--secondary));
color: white; border: none; box-shadow: var(--shadow); position: relative; overflow: hidden;
}
.btn-brand::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: var(--transition-slow);
}
.btn-brand:hover::before { left: 100%; }
.btn-brand:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.btn-ghost { background: transparent; border: 2px solid var(--gray-light); color: var(--dark); }
.btn-ghost:hover { border-color: var(--primary); background: rgba(67, 97, 238, 0.05); transform: translateY(-3px); box-shadow: var(--shadow); }
/* Hero Section */
.hero {
position: relative; padding-top: calc(var(--nav-height) + 2rem); padding-bottom: 6rem; overflow: hidden;
background: linear-gradient(135deg, rgba(67, 97, 238, 0.03) 0%, rgba(123, 44, 191, 0.03) 100%);
}
.hero::before{
content:''; position:absolute; top:-10%; right:-10%; width:500px; height:500px; border-radius:50%;
background: radial-gradient(circle, rgba(67, 97, 238, 0.15) 0%, transparent 70%); z-index:0;
}
.hero::after{
content:''; position:absolute; bottom:-10%; left:-10%; width:400px; height:400px; border-radius:50%;
background: radial-gradient(circle, rgba(123, 44, 191, 0.1) 0%, transparent 70%); z-index:0;
}
.hero-content { position: relative; z-index: 2; }
.badge-soft {
background: linear-gradient(135deg, rgba(67, 97, 238, 0.1), rgba(123, 44, 191, 0.1));
color: var(--primary); border: 1px solid rgba(67, 97, 238, 0.2);
padding: 0.5rem 1rem; border-radius:100px; font-weight:600; font-size:.85rem; display:inline-flex; align-items:center; gap:.5rem; margin-bottom:1.5rem;
}
.hero h1 {
font-size: 3.5rem;
background: linear-gradient(135deg, var(--primary), var(--secondary));
-webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
margin-bottom: 1.5rem;
}
.hero p { font-size: 1.25rem; color: var(--gray); margin-bottom: 2rem; }
.hero-image { position:relative; z-index:2; border-radius: var(--radius-xl); overflow:hidden; box-shadow: var(--shadow-xl); transform: perspective(1000px) rotateY(-5deg) rotateX(5deg); transition: var(--transition); }
.hero-image:hover { transform: perspective(1000px) rotateY(0) rotateX(0); }
.hero-image img { width:100%; height:auto; transition: var(--transition-slow); }
.hero-image:hover img { transform: scale(1.05); }
/* Section Styles */
section { padding: 5rem 0; position: relative; scroll-margin-top: calc(var(--nav-height) + 1rem); }
.section-title { position: relative; display: inline-block; margin-bottom: 2rem; }
.section-title::after {
content:''; position:absolute; bottom:-10px; left:0; width:60px; height:4px;
background: linear-gradient(to right, var(--primary), var(--secondary)); border-radius:2px;
}
.section-title.center::after { left:50%; transform: translateX(-50%); }
.lead-muted { color: var(--gray); font-size: 1.1rem; }
/* Cards */
.card-soft { background: var(--card-bg); backdrop-filter: blur(10px); border: none; border-radius: var(--radius-lg); box-shadow: var(--shadow); transition: var(--transition); overflow: hidden; }
.card-soft:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); }
.icon-pill {
width: 60px; height: 60px; border-radius: var(--radius); display:flex; align-items:center; justify-content:center;
background: linear-gradient(135deg, rgba(67, 97, 238, 0.1), rgba(123, 44, 191, 0.1)); color: var(--primary); font-size:1.5rem; transition: var(--transition);
}
.card-soft:hover .icon-pill { transform: scale(1.1); background: linear-gradient(135deg, var(--primary), var(--secondary)); color: white; }
/* Ticker / Gallery */
.ticker { position: relative; margin: 2rem 0; }
.ticker-track {
display: flex; gap: 1.5rem; overflow-x: auto; scroll-snap-type: x mandatory; scroll-behavior: smooth; padding: 1rem 0.5rem;
-ms-overflow-style: none; scrollbar-width: none;
}
.ticker-track::-webkit-scrollbar { display: none; }
.tick-card {
scroll-snap-align: start; flex: 0 0 auto; width: 320px; height: 320px; border-radius: var(--radius-lg); overflow: hidden; position: relative; box-shadow: var(--shadow); transition: var(--transition);
}
.tick-card:hover { transform: scale(1.03); box-shadow: var(--shadow-lg); }
.tick-card img { width: 100%; height: 100%; object-fit: cover; transition: var(--transition-slow);
/* ...cortado... */
/* Estilos SOLO para esta sección */
#unite-whatsapp{
background:
radial-gradient(900px 400px at 110% 5%, rgba(67,97,238,.06), transparent 60%),
radial-gradient(900px 400px at -10% 95%, rgba(123,44,191,.06), transparent 60%),
#fff;
}
/* Contenedor y flyer */
#unite-whatsapp .uw-figwrap{ display:flex; justify-content:center; }
#unite-whatsapp .uw-flyer{
width:100%; max-width:460px; /* <-- limita tamaño en desktop */
border-radius: 24px; overflow: hidden;
box-shadow: 0 20px 40px rgba(2,6,23,.12);
background:#fff;
}
#unite-whatsapp .uw-flyer img{ width:100%; height:auto; display:block; }
/* Card WhatsApp */
#unite-whatsapp .uw-card{
border:1px solid #e2e8f0; border-radius: 24px; background:#fff;
box-shadow: 0 12px 30px rgba(2,6,23,.08);
}
#unite-whatsapp .uw-card-header{
background: linear-gradient(135deg,#4361ee,#7b2cbf); color:#fff;
font-weight:800; letter-spacing:.3px; padding:1rem 1.25rem;
border-top-left-radius:24px;border-top-right-radius:24px;
}
#unite-whatsapp .uw-card-body{ padding:1.25rem 1.25rem 1.5rem }
#unite-whatsapp .uw-btn{
display:flex; align-items:center; justify-content:center; gap:.6rem;
width:100%; padding:.95rem 1.1rem; border:none; border-radius:16px; font-weight:800;
background:#25D366; color:#fff; box-shadow:0 12px 24px rgba(37,211,102,.25);
text-decoration:none;
}
#unite-whatsapp .uw-btn:hover{ filter:brightness(1.03) }
#unite-whatsapp .uw-mini{ color:#64748b; font-size:.9rem }
/* Ajustes responsive */
@media (max-width: 991.98px){
#unite-whatsapp .uw-flyer{ max-width:400px; } /* <-- un poco más chica en tablet */
#unite-whatsapp .uw-figwrap{ margin-bottom: 16px; }
}
@media (max-width: 575.98px){
#unite-whatsapp .uw-flyer{ max-width:100%; } /* ocupa ancho del móvil, pero no enorme */
}
/* ===== Estilos específicos del ticker (sobrescriben los globales) ===== */
#trabajos .ticker { position: relative; margin: 2rem 0; }
/* Dejo padding lateral para que las flechas no tapen las imágenes */
#trabajos .ticker-track{
display:flex; gap:16px;
overflow-x:auto; scroll-snap-type:x mandatory;
scroll-behavior:smooth; padding:1rem 2.75rem; /* <-- espacio p/ flechas */
-ms-overflow-style:none; scrollbar-width:none;
overscroll-behavior-x: contain;
}
#trabajos .ticker-track::-webkit-scrollbar{ display:none; }
/* Tarjetas responsivas: ancho fluido, alto según la imagen (sin recorte) */
#trabajos .tick-card{
flex:0 0 auto;
width: clamp(220px, 28vw, 360px); /* ancho adaptable */
border-radius:16px; overflow:hidden;
box-shadow:0 10px 24px rgba(2,6,23,.10);
scroll-snap-align:start;
display:grid; place-items:center;
background:#fff; cursor: zoom-in; /* indica que abre zoom */
}
#trabajos .tick-card img{
width:100%;
height:auto; /* respeta proporción */
object-fit: contain; /* NO recorta; si querés llenar, cambiá a cover */
background:#f1f5f9; /* “letterbox” suave cuando sobra espacio */
display:block;
}
/* Botones dentro del carrusel */
#trabajos .tick-ctrl{
position:absolute; top:50%; transform:translateY(-50%);
width:48px; height:48px; border-radius:50%;
display:flex; align-items:center; justify-content:center;
background:#fff; border:none; box-shadow:0 12px 28px rgba(2,6,23,.12);
z-index:10; transition:filter .2s ease;
}
#trabajos .tick-ctrl:hover{ filter:brightness(1.04); }
#trabajos .tick-prev{ left:8px; }
#trabajos .tick-next{ right:8px; }
@media (max-width: 991.98px){
#trabajos .tick-ctrl{ display:none; } /* oculto flechas en mobile */
}
/* Modal full-image */
#trabajos .modal-content{ background:#0b1220; }
#trabajos #lightboxImg{
width:100%;
max-height: calc(100vh - 6rem);
object-fit: contain;
}
#lecturas .pdf-card{
display:flex; gap:16px; align-items:center;
border:1px solid rgba(2,6,23,.12); border-radius:16px; padding:16px;
background:#fff; box-shadow:0 10px 24px rgba(2,6,23,.08); cursor:pointer;
transition:transform .15s ease, box-shadow .15s ease;
}
#lecturas .pdf-card:hover{ transform:translateY(-2px); box-shadow:0 16px 36px rgba(2,6,23,.12);}
#lecturas .pdf-icon{
width:56px; height:56px; border-radius:12px; display:grid; place-items:center;
background:#ef4444; color:#fff; font-weight:700; font-family:system-ui, sans-serif;
}
#lecturas .pdf-title{ margin:0; font-size:1.05rem; }
#lecturas .pdf-meta{ color:#64748b; font-size:.9rem; margin:0; }
#lecturas .btn-inline{ margin-left:auto; }
/* Modal */
#lecturas .modal-content{ background:#0b1220; }
#lecturas .modal-header{ border:0; }
#lecturas #pdfFrame{
width:100%; height:calc(100vh - 8rem); border:0; background:#0b1220;
}
/* ====== Styles scoped a #videos ====== */
#videos{
padding: 3.5rem 0;
background:
radial-gradient(900px 400px at 110% 5%, rgba(67,97,238,.06), transparent 60%),
radial-gradient(900px 400px at -10% 95%, rgba(123,44,191,.06), transparent 60%),
#f8f9fa;
position: relative;
}
#videos .section-title{
font-weight: 900; margin: 0; position: relative; display: inline-block;
}
#videos .section-title::after{
content:""; position:absolute; left:0; bottom:-10px; width:60px; height:4px; border-radius:2px;
background: linear-gradient(90deg, var(--primary,#4361ee), var(--secondary,#7b2cbf));
}
#videos .btn-videos{
display:inline-flex; align-items:center; gap:.55rem;
border:1px solid rgba(2,6,23,.10); border-radius:14px;
padding:.65rem 1rem; font-weight:800; background:#fff; color:#0f172a;
box-shadow: 0 8px 20px rgba(2,6,23,.06);
transition: transform .06s ease, box-shadow .2s ease, border-color .2s ease;
}
#videos .btn-videos:hover{
transform: translateY(-1px);
border-color: color-mix(in oklab, var(--primary,#4361ee) 30%, transparent);
box-shadow: 0 12px 28px rgba(2,6,23,.10);
}
#videos .btn-videos .chevron{ transition: transform .2s ease; }
#videos .btn-videos[aria-expanded="true"] .chevron{ transform: rotate(180deg); }
/* Grid responsive (mobile-first) */
#videos .videos-grid{ display:grid; gap:14px; margin-top:1rem; }
/* 1 col en móviles por ancho completo */
@media (min-width:480px){ #videos .videos-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (min-width:768px){ #videos .videos-grid{ gap:16px; grid-template-columns: repeat(3, minmax(0,1fr)); } }
@media (min-width:1200px){ #videos .videos-grid{ grid-template-columns: repeat(5, minmax(0,1fr)); } }
/* Card/video */
#videos .video-card{
background:#fff; border:1px solid rgba(2,6,23,.06);
border-radius:16px; overflow:hidden;
box-shadow: 0 10px 24px rgba(2,6,23,.07);
transition: transform .12s ease, box-shadow .2s ease;
}
#videos .video-card:hover{ transform: translateY(-2px); box-shadow: 0 16px 36px rgba(2,6,23,.12); }
/* Frame 16:9 con Bootstrap */
#videos .ratio{ border-bottom-left-radius:16px; border-bottom-right-radius:16px; }
#videos video{ width:100%; height:100%; object-fit:cover; display:block; }
/* Meta */
#videos .video-meta{
padding:.6rem .8rem .75rem; display:flex; align-items:center; gap:.5rem;
font-size:.9rem; color:#475569; min-height:44px;
}
#videos .dot{
width:8px; height:8px; border-radius:999px; flex:0 0 auto;
background: linear-gradient(135deg, var(--primary,#4361ee), var(--secondary,#7b2cbf));
}
/* ===== Contacto (scoped) ===== */
#contacto {
--ctc-brand: #3b59f0;
--ctc-accent: #7c4dff;
--ctc-ink: #0f172a;
--ctc-muted: #64748b;
--ctc-card: #ffffff;
--ctc-bg: #f7f8fb;
--ctc-radius: 18px;
--ctc-shadow: 0 20px 50px rgba(2,6,23,.10);
--ctc-border: 1px solid rgba(2,6,23,.06);
}
#contacto.contacto-wrap{
position: relative;
padding: 80px 0;
background:
radial-gradient(1200px 600px at -10% -10%, rgba(124,77,255,.08), transparent 60%),
radial-gradient(900px 500px at 110% 5%, rgba(59,89,240,.10), transparent 60%),
var(--ctc-bg);
isolation: isolate;
}
#contacto .ctc-eyebrow{
display:inline-block;
padding:.4rem .8rem;
border-radius:999px;
background:linear-gradient(90deg, rgba(59,89,240,.10), rgba(124,77,255,.10));
border:1px solid rgba(59,89,240,.20);
color:var(--ctc-brand);
font-weight:700;
letter-spacing:.3px;
}
#contacto .ctc-title{ font-weight:900; letter-spacing:.2px; }
#contacto .ctc-lead{ color:var(--ctc-muted); max-width: 760px; margin: 0 auto; }
/* Cards */
#contacto .ctc-card{ background: color-mix(in oklab, var(--ctc-card) 86%, #fff); border: var(--ctc-border); border-radius: var(--ctc-radius); box-shadow: var(--ctc-shadow); overflow: hidden; }
/* Field group with icon */
#contacto .ctc-field{ position: relative; }
#contacto .ctc-field .ctc-ico{ position:absolute; inset: 0 auto 0 12px; display:grid; place-items:center; width: 40px; color:#6b7280; pointer-events:none; }
#contacto .ctc-field .form-control{
padding-left:48px; padding-top:.85rem; padding-bottom:.85rem;
border-radius: 14px; border:1px solid rgba(2,6,23,.10);
transition: box-shadow .25s ease, border-color .25s ease, transform .05s ease; background:#fff;
}
#contacto .ctc-field textarea.form-control{ padding-left:16px; }
#contacto .form-label{ font-weight:600; color:#334155 }
#contacto .form-control:focus{
border-color: color-mix(in oklab, var(--ctc-brand) 40%, #000 0%);
box-shadow: 0 0 0 .25rem color-mix(in oklab, var(--ctc-brand) 18%, transparent);
outline: none; transform: translateY(-1px);
}
#contacto .ctc-note{ color:var(--ctc-muted); font-size:.9rem; }
/* Buttons */
#contacto .btn-ctc{
--bg: linear-gradient(135deg, var(--ctc-brand), var(--ctc-accent));
background: var(--bg); color:#fff; border:none; padding:.85rem 1.2rem; border-radius:14px; font-weight:700;
box-shadow: 0 12px 24px rgba(59,89,240,.22); transition: transform .06s ease, filter .2s ease;
}
#contacto .btn-ctc:hover{ filter:brightness(1.03) }
#contacto .btn-ctc:active{ transform: translateY(1px) }
#contacto .btn-ghost{
background:#fff; color:var(--ctc-ink);
border:1px solid rgba(2,6,23,.12); box-shadow: 0 6px 16px rgba(2,6,23,.06);
}
/* Contact info side */
#contacto .ctc-side h5{ font-weight:800 }
#contacto .ctc-item{ color:var(--ctc-muted); display:flex; gap:10px; align-items:flex-start; }
#contacto .ctc-chip{
display:inline-flex; align-items:center; gap:8px; padding:.35rem .6rem; border-radius:999px; font-size:.85rem;
background:linear-gradient(90deg, rgba(59,89,240,.10), rgba(124,77,255,.10));
border:1px solid rgba(59,89,240,.15); color:#334155;
}
/* Map frame with gradient border */
#contacto .ctc-map{ border-radius:16px; overflow:hidden; position:relative; padding: 2px; background: linear-gradient(135deg, rgba(59,89,240,.35), rgba(124,77,255,.35)); }
#contacto .ctc-map > .frame{ border:0; border-radius:14px; width:100%; height:100%; }
/* Alerts */
#contacto .ctc-alert{ border-radius:14px; padding: .9rem 1rem; font-weight:600 }
#contacto .ctc-alert.success{ background:#ecfdf5; color:#065f46; border:1px solid #a7f3d0 }
#contacto .ctc-alert.error{ background:#fff7ed; color:#9a3412; border:1px solid #fed7aa }
/* Responsive spacing */
@media (min-width: 992px){
#contacto .stack-lg{ display:flex; gap:28px }
#contacto .stack-lg > *{ flex:1 }
}
/* 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;
}
.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, .social-pulse-delayed { position: absolute; width: 100%; height: 100%; border-radius: 50%; opacity: 0; animation: pulse 2s infinite; }
.social-pulse-delayed { animation-delay: .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,.1); opacity: 0; visibility: hidden; transition: all .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; }
/* Específicos */
.whatsapp-button { background: #25D366; box-shadow: 0 10px 25px rgba(37,211,102,.3); }
.whatsapp-button:hover { background: #128C7E; box-shadow: 0 15px 30px rgba(37,211,102,.4); }
.whatsapp-pulse { background: rgba(37,211,102,.6); }
.whatsapp-pulse-delayed { background: rgba(37,211,102,.4); }
.instagram-button { background: #E1306C; box-shadow: 0 10px 25px rgba(225,48,108,.3); }
.instagram-button:hover { background: #C13584; box-shadow: 0 15px 30px rgba(193,53,132,.4); }
.instagram-pulse { background: rgba(225,48,108,.6); }
.instagram-pulse-delayed { background: rgba(193,53,132,.4); }
.facebook-button { background: #1877F2; box-shadow: 0 10px 25px rgba(24,119,242,.3); }
.facebook-button:hover { background: #166FE5; box-shadow: 0 15px 30px rgba(22,111,229,.4); }
.facebook-pulse { background: rgba(24,119,242,.6); }
.facebook-pulse-delayed { background: rgba(22,111,229,.4); }
/* Animaciones */
@keyframes float { 0%{ transform: translateY(0); } 50%{ transform: translateY(-10px); } 100%{ transform: translateY(0); } }
@keyframes pulse { 0%{ transform: scale(.8); opacity: 0; } 70%{ transform: scale(1.3); opacity:.4; } 100%{ transform: scale(1.4); opacity: 0; } }
@keyframes heartbeat { 0%{ transform: scale(1); } 25%{ transform: scale(1.1); } 50%{ transform: scale(1); } 75%{ transform: scale(1.1); } 100%{ transform: scale(1); } }
.social-button { animation: heartbeat 1.5s ease 2s 2, float 3s ease-in-out infinite 3s; }
.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; }
}
cheyole.com
https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400&family=Poppins:wght@300;400;500;600;700;800&family=Raleway:wght@300;400;500;600;700;800&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/5.15.4/css/all.min.csshttps://unpkg.com/[email protected]/dist/aos.css/* ==================
VARIABLES & BASE
================== */
:root {
--brand: #b3122b;
--brand-dark: #7f0d1f;
--brand-light: #ff4d6d;
--ink: #111;
--paper: #faf7f2;
--gold: #d4af37;
--gold-light: #f8e08e;
--muted: #6c757d;
--light-bg: #f8f9fa;
--radius-xl: 1.25rem;
--radius-lg: 1rem;
--shadow-soft: 0 10px 30px rgba(0,0,0,.08);
--shadow-medium: 0 15px 35px rgba(0,0,0,.12);
--shadow-intense: 0 25px 50px rgba(0,0,0,.15);
--nav-h: 80px;
--transition: .4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
--transition-slow: .6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
--gallery-max-h: 360px;
}
* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { max-width: 100%; overflow-x: hidden; scroll-behavior: smooth; }
body {
font-family: 'Raleway', system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, 'Helvetica Neue', Arial;
color: var(--ink);
background: #fff;
line-height: 1.7;
}
img{max-width:100%;height:auto;display:block}
h1, h2, h3, h4, h5 {
font-family: 'Playfair Display', serif;
font-weight: 700;
line-height: 1.2;
letter-spacing: -0.02em;
}
.text-brand { color: var(--brand) !important; }
.text-gold { color: var(--gold) !important; }
.bg-paper { background-color: var(--paper) !important; }
.bg-light { background-color: var(--light-bg) !important; }
.section { padding: 7rem 0; position: relative; }
.section-title {
position: relative; margin-bottom: 3rem; display: inline-block;
}
.section-title::after {
content: ''; display:block; width:80px; height:4px; background:var(--brand);
margin-top:1.2rem; border-radius:2px; transition: width .8s ease;
}
.section-title:hover::after { width:120px; }
.small-muted { color: var(--muted); font-size: 1rem; }
/* ==================
NAVBAR (FIX MOBILE)
================== */
.navbar {
height: var(--nav-h);
background: #fff !important;
color: #000;
backdrop-filter: blur(10px);
box-shadow: 0 5px 20px rgba(0,0,0,.05);
transition: var(--transition);
padding: 0.5rem 0;
z-index: 1040; /* por encima del hero */
}
.navbar-brand { font-weight: 800; font-size: 1.4rem; color:#000; }
.navbar .nav-link {
position: relative; font-weight:600; padding:.5rem .8rem !important; transition: var(--transition);
color:#111 !important;
}
.navbar .nav-link::after {
content:''; position:absolute; bottom:0; left:50%; width:0; height:2px; background:var(--brand);
transition: var(--transition); transform: translateX(-50%);
}
.navbar .nav-link:hover::after, .navbar .nav-link.active::after { width:70%; }
.navbar .navbar-toggler{ border:none; padding:.4rem; z-index:1052; }
.navbar .navbar-toggler:focus{ box-shadow:none; }
/* icono hamburguesa rojo */
.navbar .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='%23b3122b' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
transition: var(--transition);
}
/* Menú desplegado: bloque full-width SOLIDO (para que se vea y no empuje nada) */
@media (max-width: 991.98px){
.navbar .navbar-collapse{
position: absolute;
top: var(--nav-h);
left: 0; right: 0;
background:#fff;
border-bottom: 1px solid rgba(0,0,0,.06);
box-shadow: 0 15px 30px rgba(0,0,0,.08);
padding: .75rem 1rem;
}
}
/* ==================
HERO
================== */
.hero {
min-height: calc(100svh - var(--nav-h));
display: flex; align-items: center;
position: relative; color: #fff;
padding-top: var(--nav-h);
overflow: hidden;
isolation: isolate; /* evita fugas z-index */
}
.hero::before {
content:''; position:absolute; inset:0;
background: url('https://nodo25.netfan.host/cheyole.com/img/hero.jpg') 50% 30%/cover no-repeat;
z-index: -2; transform: scale(1.08); transition: transform 10s ease;
}
.hero:hover::before { transform: scale(1); }
.hero::after {
content:''; position:absolute; inset:0;
background: linear-gradient(180deg, rgba(0,0,0,.25) 0%, rgba(0,0,0,.15) 40%, rgba(0,0,0,.35) 100%);
z-index:-1;
}
.hero-content { position: relative; z-index: 2; }
.hero-title{ font-size: clamp(1.6rem, 6vw, 2.6rem); margin-bottom:1.25rem; text-shadow:0 2px 10px rgba(0,0,0,.3); }
.hero-subtitle{ font-size: clamp(.95rem, 3.5vw, 1.15rem); margin-bottom: 1.75rem; opacity:.95; }
@media (max-width: 575.98px){
.hero{ min-height: calc(82svh - var(--nav-h)); }
.hero::before{ background-position: 50% 22%; }
.hero-title, .hero-subtitle{ text-align:center; }
.hero-content .d-flex{ justify-content:center; }
}
/* ==================
CARDS
================== */
.card-soft {
border:0; border-radius: var(--radius-xl); box-shadow: var(--shadow-soft);
transition: var(--transition); overflow: hidden; height: 100%; background:#fff;
}
.card-soft:hover { transform: translateY(-10px); box-shadow: var(--shadow-intense); }
.card-img-overlay-custom {
background: linear-gradient(to top, rgba(0,0,0,0.8) 0%, rgba(0,0,0,0.2) 60%, transparent 100%);
display:flex; flex-direction:column; justify-content:flex-end; padding:2rem;
opacity:0; transition: var(--transition);
}
.card-soft:hover .card-img-overlay-custom{ opacity:1; }
.btn {
border-radius:50px; padding:.8rem 2rem; font-weight:600;
transition: var(--transition); position:relative; overflow:hidden; z-index:1;
}
.btn::before{ content:''; position:absolute; inset:0; width:0%; height:100%; background:rgba(255,255,255,.2); transition: var(--transition); z-index:-1; }
.btn:hover::before{ width:100%; }
.btn-brand{ background:var(--brand); color:#fff; border:0; box-shadow:0 5px 15px rgba(179,18,43,.3); }
.btn-brand:hover{ background:var(--brand-dark); color:#fff; transform: translateY(-3px); box-shadow:0 8px 20px rgba(179,18,43,.4); }
.btn-outline-light:hover{ background: rgba(255,255,255,.1); }
/* ==================
GALERÍA / TICKER (SIN RECORTE + NO DESBORDA)
================== */
#galeria .ticker{
display:flex; gap:1rem; overflow-x:auto; scroll-snap-type:x mandatory; scroll-behavior:smooth;
padding: 1rem .5rem; scrollbar-width:none; -ms-overflow-style:none;
}
#galeria .ticker::-webkit-scrollbar{ display:none; }
#galeria .tile{
flex:0 0 auto; display:flex; align-items:center; justify-content:center;
background:#000; border-radius: var(--radius-xl); box-shadow: var(--shadow-soft);
scroll-snap-align:center; position:relative;
}
#galeria .tile img{
height: var(--gallery-max-h); width:auto; max-width:100%;
object-fit: contain; border-radius: var(--radius-xl);
}
@media (max-width: 991px){ :root{ --gallery-max-h: 300px; } }
@media (max-width: 575px){ :root{ --gallery-max-h: 220px; } }
/* ==================
CONTACTO
================== */
.contact-card{ background:var(--paper); border-radius:var(--radius-xl); padding:2.5rem; box-shadow:var(--shadow-soft); height:100%; }
.contact-icon{ width:50px; height:50px; border-radius:50%; background:rgba(179,18,43,.1); display:flex; align-items:center; justify-content:center; margin-bottom:1rem; }
.form-control{ border-radius:10px; padding:.8rem 1.2rem; border:1px solid #e9e9e9; transit
/* ...cortado... */
/* Oculta la imagen de fondo del hero cuando el video está listo */
#inicio.video-ready::before{ opacity: 0; transition: opacity .6s ease; }
#inicio.video-failed::before{ opacity: 1; }
/* Asegura que el video siempre cubra el plano trasero */
#inicio .hero-video{ z-index: 0; }
#inicio::before{ z-index: -2; }
/* Ocultar barra superior y gadget */
.goog-te-banner-frame.skiptranslate { display:none !important; }
.goog-te-banner-frame { display:none !important; }
.skiptranslate { display:none !important; }
#google_translate_element { display:none !important; }
.goog-te-gadget { height:0 !important; overflow:hidden !important; }
.goog-logo-link, .goog-te-gadget-icon { display:none !important; }
/* Evitar desplazamiento al agregar top al body/html */
html, body { top:0 !important; position: static !important; margin-top:0 !important; }
/* Tooltips/balloons */
#goog-gt-tt, .goog-te-balloon-frame, .goog-tooltip { display:none !important; visibility:hidden !important; }
.brand-img{ height:44px; width:auto; vertical-align:middle; }
/* ======= Ajustes de altura (podés tocarlos) ======= */
:root{
--navbar-h: 72px; /* alto real de tu navbar */
--hero-extra: 32rem; /* extra de altura encima del alto de la ventana */
}
/* ======= HERO ======= */
.hero{
position: relative;
isolation: isolate; /* asegura stacking context para que nada tape el botón */
min-height: calc(100svh - var(--navbar-h) + var(--hero-extra));
color: #fff;
overflow: hidden;
}
/* Capa video al fondo */
.hero .hero-video{ position: absolute; inset: 0; z-index: 0; }
.hero .hero-video video{
width: 100%;
height: 100%;
display: block;
object-fit: cover; /* llena el contenedor (puede recortar bordes) */
object-position: 50% 35%; /* mové el encuadre si hace falta: 50% 25% / 50% 60% */
background: #000;
}
/* Overlay para contraste (no bloquea clicks) */
.hero::after{
content:"";
position:absolute;
inset:0;
z-index:1;
background: linear-gradient(
to bottom,
rgba(0,0,0,.55),
rgba(0,0,0,.35) 40%,
rgba(0,0,0,.6)
);
pointer-events:none;
}
/* Contenido por encima del video */
.hero .hero-content{
position: relative;
z-index: 2;
padding-block: clamp(24px, 6vh, 80px);
}
/* En móviles muy chicos, sumá un poco más de altura si recorta */
@media (max-width: 576px){
:root{ --hero-extra: 36rem; }
}
/* ======= Botón de sonido (flotante fijo) ======= */
#btnSound.btn-sound{
position: fixed; /* siempre visible */
bottom: 16px;
right: 16px;
z-index: 9999;
padding: .55rem .9rem;
border-radius: 999px;
border: 1px solid rgba(255,255,255,.35);
background: rgba(0,0,0,.55);
color: #fff;
font-size: .95rem;
line-height: 1;
backdrop-filter: blur(4px);
cursor: pointer;
transition: transform .15s ease, background .2s ease, border-color .2s ease, opacity .2s;
}
#btnSound.btn-sound:hover{
transform: translateY(-1px);
background: rgba(0,0,0,.7);
border-color: rgba(255,255,255,.55);
}
/* Si preferís el botón dentro del hero, cambiá a:
position:absolute; top:1rem; right:1rem; z-index:10; */
/* Miniatura uniforme 16:9 por card */
.obra-thumb{
width:100%;
aspect-ratio:16/9;
object-fit:cover;
display:block;
border-top-left-radius:.75rem;
border-top-right-radius:.75rem;
}
/* Cards consistentes */
.card.card-soft{ display:flex; flex-direction:column; }
.card.card-soft .card-body{ display:flex; flex-direction:column; }
/* Clamp de descripción */
.obra-desc{
--lines: 4; /* líneas visibles antes de expandir */
display:-webkit-box;
-webkit-box-orient:vertical;
-webkit-line-clamp:var(--lines);
overflow:hidden;
}
.obra-desc.expanded{
-webkit-line-clamp:unset;
display:block;
}
/* Botón leer más estilo link */
.btn-readmore{
border:none;
background:transparent;
padding:0;
font-weight:600;
text-decoration:underline;
}
.video-thumb .thumb-video{
width:100%; height:100%;
object-fit:cover; display:block;
background:#000; /* por si tarda en cargar */
}
.video-thumb:hover .bi-play-circle-fill{ transform:scale(1.08); }
.alx-galeria{ --gap:16px; --thumb:260px; --radius:14px; --brd:#e9eef3; --shadow:0 8px 26px rgba(0,0,0,.08); --muted:#6b7280 }
.alx-galeria .section-title{ margin-bottom:4px }
.alx-galeria .small-muted{ color:var(--muted); font-size:.95rem }
.alx-country-head{ display:flex; align-items:center; justify-content:space-between; margin:18px 0 10px; }
.alx-country-head .country{ font-size:1.25rem; font-weight:700; letter-spacing:.3px; margin:0; display:flex; gap:8px; align-items:center }
.alx-country-head .country img{ width:22px; height:auto }
.alx-country-head .photog{ margin:0; color:var(--muted); font-weight:500 }
.alx-ticker{ position:relative; padding:12px; border-radius:16px; border:1px solid var(--brd); background:#fff; box-shadow:var(--shadow);
display:flex; gap:var(--gap); overflow:auto; scroll-snap-type:x mandatory; scrollbar-width:thin; }
.alx-ticker .tile{ flex:0 0 auto; width:var(--thumb); height:var(--thumb); border-radius:var(--radius); overflow:hidden; scroll-snap-align:start;
position:relative; border:1px solid #eef2f6; background:#f8fafc; transition:transform .18s ease, box-shadow .18s ease; cursor:zoom-in; }
.alx-ticker .tile:hover{ transform:translateY(-2px); box-shadow:0 10px 24px rgba(0,0,0,.12) }
.alx-ticker .tile img{ width:100%; height:100%; object-fit:cover; display:block }
.alx-ticker.is-marquee{ overflow:hidden; scroll-snap-type:none }
.alx-ticker .marquee-inner{ display:flex; width:max-content; gap:var(--gap); animation:alx-scroll var(--dur, 40s) linear infinite }
.alx-ticker.paused .marquee-inner{ animation-play-state:paused }
.alx-ticker .marquee-group{ display:flex; gap:var(--gap) }
@keyframes alx-scroll { 0%{ transform:translateX(0) } 100%{ transform:translateX(-50%) } }
#lb-overlay{ position:fixed; inset:0; display:none; align-items:center; justify-content:center; background:rgba(0,0,0,.92); z-index:2147483647 }
#lb-overlay.show{ display:flex }
#lb-overlay .lb-stage{ position:relative; width:100%; max-width:1200px; padding:0 64px }
#lb-overlay img{ width:100%; max-height:85vh; object-fit:contain; display:block }
#lb-overlay .lb-nav{ position:absolute; top:50%; transform:translateY(-50%); border:0; width:48px; height:48px; border-radius:50%;
background:rgba(255,255,255,.22); color:#fff; font-size:28px; display:flex; align-items:center; justify-content:center; cursor:pointer; }
#lb-prev{ left:12px } #lb-next{ right:12px }
#lb-overlay .lb-nav:hover{ background:rgba(255,255,255,.33) }
#lb-close{ position:absolute; top:12px; right:12px; width:40px; height:40px; border:0; border-radius:50%; background:rgba(255,255,255,.22);
color:#fff; font-size:26px; line-height:1; cursor:pointer; }
#lb-close:hover{ background:rgba(255,255,255,.33) }
#lb-caption{ position:absolute; left:0; right:0; bottom:0; color:#e5e7eb; padding:.6rem 1rem; display:flex; justify-content:space-between; align-items:center;
background:linear-gradient(to top, rgba(0,0,0,.45), rgba(0,0,0,0)); }
#lb-meta b{ letter-spacing:.3px }
@media (max-width:576px){ .alx-galeria{ --thumb:200px } }
@media (prefers-reduced-motion: reduce){ .alx-ticker.is-marquee .marquee-inner{ animation:none !important } }
/* ===== Scroller ===== */
#prensa .press-scroller{
position: relative;
overflow: hidden;
border-radius: var(--radius-xl, 16px);
box-shadow: var(--shadow-soft, 0 10px 30px rgba(0,0,0,.08));
background: #fff;
padding: 12px 0;
isolation:isolate;
}
#prensa .press-track{
display: flex;
align-items: center;
gap: 16px;
will-change: transform;
animation: press-scroll 45s linear infinite;
animation-play-state: paused; /* solo corre al entrar en viewport */
padding: 6px 12px;
}
/* Miniaturas un poquito más grandes */
#prensa .press-item{
height: clamp(165px, 24vw, 240px);
width: auto;
border-radius: 12px;
box-shadow: 0 8px 22px rgba(0,0,0,.08);
object-fit: contain;
background:#000;
transition: transform .35s ease, box-shadow .35s ease;
cursor: pointer;
user-select: none;
}
#prensa .press-item[aria-hidden="true"]{ pointer-events: none; }
#prensa .press-item:hover{
transform: translateY(-3px) scale(1.015);
box-shadow: 0 16px 35px rgba(0,0,0,.15);
}
/* Gradientes laterales para fade */
#prensa .press-mask{
position:absolute; top:0; bottom:0; width:120px; z-index:2; pointer-events:none;
}
#prensa .press-mask-left{ left:0; background:linear-gradient(to right, rgba(255,255,255,1), rgba(255,255,255,0)); }
#prensa .press-mask-right{ right:0; background:linear-gradient(to left, rgba(255,255,255,1), rgba(255,255,255,0)); }
@media (prefers-color-scheme: dark){
#prensa .press-mask-left{ background:linear-gradient(to right, rgba(255,255,255,.06), rgba(255,255,255,0)); }
#prensa .press-mask-right{ background:linear-gradient(to left, rgba(255,255,255,.06), rgba(255,255,255,0)); }
}
@keyframes press-scroll{
0% { transform: translateX(0); }
100% { transform: translateX(-50%); } /* duplicamos la serie */
}
@media (hover:hover){
#prensa .press-scroller:hover .press-track{ animation-play-state: paused; }
}
@media (prefers-reduced-motion: reduce){
#prensa .press-track{ animation: none; }
}
#prensa .press-scroller.is-running .press-track{ animation-play-state: running; }
/* ======== FIX MOBILE: video 100% responsive sin estirar ======== */
/* Teléfonos en vertical */
@media (max-width: 575.98px) and (orientation: portrait){
:root{
--hero-extra: 0rem; /* sin extra para que no corte */
}
.hero{
/* alto exacto de la ventana móvil (barra de direcciones incluida) */
min-height: calc(100dvh - var(--nav-h));
padding-top: var(--nav-h); /* si tu navbar es fixed */
}
.hero .hero-video{
position: absolute;
inset: 0;
}
.hero .hero-video video{
width: 100%;
height: 100%;
object-fit: contain; /* <- clave: no recorta ni deforma */
object-position: center center;
background: #000; /* franjas prolijas si no coincide el ratio */
}
/* el botón de sonido centrado para que no tape cosas */
#btnSound.btn-sound{
bottom: 12px;
right: 50%;
transform: translateX(50%);
}
}
/* Teléfonos en horizontal: se puede cubrir sin “aplastar” */
@media (max-width: 575.98px) and (orientation: landscape){
.hero{
min-height: calc(100dvh - var(--nav-h));
}
.hero .hero-video video{
object-fit: cover; /* aprovecha todo el ancho/alto */
object-position: 50% 50%;
}
}
/* Fallback si el navegador no soporta d vh */
@supports not (height: 100dvh) {
@media (max-width: 575.98px) and (orientation: portrait){
.hero{ min-height: calc(100vh - var(--nav-h)); }
}
}
/* Tablets chicas en vertical (opcional) */
@media (min-width: 576px) and (max-width: 991.98px) and (orientation: portrait){
.hero{
min-height: calc(100dvh - var(--nav-h));
}
.hero .hero-video video{
object-fit: contain;
background: #000;
}
}
prueba
https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.csshttps://cdnjs.cloudflare.com/ajax/libs/animate.css/4.1.1/animate.min.css/* Glass Card Effect */
.glass-card {
background: rgba(255, 255, 255, 0.6);
backdrop-filter: blur(12px);
border-radius: 20px;
box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
transition: transform 0.3s ease, box-shadow 0.3s ease;
cursor: pointer;
}
.glass-card:hover {
transform: translateY(-5px);
box-shadow: 0 12px 32px rgba(0, 0, 0, 0.15);
}
/* Hero */
.hero {
background: url("imagenes/prueba.JPG") top center no-repeat;
background-size: cover;
height: 100vh;
color: white;
display: flex;
align-items: center;
justify-content: center;
text-align: center;
flex-direction: column;
padding: 0 1rem 60px;
position: relative;
}
/* Navbar */
.navbar {
background: linear-gradient(90deg, #222c4a, #2e395f);
box-shadow: 0 3px 8px rgba(0, 0, 0, 0.3);
}
.navbar-brand,
.nav-link,
.dropdown-item {
color: #e0e6ff !important;
font-weight: 600;
}
.nav-link:hover,
.dropdown-item:hover {
color: #8ab4f8 !important;
}
.dropdown-menu {
background: #2e395f;
border: none;
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
border-radius: 0.5rem;
}
.dropdown-menu.show {
animation: fadeInDropdown 0.3s ease forwards;
}
@keyframes fadeInDropdown {
from {
opacity: 0;
transform: translateY(-10px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
/* Img Hover */
.img-hover-container {
position: relative;
display: inline-block;
max-width: 100%;
}
.img-hover-container .hover-img {
position: absolute;
top: 0;
left: 0;
opacity: 0;
transition: opacity 0.4s ease-in-out;
width: 100%;
height: 100%;
border-radius: 1rem;
object-fit: cover;
}
.img-hover-container:hover .hover-img {
opacity: 1;
}
.img-hover-container:hover .main-img {
opacity: 0;
}
/* Expanded sections */
.expanded-section {
display: none;
background: #f9fbff;
padding: 3rem 1rem;
border-radius: 1rem;
margin-top: 2rem;
box-shadow: 0 8px 24px rgba(0, 0, 0, 0.05);
}
.btn-back {
margin-top: 2rem;
background: #2e395f;
color: #e0e6ff;
border: none;
padding: 0.5rem 1.5rem;
border-radius: 25px;
cursor: pointer;
transition: background 0.3s ease;
}
.btn-back:hover {
background: #8ab4f8;
color: #fff;
}
/* Slider trabajos */
.slider-container {
overflow: hidden;
position: relative;
max-width: 100%;
}
.slider-track {
display: flex;
animation: scroll 30s linear infinite;
}
.slider-item {
flex: 0 0 auto;
width: 300px;
height: 200px;
margin-right: 20px;
border-radius: 12px;
overflow: hidden;
box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1);
background: #fff;
cursor: pointer;
transition: transform 0.3s ease;
}
.slider-item:hover {
transform: scale(1.05);
z-index: 10;
}
.slider-item img,
.slider-item video {
width: 100%;
height: 100%;
object-fit: cover;
object-position: top;
display: block;
border-radius: 12px;
}
@keyframes scroll {
0% {
transform: translateX(0);
}
100% {
transform: translateX(-50%);
}
}
@media (max-width: 768px) {
.slider-item {
width: 250px;
height: 160px;
}
}
/* Modal */
.modal {
display: none;
position: fixed;
z-index: 999;
padding-top: 60px;
left: 0;
top: 0;
width: 100%;
height: 100%;
overflow: auto;
background-color: rgba(0, 0, 0, 0.9);
text-align: center;
}
.modal-content {
margin: auto;
max-width: 90vw;
max-height: 80vh;
width: auto;
height: auto;
border-radius: 10px;
object-fit: contain;
background: #000;
}
.close {
position: absolute;
top: 20px;
right: 35px;
color: #fff;
font-size: 40px;
font-weight: bold;
cursor: pointer;
}
/* Ticker */
.ticker {
background: #f8f9fa;
overflow: hidden;
white-space: nowrap;
border-radius: 12px;
box-shadow: 0 5px 12px rgba(0, 0, 0, 0.1);
margin: 2rem 0;
padding: 0.5rem 0;
}
.ticker-track {
display: inline-flex;
animation: tickerScroll 10s linear infinite;
gap: 2rem;
align-items: center;
}
.ticker-item {
display: flex;
flex-direction: column;
align-items: center;
min-width: 200px;
user-select: none;
}
.ticker-item img {
width: 150px;
height: 100px;
object-fit: cover;
border-radius: 12px;
box-shadow: 0 4px 8px rgba(0,0,0,0.12);
margin-bottom: 0.5rem;
transition: transform 0.3s ease;
cursor: pointer;
}
.ticker-item img:hover {
transform: scale(1.05);
}
.ticker-item p {
font-size: 0.9rem;
color: #555;
margin: 0;
}
@keyframes tickerScroll {
0% {
transform: translateX(100%);
}
100% {
transform: translateX(-100%);
}
}
/* FAQs */
.faq-item {
border-bottom: 1px solid #ddd;
margin-bottom: 10px;
}
.faq-question {
background: none;
border: none;
width: 100%;
text-align: left;
padding: 15px;
font-size: 1.1rem;
font-weight: bold;
cursor: pointer;
transition: background 0.3s;
position: relative;
}
.faq-question::after {
content: "+";
position: absolute;
right: 20px;
transition: transform 0.3s;
}
.faq-question.active::after {
content: "-";
transform: rotate(180deg);
}
.faq-answer {
max-height: 0;
overflow: hidden;
transition: max-height 0.4s ease;
padding: 0 15px;
background: #f9f9f9;
}
.faq-answer p {
margin: 15px 0;
}
.faq-question:hover {
background: #f0f0f0;
}
bendecidosparabendecir.com.ar
https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.csshttps://cdnjs.cloudflare.com/ajax/libs/bootstrap-icons/1.11.3/font/bootstrap-icons.min.csshttps://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swaphttps://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.0/css/all.min.css:root {
--primary: #4361ee;
--primary-dark: #3a56d4;
--secondary: #7b2cbf;
--accent: #f72585;
--success: #06d6a0;
--warning: #ffd166;
--info: #118ab2;
--dark: #0f172a;
--darker: #070b15;
--light: #f8f9fa;
--lighter: #ffffff;
--gray: #64748b;
--gray-light: #e2e8f0;
--card-bg: rgba(255, 255, 255, 0.85);
--footer-bg: #070b15;
--radius-sm: 8px;
--radius: 16px;
--radius-lg: 24px;
--radius-xl: 32px;
--shadow-sm: 0 4px 6px rgba(2, 6, 23, 0.05);
--shadow: 0 10px 25px rgba(2, 6, 23, 0.1);
--shadow-lg: 0 20px 40px rgba(2, 6, 23, 0.15);
--shadow-xl: 0 25px 50px rgba(2, 6, 23, 0.25);
--transition: all 0.3s ease;
--transition-slow: all 0.5s ease;
--nav-height: 80px;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
html {
scroll-behavior: smooth;
scroll-padding-top: calc(var(--nav-height) + 20px);
}
body {
font-family: 'Inter', -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Ubuntu, sans-serif;
color: var(--dark);
background: var(--light);
line-height: 1.6;
overflow-x: hidden;
position: relative; /* necesario para Scrollspy */
}
h1, h2, h3, h4, h5, h6 { font-weight: 800; line-height: 1.2; margin-bottom: 0.5em; }
/* Custom Scrollbar */
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--gray-light); }
::-webkit-scrollbar-thumb { background: var(--primary); border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: var(--primary-dark); }
/* Navbar */
.navbar {
height: var(--nav-height);
backdrop-filter: blur(10px) saturate(180%);
background: rgba(255, 255, 255, 0.92);
box-shadow: var(--shadow-sm);
transition: var(--transition);
padding: 0.5rem 0;
}
.navbar.scrolled { box-shadow: var(--shadow); }
.navbar-brand { font-weight: 900; font-size: 1.5rem; display: flex; align-items: center; gap: 0.5rem; }
.navbar-brand span {
background: linear-gradient(135deg, var(--primary), var(--secondary));
-webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.nav-link { font-weight: 600; position: relative; padding: 0.5rem 1rem !important; transition: var(--transition); }
.nav-link::after {
content: ''; position: absolute; bottom: 0; left: 50%; width: 0; height: 2px;
background: linear-gradient(to right, var(--primary), var(--secondary));
transition: var(--transition); transform: translateX(-50%);
}
.nav-link:hover::after, .nav-link.active::after { width: 70%; }
.navbar-toggler { border: none; padding: 0.5rem; }
.navbar-toggler:focus { box-shadow: none; }
/* Buttons */
.btn { border-radius: var(--radius); font-weight: 600; padding: 0.75rem 1.5rem; transition: var(--transition); display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem; }
.btn-brand {
background: linear-gradient(135deg, var(--primary), var(--secondary));
color: white; border: none; box-shadow: var(--shadow); position: relative; overflow: hidden;
}
.btn-brand::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: var(--transition-slow);
}
.btn-brand:hover::before { left: 100%; }
.btn-brand:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.btn-ghost { background: transparent; border: 2px solid var(--gray-light); color: var(--dark); }
.btn-ghost:hover { border-color: var(--primary); background: rgba(67, 97, 238, 0.05); transform: translateY(-3px); box-shadow: var(--shadow); }
/* Hero Section */
.hero {
position: relative; padding-top: calc(var(--nav-height) + 2rem); padding-bottom: 6rem; overflow: hidden;
background: linear-gradient(135deg, rgba(67, 97, 238, 0.03) 0%, rgba(123, 44, 191, 0.03) 100%);
}
.hero::before{
content:''; position:absolute; top:-10%; right:-10%; width:500px; height:500px; border-radius:50%;
background: radial-gradient(circle, rgba(67, 97, 238, 0.15) 0%, transparent 70%); z-index:0;
}
.hero::after{
content:''; position:absolute; bottom:-10%; left:-10%; width:400px; height:400px; border-radius:50%;
background: radial-gradient(circle, rgba(123, 44, 191, 0.1) 0%, transparent 70%); z-index:0;
}
.hero-content { position: relative; z-index: 2; }
.badge-soft {
background: linear-gradient(135deg, rgba(67, 97, 238, 0.1), rgba(123, 44, 191, 0.1));
color: var(--primary); border: 1px solid rgba(67, 97, 238, 0.2);
padding: 0.5rem 1rem; border-radius:100px; font-weight:600; font-size:.85rem; display:inline-flex; align-items:center; gap:.5rem; margin-bottom:1.5rem;
}
.hero h1 {
font-size: 3.5rem;
background: linear-gradient(135deg, var(--primary), var(--secondary));
-webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
margin-bottom: 1.5rem;
}
.hero p { font-size: 1.25rem; color: var(--gray); margin-bottom: 2rem; }
.hero-image { position:relative; z-index:2; border-radius: var(--radius-xl); overflow:hidden; box-shadow: var(--shadow-xl); transform: perspective(1000px) rotateY(-5deg) rotateX(5deg); transition: var(--transition); }
.hero-image:hover { transform: perspective(1000px) rotateY(0) rotateX(0); }
.hero-image img { width:100%; height:auto; transition: var(--transition-slow); }
.hero-image:hover img { transform: scale(1.05); }
/* Section Styles */
section { padding: 5rem 0; position: relative; scroll-margin-top: calc(var(--nav-height) + 1rem); }
.section-title { position: relative; display: inline-block; margin-bottom: 2rem; }
.section-title::after {
content:''; position:absolute; bottom:-10px; left:0; width:60px; height:4px;
background: linear-gradient(to right, var(--primary), var(--secondary)); border-radius:2px;
}
.section-title.center::after { left:50%; transform: translateX(-50%); }
.lead-muted { color: var(--gray); font-size: 1.1rem; }
/* Cards */
.card-soft { background: var(--card-bg); backdrop-filter: blur(10px); border: none; border-radius: var(--radius-lg); box-shadow: var(--shadow); transition: var(--transition); overflow: hidden; }
.card-soft:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); }
.icon-pill {
width: 60px; height: 60px; border-radius: var(--radius); display:flex; align-items:center; justify-content:center;
background: linear-gradient(135deg, rgba(67, 97, 238, 0.1), rgba(123, 44, 191, 0.1)); color: var(--primary); font-size:1.5rem; transition: var(--transition);
}
.card-soft:hover .icon-pill { transform: scale(1.1); background: linear-gradient(135deg, var(--primary), var(--secondary)); color: white; }
/* Ticker / Gallery */
.ticker { position: relative; margin: 2rem 0; }
.ticker-track {
display: flex; gap: 1.5rem; overflow-x: auto; scroll-snap-type: x mandatory; scroll-behavior: smooth; padding: 1rem 0.5rem;
-ms-overflow-style: none; scrollbar-width: none;
}
.ticker-track::-webkit-scrollbar { display: none; }
.tick-card {
scroll-snap-align: start; flex: 0 0 auto; width: 320px; height: 320px; border-radius: var(--radius-lg); overflow: hidden; position: relative; box-shadow: var(--shadow); transition: var(--transition);
}
.tick-card:hover { transform: scale(1.03); box-shadow: var(--shadow-lg); }
.tick-card img { width: 100%; height: 100%; object-fit: cover; transition: var(--transition-slow);
/* ...cortado... */
/* Estilos SOLO para esta sección */
#unite-whatsapp{
background:
radial-gradient(900px 400px at 110% 5%, rgba(67,97,238,.06), transparent 60%),
radial-gradient(900px 400px at -10% 95%, rgba(123,44,191,.06), transparent 60%),
#fff;
}
#unite-whatsapp .uw-flyer{
border-radius: 28px; overflow: hidden;
box-shadow: 0 25px 50px rgba(2,6,23,.15);
background:#fff;
}
#unite-whatsapp .uw-card{
border:1px solid #e2e8f0; border-radius: 28px; background:#fff;
box-shadow: 0 12px 30px rgba(2,6,23,.08);
}
#unite-whatsapp .uw-card-header{
background: linear-gradient(135deg,#4361ee,#7b2cbf); color:#fff;
font-weight:800; letter-spacing:.3px; padding:1rem 1.25rem;
border-top-left-radius:28px;border-top-right-radius:28px;
}
#unite-whatsapp .uw-card-body{ padding:1.25rem 1.25rem 1.5rem }
#unite-whatsapp .uw-btn{
display:flex; align-items:center; justify-content:center; gap:.6rem;
width:100%; padding:.95rem 1.1rem; border:none; border-radius:16px; font-weight:800;
background:#25D366; color:#fff; box-shadow:0 12px 24px rgba(37,211,102,.25);
text-decoration:none;
}
#unite-whatsapp .uw-btn:hover{ filter:brightness(1.03) }
#unite-whatsapp .uw-mini{ color:#64748b; font-size:.9rem }
/* ====== Styles scoped a #videos ====== */
#videos{
padding: 3.5rem 0;
background:
radial-gradient(900px 400px at 110% 5%, rgba(67,97,238,.06), transparent 60%),
radial-gradient(900px 400px at -10% 95%, rgba(123,44,191,.06), transparent 60%),
#f8f9fa;
position: relative;
}
#videos .section-title{
font-weight: 900; margin: 0; position: relative; display: inline-block;
}
#videos .section-title::after{
content:""; position:absolute; left:0; bottom:-10px; width:60px; height:4px; border-radius:2px;
background: linear-gradient(90deg, var(--primary,#4361ee), var(--secondary,#7b2cbf));
}
#videos .btn-videos{
display:inline-flex; align-items:center; gap:.55rem;
border:1px solid rgba(2,6,23,.10); border-radius:14px;
padding:.65rem 1rem; font-weight:800; background:#fff; color:#0f172a;
box-shadow: 0 8px 20px rgba(2,6,23,.06);
transition: transform .06s ease, box-shadow .2s ease, border-color .2s ease;
}
#videos .btn-videos:hover{
transform: translateY(-1px);
border-color: color-mix(in oklab, var(--primary,#4361ee) 30%, transparent);
box-shadow: 0 12px 28px rgba(2,6,23,.10);
}
#videos .btn-videos .chevron{ transition: transform .2s ease; }
#videos .btn-videos[aria-expanded="true"] .chevron{ transform: rotate(180deg); }
/* Grid responsive (mobile-first) */
#videos .videos-grid{ display:grid; gap:14px; margin-top:1rem; }
/* 1 col en móviles por ancho completo */
@media (min-width:480px){ #videos .videos-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (min-width:768px){ #videos .videos-grid{ gap:16px; grid-template-columns: repeat(3, minmax(0,1fr)); } }
@media (min-width:1200px){ #videos .videos-grid{ grid-template-columns: repeat(5, minmax(0,1fr)); } }
/* Card/video */
#videos .video-card{
background:#fff; border:1px solid rgba(2,6,23,.06);
border-radius:16px; overflow:hidden;
box-shadow: 0 10px 24px rgba(2,6,23,.07);
transition: transform .12s ease, box-shadow .2s ease;
}
#videos .video-card:hover{ transform: translateY(-2px); box-shadow: 0 16px 36px rgba(2,6,23,.12); }
/* Frame 16:9 con Bootstrap */
#videos .ratio{ border-bottom-left-radius:16px; border-bottom-right-radius:16px; }
#videos video{ width:100%; height:100%; object-fit:cover; display:block; }
/* Meta */
#videos .video-meta{
padding:.6rem .8rem .75rem; display:flex; align-items:center; gap:.5rem;
font-size:.9rem; color:#475569; min-height:44px;
}
#videos .dot{
width:8px; height:8px; border-radius:999px; flex:0 0 auto;
background: linear-gradient(135deg, var(--primary,#4361ee), var(--secondary,#7b2cbf));
}
/* ===== Contacto (scoped) ===== */
#contacto {
--ctc-brand: #3b59f0;
--ctc-accent: #7c4dff;
--ctc-ink: #0f172a;
--ctc-muted: #64748b;
--ctc-card: #ffffff;
--ctc-bg: #f7f8fb;
--ctc-radius: 18px;
--ctc-shadow: 0 20px 50px rgba(2,6,23,.10);
--ctc-border: 1px solid rgba(2,6,23,.06);
}
#contacto.contacto-wrap{
position: relative;
padding: 80px 0;
background:
radial-gradient(1200px 600px at -10% -10%, rgba(124,77,255,.08), transparent 60%),
radial-gradient(900px 500px at 110% 5%, rgba(59,89,240,.10), transparent 60%),
var(--ctc-bg);
isolation: isolate;
}
#contacto .ctc-eyebrow{
display:inline-block;
padding:.4rem .8rem;
border-radius:999px;
background:linear-gradient(90deg, rgba(59,89,240,.10), rgba(124,77,255,.10));
border:1px solid rgba(59,89,240,.20);
color:var(--ctc-brand);
font-weight:700;
letter-spacing:.3px;
}
#contacto .ctc-title{ font-weight:900; letter-spacing:.2px; }
#contacto .ctc-lead{ color:var(--ctc-muted); max-width: 760px; margin: 0 auto; }
/* Cards */
#contacto .ctc-card{ background: color-mix(in oklab, var(--ctc-card) 86%, #fff); border: var(--ctc-border); border-radius: var(--ctc-radius); box-shadow: var(--ctc-shadow); overflow: hidden; }
/* Field group with icon */
#contacto .ctc-field{ position: relative; }
#contacto .ctc-field .ctc-ico{ position:absolute; inset: 0 auto 0 12px; display:grid; place-items:center; width: 40px; color:#6b7280; pointer-events:none; }
#contacto .ctc-field .form-control{
padding-left:48px; padding-top:.85rem; padding-bottom:.85rem;
border-radius: 14px; border:1px solid rgba(2,6,23,.10);
transition: box-shadow .25s ease, border-color .25s ease, transform .05s ease; background:#fff;
}
#contacto .ctc-field textarea.form-control{ padding-left:16px; }
#contacto .form-label{ font-weight:600; color:#334155 }
#contacto .form-control:focus{
border-color: color-mix(in oklab, var(--ctc-brand) 40%, #000 0%);
box-shadow: 0 0 0 .25rem color-mix(in oklab, var(--ctc-brand) 18%, transparent);
outline: none; transform: translateY(-1px);
}
#contacto .ctc-note{ color:var(--ctc-muted); font-size:.9rem; }
/* Buttons */
#contacto .btn-ctc{
--bg: linear-gradient(135deg, var(--ctc-brand), var(--ctc-accent));
background: var(--bg); color:#fff; border:none; padding:.85rem 1.2rem; border-radius:14px; font-weight:700;
box-shadow: 0 12px 24px rgba(59,89,240,.22); transition: transform .06s ease, filter .2s ease;
}
#contacto .btn-ctc:hover{ filter:brightness(1.03) }
#contacto .btn-ctc:active{ transform: translateY(1px) }
#contacto .btn-ghost{
background:#fff; color:var(--ctc-ink);
border:1px solid rgba(2,6,23,.12); box-shadow: 0 6px 16px rgba(2,6,23,.06);
}
/* Contact info side */
#contacto .ctc-side h5{ font-weight:800 }
#contacto .ctc-item{ color:var(--ctc-muted); display:flex; gap:10px; align-items:flex-start; }
#contacto .ctc-chip{
display:inline-flex; align-items:center; gap:8px; padding:.35rem .6rem; border-radius:999px; font-size:.85rem;
background:linear-gradient(90deg, rgba(59,89,240,.10), rgba(124,77,255,.10));
border:1px solid rgba(59,89,240,.15); color:#334155;
}
/* Map frame with gradient border */
#contacto .ctc-map{ border-radius:16px; overflow:hidden; position:relative; padding: 2px; background: linear-gradient(135deg, rgba(59,89,240,.35), rgba(124,77,255,.35)); }
#contacto .ctc-map > .frame{ border:0; border-radius:14px; width:100%; height:100%; }
/* Alerts */
#contacto .ctc-alert{ border-radius:14px; padding: .9rem 1rem; font-weight:600 }
#contacto .ctc-alert.success{ background:#ecfdf5; color:#065f46; border:1px solid #a7f3d0 }
#contacto .ctc-alert.error{ background:#fff7ed; color:#9a3412; border:1px solid #fed7aa }
/* Responsive spacing */
@media (min-width: 992px){
#contacto .stack-lg{ display:flex; gap:28px }
#contacto .stack-lg > *{ flex:1 }
}
/* 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;
}
.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, .social-pulse-delayed { position: absolute; width: 100%; height: 100%; border-radius: 50%; opacity: 0; animation: pulse 2s infinite; }
.social-pulse-delayed { animation-delay: .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,.1); opacity: 0; visibility: hidden; transition: all .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; }
/* Específicos */
.whatsapp-button { background: #25D366; box-shadow: 0 10px 25px rgba(37,211,102,.3); }
.whatsapp-button:hover { background: #128C7E; box-shadow: 0 15px 30px rgba(37,211,102,.4); }
.whatsapp-pulse { background: rgba(37,211,102,.6); }
.whatsapp-pulse-delayed { background: rgba(37,211,102,.4); }
.instagram-button { background: #E1306C; box-shadow: 0 10px 25px rgba(225,48,108,.3); }
.instagram-button:hover { background: #C13584; box-shadow: 0 15px 30px rgba(193,53,132,.4); }
.instagram-pulse { background: rgba(225,48,108,.6); }
.instagram-pulse-delayed { background: rgba(193,53,132,.4); }
.facebook-button { background: #1877F2; box-shadow: 0 10px 25px rgba(24,119,242,.3); }
.facebook-button:hover { background: #166FE5; box-shadow: 0 15px 30px rgba(22,111,229,.4); }
.facebook-pulse { background: rgba(24,119,242,.6); }
.facebook-pulse-delayed { background: rgba(22,111,229,.4); }
/* Animaciones */
@keyframes float { 0%{ transform: translateY(0); } 50%{ transform: translateY(-10px); } 100%{ transform: translateY(0); } }
@keyframes pulse { 0%{ transform: scale(.8); opacity: 0; } 70%{ transform: scale(1.3); opacity:.4; } 100%{ transform: scale(1.4); opacity: 0; } }
@keyframes heartbeat { 0%{ transform: scale(1); } 25%{ transform: scale(1.1); } 50%{ transform: scale(1); } 75%{ transform: scale(1.1); } 100%{ transform: scale(1); } }
.social-button { animation: heartbeat 1.5s ease 2s 2, float 3s ease-in-out infinite 3s; }
.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; }
}
administracionalarcon.com.ar
https://cdn.jsdelivr.net/npm/[email protected]/font/bootstrap-icons.csshttps://unpkg.com/aos@next/dist/aos.css/* ...tus reglas... */
:root {
/* Colores principales */
--primary: #0a6e5a;
--primary-dark: #065142;
--primary-light: #e8f5f2;
--secondary: #2fbf71;
--accent: #ff6b35;
--dark: #0f1b1a;
--text: #2a2f2e;
--text-light: #6e7a79;
--light: #f9fbfa;
--white: #ffffff;
/* Sombras */
--shadow-sm: 0 4px 6px rgba(0, 0, 0, 0.04);
--shadow-md: 0 10px 20px rgba(0, 0, 0, 0.08);
--shadow-lg: 0 20px 40px rgba(0, 0, 0, 0.12);
/* Bordes */
--radius-sm: 8px;
--radius-md: 16px;
--radius-lg: 24px;
--radius-xl: 32px;
/* Espaciado */
--space-xs: 0.5rem;
--space-sm: 1rem;
--space-md: 1.5rem;
--space-lg: 2.5rem;
--space-xl: 4rem;
/* Transiciones */
--transition-fast: 0.2s ease;
--transition-normal: 0.3s ease;
--transition-slow: 0.5s ease;
scroll-behavior: smooth;
}
/* Reset y base */
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
html, body {
font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
color: var(--text);
line-height: 1.6;
background-color: var(--white);
overflow-x: hidden;
}
/* Mejoras de tipografía */
h1, h2, h3, h4, h5, h6 {
font-weight: 700;
line-height: 1.2;
margin-bottom: var(--space-sm);
color: var(--dark);
}
p {
margin-bottom: var(--space-sm);
}
a {
color: var(--primary);
text-decoration: none;
transition: var(--transition-fast);
}
a:hover {
color: var(--primary-dark);
}
img {
max-width: 100%;
height: auto;
display: block;
}
/* Utilidades */
.container {
width: 100%;
max-width: 1200px;
margin: 0 auto;
padding: 0 var(--space-md);
}
.section {
padding: var(--space-xl) 0;
position: relative;
}
.section-title {
font-size: clamp(2rem, 5vw, 2.8rem);
margin-bottom: var(--space-sm);
position: relative;
display: inline-block;
}
.section-title::after {
content: '';
position: absolute;
bottom: -8px;
left: 0;
width: 60px;
height: 4px;
background: linear-gradient(90deg, var(--primary), var(--secondary));
border-radius: 2px;
}
.text-center {
text-align: center;
}
.text-center .section-title::after {
left: 50%;
transform: translateX(-50%);
}
.lead {
font-size: clamp(1rem, 2.5vw, 1.2rem);
color: var(--text-light);
margin-bottom: var(--space-md);
line-height: 1.6;
}
/* Botones */
.btn {
display: inline-flex;
align-items: center;
justify-content: center;
gap: var(--space-xs);
padding: 0.8rem 1.8rem;
border-radius: var(--radius-md);
font-weight: 600;
text-decoration: none;
transition: all var(--transition-normal);
cursor: pointer;
border: none;
position: relative;
overflow: hidden;
z-index: 1;
}
.btn::before {
content: '';
position: absolute;
top: 0;
left: 0;
width: 0%;
height: 100%;
background: linear-gradient(90deg, var(--primary-dark), var(--primary));
transition: var(--transition-normal);
z-index: -1;
}
.btn:hover::before {
width: 100%;
}
.btn-primary {
background: linear-gradient(90deg, var(--primary), var(--secondary));
color: var(--white);
box-shadow: var(--shadow-md);
}
.btn-primary:hover {
box-shadow: var(--shadow-lg);
transform: translateY(-2px);
color: var(--white);
}
.btn-outline {
background: transparent;
color: var(--primary);
border: 2px solid var(--primary);
}
.btn-outline:hover {
color: var(--white);
border-color: var(--primary-dark);
}
/* Navbar */
.navbar {
position: fixed;
top: 0;
left: 0;
width: 100%;
z-index: 1000;
background: rgba(255, 255, 255, 0.95);
backdrop-filter: blur(10px);
-webkit-backdrop-filter: blur(10px);
border-bottom: 1px solid rgba(255, 255, 255, 0.2);
box-shadow: var(--shadow-sm);
transition: var(--transition-normal);
}
.navbar.scrolled {
background: rgba(255, 255, 255, 0.98);
box-shadow: var(--shadow-md);
}
.nav-wrap {
display: flex;
align-items: center;
justify-content: space-between;
height: 80px;
}
.brand {
display: flex;
align-items: center;
gap: var(--space-sm);
text-decoration: none;
color: var(--dark);
font-weight: 700;
font-size: 1.2rem;
}
.brand img {
height: 48px;
width: auto;
border-radius: var(--radius-sm);
transition: var(--transition-normal);
}
.brand:hover img {
transform: scale(1.05);
}
.nav {
display: flex;
gap: var(--space-md);
align-items: center;
}
.nav a {
color: var(--text);
text-decoration: none;
font-weight: 500;
font-size: 0.95rem;
padding: 0.5rem 1rem;
border-radius: var(--radius-md);
transition: var(--transition-fast);
position: relative;
}
.nav a::after {
content: '';
position: absolute;
bottom: 0;
left: 50%;
width: 0;
height: 2px;
background: linear-gradient(90deg, var(--primary), var(--secondary));
transition: var(--transition-normal);
transform: translateX(-50%);
}
.nav a:hover::after,
.nav a.active::after {
width: 70%;
}
.nav a:hover,
.nav a.active {
color: var(--primary);
}
.nav-cta {
display: flex;
gap: var(--space-sm);
align-items: center;
margin-left: var(--space-md);
}
.hamb {
display: none;
font-size: 1.5rem;
background: none;
border: none;
color: var(--dark);
cursor: pointer;
}
/* Hero Section */
.hero {
position: relative;
padding-top: 120px;
padding-bottom: var(--space-xl);
overflow: hidden;
background: linear-gradient(135deg, #f8fdfb 0%, #e6f4f0 100%);
}
.hero::before {
content: '';
position: absolute;
top: -100px;
right: -100px;
width: 500px;
height: 500px;
border-radius: 50%;
background: linear-gradient(45deg, rgba(47, 191, 113, 0.1) 0%, rgba(10, 110, 90, 0.05) 100%);
z-index: 0;
}
.hero::after {
content: '';
position: absolute;
bottom: -150px;
left: -150px;
width: 600px;
height: 600px;
border-radius: 50%;
background: linear-gradient(45deg, rgba(255, 107, 53, 0.05) 0%, rgba(47, 191, 113, 0.1) 100%);
z-index: 0;
}
.hero-inner {
display: grid;
grid-template-columns: 1.1fr 0.9fr;
gap: var(--space-xl);
align-items: center;
position: relative;
z-index: 2;
}
.hero-content {
animation: fadeInUp 1s ease;
}
.hero .tag {
display: inline-block;
background: var(--primary-light);
color: var(--primary);
font-weight: 600;
padding: 0.4rem 1rem;
border-radius: 100px;
font-size: 0.8rem;
margin-bottom: var(--space-md);
box-shadow: var(--shadow-sm);
}
.hero h1 {
font-size: clamp(2.2rem, 5vw, 3.5rem);
li
/* ...cortado... */
/* === Hero offset dinámico en mobile según altura real del header === */
@media (max-width: 980px){
:root{ --nav-h: 80px; } /* fallback */
.hero{ padding-top: calc(var(--nav-h) + 28px) !important; }
/* el menú desplegable arranca debajo del header real */
.nav{ inset: var(--nav-h) 0 auto 0 !important; }
}
/* === Anchor offset global: evita que el header fijo tape el inicio de cada sección === */
html:focus-within { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce){ html:focus-within { scroll-behavior: auto; } }
[id] { scroll-margin-top: calc(var(--nav-h) + 16px); }
/* === HERO: ver la imagen completa (sin recorte) === */
.hero-figure{
/* anulamos cualquier ratio/altura fija que recorte */
aspect-ratio: auto !important;
height: auto !important;
display: grid;
place-items: center;
background: #fff; /* o un verde muy claro del logo */
border-radius: 20px;
box-shadow: 0 10px 30px rgba(0,0,0,.08);
padding: 10px; /* leve respiración para que no toque bordes */
overflow: hidden; /* por si alguna vez desborda */
}
.hero-figure img{
/* que se ajuste sin recortarse */
object-fit: contain !important;
width: auto; /* dejamos que el navegador decida el mejor ancho */
height: auto;
max-width: 100%; /* no pasar el ancho del contenedor */
max-height: min(62vh, 520px); /* alto máximo visible (ajustable) */
display: block;
}
/* En mobile permitimos un poquito menos de alto para que no empuje el contenido */
@media (max-width: 980px){
.hero-figure img{
max-height: 48vh;
}
}
/* Opcional: si tu grid fuerza 2 columnas y achica la figura, en mobile la pasamos a 1 */
@media (max-width: 980px){
.hero .hero-inner{
display: grid;
grid-template-columns: 1fr !important;
gap: 24px;
}
}
/* ---------- Ajustes rápidos ---------- */
.alx-tickers{ --tile-size: 500px; --gap:16px; --radius:16px; --brd:#e8f0ec; --bg:#fff; --shadow:0 10px 30px rgba(0,0,0,.08) }
.alx-tickers .lead{color:#6e7a79}
/* ---------- Ticker ---------- */
.alx-ticker{
position:relative; overflow:hidden; border-radius:18px;
border:1px solid var(--brd); background:var(--bg); box-shadow:var(--shadow); margin-top:10px
}
.alx-viewport{
overflow:auto; scroll-snap-type:x mandatory; display:flex; gap:var(--gap);
padding:16px; scrollbar-width:none; touch-action: pan-y;
}
.alx-viewport::-webkit-scrollbar{display:none}
.alx-track{display:flex; gap:var(--gap)}
.alx-tile{
flex:0 0 var(--tile-size); height:var(--tile-size);
border-radius:var(--radius); overflow:hidden; scroll-snap-align:center; background:#f2f6f4
}
.alx-tile img{width:100%; height:100%; object-fit:cover; object-position:center; cursor:pointer}
.alx-ctrls{
position:absolute; inset:0; display:flex; justify-content:space-between; align-items:center;
pointer-events:none; padding:0 6px
}
.alx-ctrl{
pointer-events:auto; width:42px; height:42px; border-radius:999px; display:grid; place-items:center;
border:1px solid #e8efe9; background:rgba(255,255,255,.9); box-shadow:var(--shadow);
cursor:pointer; transition:.2s
}
.alx-ctrl:hover{transform:translateY(-1px)}
.alx-ctrl svg{width:20px; height:20px}
@media (max-width:640px){
.alx-tile{ flex:0 0 min(86vw, var(--tile-size)); height:min(86vw, var(--tile-size)) }
}
/* ---------- Lightbox / Modal ---------- */
.alx-lightbox[hidden]{display:none !important}
.alx-lightbox{
position:fixed; inset:0; z-index:9999; background:rgba(0,0,0,.86);
display:grid; place-items:center; padding:24px; overscroll-behavior:none
}
.alx-lb-stage{ position:relative; width:100%; height:100%; display:grid; place-items:center }
.alx-lb-img{
max-width:min(96vw, 1400px); max-height:92vh; width:auto; height:auto;
object-fit:contain; background:#111; border-radius:12px; box-shadow:0 20px 60px rgba(0,0,0,.45)
}
.alx-lb-btn{
position:absolute; top:50%; transform:translateY(-50%);
width:48px; height:48px; border-radius:999px; display:grid; place-items:center;
border:1px solid rgba(255,255,255,.25); background:rgba(0,0,0,.45);
color:#fff; cursor:pointer; transition:.2s; backdrop-filter: blur(4px)
}
.alx-lb-btn:hover{ background:rgba(0,0,0,.65) }
.alx-lb-prev{ left:14px } .alx-lb-next{ right:14px }
.alx-lb-close{
position:absolute; top:14px; right:14px; width:44px; height:44px; border-radius:999px;
display:grid; place-items:center; border:1px solid rgba(255,255,255,.25); background:rgba(0,0,0,.45); color:#fff; cursor:pointer;
}
.alx-lb-counter{
position:absolute; bottom:14px; left:50%; transform:translateX(-50%);
color:#fff; font-weight:700; background:rgba(0,0,0,.45);
border:1px solid rgba(255,255,255,.25); padding:.35rem .65rem; border-radius:999px; font-size:14px
}
.alx-lb-backdrop{position:absolute; inset:0}
.fs-root{
--fs-brand:#1e6f5c; /* verde principal */
--fs-brand-2:#2fbf71; /* acento */
--fs-bg:#ffffff;
--fs-text:#0f1b1a;
--fs-muted:#6e7a79;
--fs-shadow:0 12px 35px rgba(0,0,0,.20);
position:fixed; right:18px; bottom:18px; z-index:9998;
display:grid; gap:10px; place-items:end;
font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif
}
.fs-overlay[hidden]{display:none!important}
.fs-overlay{
position:fixed; inset:0; z-index:9997; background:rgba(0,0,0,.28); backdrop-filter:blur(2px)
}
/* Botón principal “Contactar” (píldora) */
.fs-toggle{
border:0; cursor:pointer; height:56px; border-radius:999px;
color:#fff; background:linear-gradient(135deg,var(--fs-brand),var(--fs-brand-2));
display:flex; align-items:center; gap:10px; padding:0 16px 0 12px;
box-shadow:var(--fs-shadow); transition:transform .18s ease, box-shadow .18s ease
}
.fs-toggle:active{ transform:scale(.97) }
.fs-toggle .ico svg{ width:22px; height:22px }
.fs-toggle .txt{ font-weight:800; letter-spacing:.2px; font-size:15px }
/* Lista desplegable */
.fs-list{
display:grid; gap:10px; transform:translateY(10px); opacity:0; pointer-events:none;
transition:opacity .22s ease, transform .22s ease
}
.fs-root.fs-open .fs-list{ transform:none; opacity:1; pointer-events:auto }
.fs-item{
display:flex; align-items:center; gap:10px;
background:var(--fs-bg); color:var(--fs-text);
border:1px solid #e6efea; border-radius:999px; padding:10px 14px 10px 10px;
text-decoration:none; white-space:nowrap; box-shadow:var(--fs-shadow);
transition:transform .15s ease, background .15s ease, border-color .15s ease
}
.fs-item:hover{ transform:translateY(-1px); background:#f7fbf8; border-color:#dcefe6 }
.fs-ico{ width:28px; height:28px; border-radius:999px; display:grid; place-items:center; flex:0 0 28px }
.fs-ico svg{ width:18px; height:18px }
.fs-wa .fs-ico{ background:#25d366; color:#fff }
.fs-call .fs-ico{ background:#0aa84f; color:#fff }
.fs-mail .fs-ico{ background:#0f6; color:#0b3d2a }
.fs-ig .fs-ico{ background:radial-gradient(circle at 30% 110%, #fdf497 0,#fd5949 45%,#d6249f 60%,#285AEB 90%); color:#fff }
.fs-fb .fs-ico{ background:#1877f2; color:#fff }
.fs-label{ font-weight:700; font-size:14px }
.fs-sub{ font-size:12px; color:var(--fs-muted); margin-left:4px }
/* Viñeta / globo */
.fs-hint[hidden]{display:none!important}
.fs-hint{
position:absolute; right:78px; bottom:70px; /* junto al botón */
background:#fff; color:#0f1b1a; border:1px solid #e6efea; border-radius:14px;
padding:.45rem .7rem; font-weight:800; font-size:14px; box-shadow:var(--fs-shadow);
opacity:0; transform:translateY(6px); transition:.22s ease;
}
.fs-hint.show{ opacity:1; transform:none }
.fs-hint::after{
content:""; position:absolute; right:-7px; bottom:10px;
border:7px solid transparent; border-left-color:#fff;
filter:drop-shadow(0 0 0 #e6efea);
}
.fs-root.fs-open .fs-hint{ display:none }
@media (max-width:520px){
.fs-root{ right:14px; bottom:14px }
.fs-item{ padding:9px 12px 9px 9px }
.fs-hint{ right:72px; bottom:66px }
}
:root { --nav-h: 72px; } /* valor de respaldo */
[id] { scroll-margin-top: calc(var(--nav-h) + 16px); }
html { scroll-behavior: smooth; }