Preview de mixed.css
/* MIXED CSS PACK */
/* Template: fcmservicios.com.ar/index.html */
/* Template mtime: 2026-03-09 11:36:20 */
/* external link (no embedded): https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&display=swap */
/* external link (no embedded): https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css */
/* ===== INLINE <style> BLOCK #1 ===== */
/* =====================================================
VARIABLES
===================================================== */
:root {
--accent: #00ace3;
--accent-light: #1f4f78;
--accent-glow: rgba(10,43,74,0.18);
--gold: #b55bb2;
--gold-light: #e8cc9a;
--gold-dim: rgba(200,169,110,0.12);
--gray-50: #f8fafc;
--gray-100: #f1f5f9;
--gray-200: #e2e8f0;
--gray-300: #cbd5e1;
--gray-400: #94a3b8;
--gray-500: #64748b;
--gray-600: #475569;
--gray-700: #334155;
--gray-800: #1e293b;
--gray-900: #0f172a;
--text-primary: #0f172a;
--text-secondary: #475569;
--text-tertiary: #64748b;
--bg-primary: #ffffff;
--bg-secondary: #f8fafc;
--border-light: rgba(0,0,0,0.065);
--border-medium: rgba(10,43,74,0.14);
--border-gold: rgba(200,169,110,0.3);
--shadow-xs: 0 1px 3px rgba(0,0,0,0.04);
--shadow-sm: 0 2px 8px rgba(0,0,0,0.05), 0 1px 2px rgba(0,0,0,0.04);
--shadow-md: 0 8px 24px -4px rgba(10,43,74,0.10), 0 2px 6px rgba(0,0,0,0.04);
--shadow-lg: 0 20px 40px -12px rgba(10,43,74,0.16), 0 4px 12px rgba(0,0,0,0.06);
--shadow-xl: 0 32px 56px -16px rgba(10,43,74,0.22);
--shadow-gold: 0 4px 24px rgba(200,169,110,0.2);
--radius-sm: 4px;
--radius-md: 8px;
--radius-lg: 14px;
--radius-xl: 20px;
--radius-2xl: 28px;
--nav-height: 76px;
--font-display: "Space Grotesk", sans-serif;
--font-body: "Space Grotesk", system-ui, sans-serif;
}
/* =====================================================
RESET & BASE
===================================================== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
font-family: var(--font-body);
color: var(--text-primary);
background: var(--bg-secondary);
line-height: 1.65;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
overflow-x: hidden;
}
h1,h2,h3,h4,h5,h6 {
font-family: var(--font-display);
line-height: 1.15;
letter-spacing: -0.02em;
color: var(--text-primary);
}
h1 { font-size: clamp(2.6rem,5.5vw,4.2rem); font-weight: 800; letter-spacing: -0.035em; }
h2 { font-size: clamp(2rem,4vw,3rem); font-weight: 700; }
h3 { font-size: 1.15rem; font-weight: 700; letter-spacing: -0.01em; }
p { color: var(--text-secondary); line-height: 1.75; font-size: .975rem; }
a { color: var(--accent); text-decoration: none; transition: color .2s; }
a:hover { color: var(--accent-light); }
/* =====================================================
NOISE TEXTURE
===================================================== */
.noise-bg::after {
content: "";
position: absolute; inset: 0; pointer-events: none; z-index: 0;
background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");
background-repeat: repeat;
background-size: 160px 160px;
opacity: .5;
}
/* =====================================================
EYEBROW / LABEL
===================================================== */
.eyebrow {
display: inline-flex;
align-items: center;
gap: .5rem;
font-family: var(--font-body);
font-size: .75rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: .1em;
color: var(--gold);
margin-bottom: 1.1rem;
}
.eyebrow::before {
content: "";
display: inline-block;
width: 22px; height: 2px;
background: var(--gold);
border-radius: 99px;
}
/* =====================================================
LAYOUT
===================================================== */
.container { max-width: 1260px; }
.section { padding: 110px 0; }
.section-header {
text-align: center;
max-width: 680px;
margin: 0 auto 64px;
}
.section-header h2 { margin-bottom: 1.1rem; }
.section-header p { font-size: 1.05rem; color: var(--text-tertiary); }
/* =====================================================
NAVBAR
===================================================== */
.navbar {
background: rgba(255,255,255,0.97);
backdrop-filter: blur(16px);
-webkit-backdrop-filter: blur(16px);
border-bottom: 1px solid var(--border-light);
height: var(--nav-height);
padding: 0;
transition: box-shadow .3s, background .3s;
}
.navbar.scrolled {
box-shadow: 0 2px 20px rgba(10,43,74,.08);
background: rgba(255,255,255,0.99);
}
.navbar-brand {
display: flex; align-items: center; gap: 11px; padding: 0;
}
.navbar-brand img { height: 40px; width: auto; }
.brand-text {
font-family: var(--font-display);
font-weight: 700;
font-size: 1rem;
color: var(--text-primary);
letter-spacing: -.02em;
line-height: 1.2;
}
.brand-text small {
display: block;
font-size: .65rem;
font-weight: 500;
color: var(--gold);
letter-spacing: .08em;
text-transform: uppercase;
}
.navbar-nav { gap: 2px; }
.navbar-nav .nav-link {
font-family: var(--font-body);
font-size: .9rem;
font-weight: 500;
color: var(--text-secondary);
padding: .45rem .9rem !important;
border-radius: var(--radius-md);
transition: all .2s;
position: relative;
}
.navbar-nav .nav-link:hover { color: var(--accent); background: var(--accent-soft,#eef3f8); }
.navbar-nav .nav-link.active { color: var(--accent); font-weight: 600; }
.nav-cta {
display: inline-flex; align-items: center; gap: .45rem;
padding: .5rem 1.2rem;
font-family: var(--font-body);
font-size: .88rem;
font-weight: 600;
background: var(--accent);
color: #fff !important;
border-radius: var(--radius-md);
margin-left: .75rem;
transition: all .25s;
border: 1.5px solid transparent;
}
.nav-cta:hover {
background: var(--accent-light);
transform: translateY(-1px);
box-shadow: var(--shadow-md);
}
/* toggler */
.navbar-toggler { border: none; padding: 6px; }
.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='%230a2b4a' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
}
/* =====================================================
HERO
===================================================== */
#inicio {
padding-top: calc(var(--nav-height) + 60px);
padding-bottom: 100px;
background: #fff;
position: relative;
overflow: hidden;
}
/* geometric accent — right side */
#inicio::before {
content: "";
position: absolute;
top: -120px; right: -180px;
width: 700px; height: 700px;
background: radial-gradient(ellipse at 60% 40%, rgba(10,43,74,.06) 0%, transparent 70%);
border-radius: 50%;
pointer-events: none;
}
/* subtle grid */
#inicio::after {
content: "";
position: absolute;
inset: 0; pointer-events: none;
background-image:
linear-gradient(var(--border-light) 1px, transparent 1px),
linear-gradient(90deg, var(--border-light) 1px, transparent 1px);
background-size: 40px 40px;
mask-image: radial-gradient(ellipse 80% 80% at 80% 50%, black 0%, transparent 70%);
-webkit-mask-image: radial-gradient(ellipse 80% 80% at 80% 50%, black 0%, transparent 70%);
}
.hero-content { max-width: 560px; position: relative; z-index: 1; }
.hero-content h1 { margin-bottom: 1.4rem; }
.hero-content h1 span { color: var(--accent); }
.hero-lead {
font-size: 1.08rem;
color: var(--text-tertiary);
margin-bottom: 2.2rem;
max-width: 480px;
}
.hero-features {
display: grid;
grid-template-columns: 1fr 1fr;
gap: .6rem 1rem;
margin-bottom: 2.8rem;
list-style: none; padding: 0;
}
.hero-features li {
display: flex; align-items: flex-start; gap: .6rem;
font-size: .88rem;
font-weight: 500;
color: var(--text-secondary);
}
.hero-features li .dot {
flex-shrink: 0;
margin-top: .38em;
width: 6px; height: 6px;
border-radius: 50%;
background: var(--gold);
}
.hero-actions { display: flex; gap: .9rem; flex-wrap: wrap; }
.btn-primary-fcm {
display: inline-flex; align-items: center; gap: .5rem;
padding: .8rem 1.8rem;
background: var(--accent);
color: #fff;
font-family: var(--font-body);
font-size: .92rem;
font-weight: 600;
border-radius: var(--radius-md);
border: none;
cursor: pointer;
transition: all .25s;
text-decoration: none;
}
.btn-primary-fcm:hover {
background: var(--accent-light);
color: #fff;
transform: translateY(-2px);
box-shadow: var(--shadow-md);
}
.btn-secondary-fcm {
display: inline-flex; align-items: center; gap: .5rem;
padding: .8rem 1.6rem;
background: transparent;
color: var(--text-primary);
font-family: var(--font-body);
font-size: .92rem;
font-weight: 500;
border-radius: var(--radius-md);
border: 1.5px solid var(--border-medium);
cursor: pointer;
transition: all .25s;
text-decoration: none;
}
.btn-secondary-fcm:hover {
border-color: var(--accent);
color: var(--accent);
background: rgba(10,43,74,.03);
}
/* Hero image panel */
.hero-image { position: relative; z-index: 1; }
.hero-img-wrap {
position: relative;
border-radius: var(--radius-2xl);
overflow: hidden;
box-shadow: var(--shadow-xl);
background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(244,248,252,.98));
padding: clamp(16px, 2.5vw, 28px);
}
.hero-img-wrap::after {
content: "";
position: absolute; inset: 0;
background: linear-gradient(160deg, transparent 55%, rgba(10,43,74,.10) 100%);
pointer-events: none;
}
.hero-img-wrap img {
width: 100%;
display: block;
aspect-ratio: 4/3;
object-fit: contain;
object-position: center;
}
/* floating badge */
.hero-badge {
position: absolute;
bottom: 16px;
left: -18px;
background: #fff;
border: 1px solid var(--border-light);
border-radius: var(--radius-lg);
padding: .7rem 1rem;
box-shadow: var(--shadow-lg);
max-width: 180px;
z-index: 2;
}
.hero-badge strong {
display: block;
font-family: var(--font-display);
font-weight: 700;
font-size: .8rem;
color: var(--text-primary);
margin-bottom: .15rem;
}
.hero-badge span {
font-size: .7rem;
color: var(--text-tertiary);
}
.hero-badge-dot {
width: 6px;
height: 6px;
border-radius: 50%;
background: #22c55e;
display: inline-block;
margin-right: .3rem;
box-shadow: 0 0 0 2px rgba(34,197,94,.2);
}
/* stat strip */
.hero-stats {
display: flex; gap: 0;
margin-top: 56px;
border: 1px solid var(--border-light);
border-radius: var(--radius-xl);
background: var(--bg-secondary);
overflow: hidden;
}
.hero-stat {
flex: 1;
padding: 1.2rem 1.5rem;
border-right: 1px solid var(--border-light);
text-align: center;
}
.hero-stat:last-child { border-right: none; }
.hero-stat .val {
display: block;
font-family: var(--font-display);
font-size: 1.7rem;
font-weight: 800;
color: var(--accent);
letter-spacing: -.03em;
line-height: 1;
margin-bottom: .2rem;
}
.hero-stat .lbl { font-size: .75rem; font-weight: 500; color: var(--text-tertiary); }
/* =====================================================
QUIÉNES SOMOS
===================================================== */
#quienes-somos {
background: var(--bg-secondary);
position: relative;
}
.prose-card {
background: #fff;
border: 1px solid var(--border-light);
border-radius: var(--radius-xl);
padding: 2.5rem;
height: 100%;
}
.prose-card p + p { margin-top: 1rem; }
.stat-grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 1rem;
height: 100%;
}
.stat-item {
background: #fff;
border: 1px solid var(--border-light);
border-radius: var(--radius-lg);
padding: 1.5rem;
transition: all .3s;
position: relative;
overflow: hidden;
}
.stat-item::before {
content: "";
position: absolute;
top: 0; left: 0;
width: 100%; height: 3px;
background: linear-gradient(90deg, var(--gold), var(--gold-light));
opacity: 0;
transition: opacity .3s;
}
.stat-item:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.stat-item:hover::before { opacity: 1; }
.stat-item h3 {
font-size: .85rem;
font-weight: 700;
color: var(--accent);
text-transform: uppercase;
letter-spacing: .04em;
margin-bottom: .65rem;
}
.stat-item p { font-size: .875rem; margin: 0; }
/* =====================================================
SERVICIOS
===================================================== */
#servicios { background: #fff; }
.service-card {
background: var(--bg-secondary);
border: 1px solid var(--border-light);
border-radius: var(--radius-xl);
padding: 2rem 1.75rem 1.75rem;
height: 100%;
transition: all .3s cubic-bezier(.23,1,.32,1);
position: relative;
overflow: hidden;
}
.service-card::after {
content: "";
position: absolute;
bottom: 0; left: 0; right: 0;
height: 3px;
background: linear-gradient(90deg, var(--accent), var(--accent-light));
transform: scaleX(0);
transform-origin: left;
transition: transform .35s cubic-bezier(.23,1,.32,1);
}
.service-card:hover {
background: #fff;
border-color: var(--border-medium);
box-shadow: var(--shadow-lg);
transform: translateY(-4px);
}
.service-card:hover::after { transform: scaleX(1); }
.service-icon {
width: 52px; height: 52px;
border-radius: var(--radius-lg);
background: var(--accent);
display: flex; align-items: center; justify-content: center;
margin-bottom: 1.4rem;
transition: all .3s;
}
.service-card:hover .service-icon {
background: var(--accent-light);
box-shadow: 0 8px 20px rgba(10,43,74,.3);
}
.service-icon svg {
width: 24px; height: 24px;
stroke: #fff; stroke-width: 1.75; fill: none;
}
.service-card h3 { margin-bottom: .6rem; }
.service-card p { font-size: .875rem; }
/* =====================================================
POR QUÉ ELEGIRNOS
===================================================== */
#porque-elegirnos { background: var(--bg-secondary); }
.why-card {
background: #fff;
border: 1px solid var(--border-light);
border-radius: var(--radius-xl);
padding: 2rem 1.75rem;
height: 100%;
display: flex; flex-direction: column;
gap: 1rem;
transition: all .3s;
}
.why-card:hover {
box-shadow: var(--shadow-lg);
border-color: var(--border-medium);
transform: translateY(-3px);
}
.why-num {
font-family: var(--font-display);
font-size: .72rem;
font-weight: 700;
letter-spacing: .1em;
color: var(--gold);
text-transform: uppercase;
}
.why-icon {
width: 44px; height: 44px;
border-radius: var(--radius-md);
background: var(--gold-dim);
border: 1px solid var(--border-gold);
display: flex; align-items: center; justify-content: center;
}
.why-icon svg {
width: 22px; height: 22px;
stroke: var(--gold); stroke-width: 1.75; fill: none;
}
.why-card h3 { font-size: 1.05rem; margin: 0; }
.why-card p { font-size: .875rem; margin: 0; }
/* =====================================================
GALERÍA
===================================================== */
.gal-gallery { background: #fff; }
.gal-gallery .carousel { max-width: 960px; margin: 0 auto; }
.gal-frame {
height: clamp(280px,52vh,500px);
background: var(--bg-secondary);
border-radius: var(--radius-xl);
overflow: hidden;
box-shadow: var(--shadow-xl);
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;
cursor: zoom-in;
border-radius: var(--radius-lg);
transition: transform .3s;
}
.gal-img:hover { transform: scale(1.015); }
.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(10,43,74,.7);
border-radius: 50%;
margin: 0 16px;
backdrop-filter: blur(4px);
transition: background .2s;
}
.gal-gallery .carousel-control-prev:hover,
.gal-gallery .carousel-control-next:hover { background: var(--accent); }
.gal-gallery .carousel-indicators { bottom: -36px; }
.gal-gallery .carousel-indicators button {
width: 7px; height: 7px;
border-radius: 50%;
background: var(--gray-300);
border: none; margin: 0 4px;
transition: all .3s;
}
.gal-gallery .carousel-indicators button.active {
background: var(--accent);
transform: scale(1.3);
}
#galLightbox .modal-content { background: #000; border-radius: var(--radius-xl); }
.gal-lightbox-nav {
position: absolute; top: 50%; transform: translateY(-50%);
border: 0; width: 44px; height: 44px; border-radius: 50%;
background: rgba(255,255,255,.16); color: #fff;
font-size: 28px; line-height: 44px; text-align: center;
z-index: 5; cursor: pointer; transition: background .2s;
}
.gal-lightbox-nav:hover { background: rgba(255,255,255,.28); }
/* =====================================================
ACCORDION FAQS
===================================================== */
#faqs { background: var(--bg-secondary); }
.accordion {
--bs-accordion-border-color: var(--border-light);
--bs-accordion-btn-focus-box-shadow: none;
--bs-accordion-active-bg: white;
--bs-accordion-active-color: var(--accent);
}
.accordion-item {
border: 1px solid var(--border-light) !important;
border-radius: var(--radius-lg) !important;
overflow: hidden;
margin-bottom: .85rem;
background: white;
transition: box-shadow .2s;
}
.accordion-item:hover { box-shadow: var(--shadow-sm); }
.accordion-button {
font-family: var(--font-display);
font-weight: 600;
font-size: .975rem;
color: var(--text-primary);
padding: 1.4rem 1.5rem;
background: white;
}
.accordion-button:not(.collapsed) {
color: var(--accent); background: white; box-shadow: none;
}
.accordion-button::after {
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%230a2b4a'%3E%3Cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E");
}
.accordion-body {
color: var(--text-secondary);
font-size: .925rem;
padding: 0 1.5rem 1.4rem;
line-height: 1.75;
}
/* =====================================================
CONTACTO
===================================================== */
#contacto { background: #fff; }
.contact-info-card {
background: var(--accent);
border-radius: var(--radius-xl);
padding: 2.5rem;
height: 100%;
position: relative;
overflow: hidden;
}
.contact-info-card::before {
content: "";
position: absolute;
top: -80px; right: -80px;
width: 260px; height: 260px;
border-radius: 50%;
background: rgba(255,255,255,.05);
pointer-events: none;
}
.contact-info-card::after {
content: "";
position: absolute;
bottom: -60px; left: -60px;
width: 200px; height: 200px;
border-radius: 50%;
background: rgba(255,255,255,.04);
pointer-events: none;
}
.contact-info-card .eyebrow { color: var(--gold); }
.contact-info-card h3 {
font-family: var(--font-display);
font-size: 1.6rem;
color: #fff;
margin-bottom: .8rem;
position: relative; z-index: 1;
}
.contact-info-card > p {
color: rgba(255,255,255,.7);
font-size: .9rem;
position: relative; z-index: 1;
}
.contact-list {
list-style: none; padding: 0;
margin-top: 2rem;
position: relative; z-index: 1;
}
.contact-list li {
display: flex; gap: 1rem; align-items: flex-start;
padding: 1rem 0;
border-bottom: 1px solid rgba(255,255,255,.1);
}
.contact-list li:last-child { border-bottom: none; }
.contact-list .ci-icon {
width: 36px; height: 36px; flex-shrink: 0;
border-radius: var(--radius-md);
background: rgba(255,255,255,.12);
display: flex; align-items: center; justify-content: center;
}
.contact-list .ci-icon svg {
width: 16px; height: 16px;
stroke: var(--gold); stroke-width: 2; fill: none;
}
.contact-list strong {
display: block; font-size: .75rem;
font-weight: 600; letter-spacing: .06em;
text-transform: uppercase; color: rgba(255,255,255,.5);
margin-bottom: .2rem;
}
.contact-list a, .contact-list span {
color: rgba(255,255,255,.88);
font-size: .9rem;
}
.contact-list a:hover { color: var(--gold-light); }
.contact-form-card {
background: white;
border: 1px solid var(--border-light);
border-radius: var(--radius-xl);
padding: 2.5rem;
box-shadow: var(--shadow-sm);
}
.contact-form-card h3 {
font-size: 1.35rem;
margin-bottom: .4rem;
}
.contact-form-card > p {
font-size: .9rem; color: var(--text-tertiary);
margin-bottom: 2rem;
}
.form-group { margin-bottom: 1.2rem; }
.form-label {
display: block;
font-size: .78rem; font-weight: 600;
letter-spacing: .04em; text-transform: uppercase;
color: var(--text-secondary);
margin-bottom: .5rem;
}
.form-control, .form-select {
width: 100%;
border: 1.5px solid var(--border-light);
border-radius: var(--radius-md);
padding: .78rem 1rem;
font-family: var(--font-body);
font-size: .92rem;
color: var(--text-primary);
background: var(--bg-secondary);
transition: all .2s;
outline: none;
}
.form-control:focus, .form-select:focus {
border-color: var(--accent);
background: #fff;
box-shadow: 0 0 0 3px rgba(10,43,74,.08);
}
.form-control::placeholder { color: var(--gray-400); }
textarea.form-control { min-height: 120px; resize: vertical; }
.btn-submit {
display: inline-flex; align-items: center; gap: .55rem;
padding: .88rem 2.2rem;
background: var(--accent);
color: #fff;
font-family: var(--font-body);
font-size: .92rem;
font-weight: 600;
border: none;
border-radius: var(--radius-md);
cursor: pointer;
transition: all .25s;
width: 100%;
justify-content: center;
}
.btn-submit:hover {
background: var(--accent-light);
transform: translateY(-2px);
box-shadow: var(--shadow-md);
}
.btn-submit svg { width: 18px; height: 18px; stroke: #fff; stroke-width: 2; fill: none; }
/* =====================================================
FOOTER
===================================================== */
.footer {
background: var(--gray-900);
color: white;
padding: 5rem 0 0;
position: relative;
overflow: hidden;
}
.footer::before {
content: "";
position: absolute; top: 0; left: 0; right: 0;
height: 1px;
background: linear-gradient(90deg, transparent, var(--gold), transparent);
opacity: .4;
}
.footer-brand {
display: flex; align-items: center; gap: 1rem;
margin-bottom: 1.4rem;
}
.footer-brand img {
height: 44px; width: auto;
}
.footer-brand-name {
font-family: var(--font-display);
font-weight: 700; font-size: 1.1rem;
color: #fff; letter-spacing: -.02em; line-height: 1.2;
}
.footer-brand-name small {
display: block; font-size: .65rem;
color: var(--gold); letter-spacing: .1em;
text-transform: uppercase; font-weight: 500;
}
.footer-text { color: var(--gray-400); font-size: .9rem; line-height: 1.75; max-width: 320px; }
.footer h6 {
font-family: var(--font-display);
color: white; font-weight: 700;
font-size: .75rem; letter-spacing: .1em;
text-transform: uppercase;
margin-bottom: 1.4rem;
}
.footer ul { list-style: none; padding: 0; }
.footer ul li { margin-bottom: .65rem; }
.footer a { color: var(--gray-400); font-size: .9rem; transition: color .2s; }
.footer a:hover { color: var(--gold-light); }
.footer-divider {
height: 1px;
background: rgba(255,255,255,.07);
margin: 3.5rem 0 0;
}
.footer-bottom {
padding: 1.5rem 0;
color: var(--gray-500); font-size: .82rem;
}
.footer-bottom a { color: var(--gray-400); font-weight: 600; }
.footer-bottom a:hover { color: var(--gold); }
/* =====================================================
SCROLL ANIMATIONS
===================================================== */
.reveal {
opacity: 0;
transform: translateY(24px);
transition: opacity .6s cubic-bezier(.23,1,.32,1), transform .6s cubic-bezier(.23,1,.32,1);
}
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-delay-1 { transition-delay: .1s; }
.reveal-delay-2 { transition-delay: .2s; }
.reveal-delay-3 { transition-delay: .3s; }
.reveal-delay-4 { transition-delay: .4s; }
.reveal-delay-5 { transition-delay: .5s; }
/* =====================================================
RESPONSIVE
===================================================== */
@media (max-width: 991.98px) {
.navbar-collapse {
background: white;
padding: 1rem 1.2rem;
border-radius: var(--radius-lg);
margin-top: .5rem;
border: 1px solid var(--border-light);
box-shadow: var(--shadow-lg);
}
.nav-cta { margin-left: 0; margin-top: .5rem; width: 100%; justify-content: center; }
.hero-image { margin-top: 3rem; }
.hero-badge { left: 0; }
.hero-stats { flex-wrap: wrap; }
.hero-stat { min-width: 50%; }
.stat-grid { grid-template-columns: 1fr; }
}
@media (max-width: 767.98px) {
.section { padding: 70px 0; }
.hero-features { grid-template-columns: 1fr; }
.contact-info-card, .contact-form-card { padding: 1.75rem; }
.hero-stats { display: none; }
h1 { font-size: 2.3rem; }
}
@media (max-width: 575.98px) {
.hero-actions { flex-direction: column; }
.btn-primary-fcm, .btn-secondary-fcm { width: 100%; justify-content: center; }
}
/* ===== INLINE <style> BLOCK #2 ===== */
/* ===== Contenedor fijo ===== */
.wa-float{
position: fixed;
right: 18px;
bottom: 18px;
z-index: 2147483647;
display: flex;
flex-direction: column;
align-items: flex-end;
font-family: inherit;
}
/* ===== Botón flotante ===== */
.wa-btn{
width: 60px;
height: 60px;
border-radius: 50%;
border: none;
background: linear-gradient(135deg, #25D366, #128C7E);
color: #fff;
display: grid;
place-items: center;
cursor: pointer;
box-shadow: 0 10px 30px rgba(37,211,102,.45);
transition: transform .25s ease, box-shadow .25s ease;
}
.wa-btn:hover{
transform: translateY(-3px) scale(1.05);
box-shadow: 0 14px 36px rgba(37,211,102,.55);
}
/* ===== Card ===== */
.wa-card{
position: absolute;
right: 0;
bottom: 74px;
width: min(360px, 92vw);
background: #fff;
border-radius: 18px;
border: 1px solid #e3e6ea;
box-shadow: 0 18px 60px rgba(0,0,0,.25);
overflow: hidden;
transform: translateY(10px);
opacity: 0;
transition: .25s ease;
}
.wa-card[aria-modal="true"]{
transform: none;
opacity: 1;
}
/* ===== Head ===== */
.wa-head{
display: flex;
align-items: center;
gap: 12px;
padding: 14px;
background: linear-gradient(135deg, #0a2b4a, #154d7a);
color: #fff;
}
.wa-avatar{
width: 40px;
height: 40px;
background: #fff;
border-radius: 10px;
display: grid;
place-items: center;
overflow: hidden;
flex: 0 0 40px;
}
.wa-avatar img{
width: 26px;
height: 26px;
object-fit: contain;
}
.wa-title{
font-weight: 800;
line-height: 1.1;
}
.wa-status{
font-size: .85rem;
opacity: .92;
}
.wa-close{
margin-left: auto;
border: none;
background: transparent;
color: #fff;
font-size: 24px;
cursor: pointer;
width: 32px;
height: 32px;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
opacity: .9;
}
.wa-close:hover{
opacity: 1;
background: rgba(255,255,255,.14);
}
/* ===== Body ===== */
.wa-body{
padding: 14px;
max-height: 40vh;
overflow: auto;
background: #f7f9fc;
display: flex;
flex-direction: column;
gap: 8px;
}
.wa-bubble{
max-width: 88%;
padding: 10px 12px;
border-radius: 14px;
font-size: .95rem;
box-shadow: 0 4px 10px rgba(0,0,0,.08);
}
.wa-bot{
background: #fff;
border: 1px solid #e3e6ea;
align-self: flex-start;
}
.wa-user{
background: #eaf7f0;
border: 1px solid #cfeedd;
align-self: flex-end;
}
/* ===== Compose ===== */
.wa-compose{
display: grid;
grid-template-columns: 1fr auto;
gap: 8px;
padding: 10px;
border-top: 1px solid #e3e6ea;
background: #fff;
}
.wa-compose textarea{
resize: none;
border-radius: 12px;
padding: 10px;
border: 1px solid #e3e6ea;
font-family: inherit;
outline: none;
}
.wa-compose textarea:focus{
border-color: #0a2b4a;
box-shadow: 0 0 0 3px rgba(10,43,74,.10);
}
.wa-send{
background: #0a2b4a;
color: #fff;
border: none;
border-radius: 12px;
padding: 0 16px;
cursor: pointer;
transition: background .2s ease;
}
.wa-send:hover{
background: #154d7a;
}
@media (max-width: 480px){
.wa-float{
right: 12px;
bottom: 12px;
}
.wa-card{
width: calc(100vw - 24px);
}
}