Preview de mixed.css
/* MIXED CSS PACK */
/* Template: construccionsala.com.ar/index.html */
/* Template mtime: 2026-05-20 11:50:05 */
/* external link (no embedded): https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700;800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,300&display=swap */
/* external link (no embedded): https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css */
/* ===== INLINE <style> BLOCK #1 ===== */
/* ─── TOKENS ─────────────────────────────────────────── */
:root{
--accent:#0a2b4a;
--accent-dark:#08233c;
--accent-mid:#1a4a72;
--accent-soft:#eef4f9;
--text:#101820;
--muted:#5d6670;
--line:#dbe4ec;
--soft:#f7f9fb;
--white:#ffffff;
--radius-xl:28px;
--radius-lg:22px;
--radius-md:18px;
--shadow-lg:0 24px 60px rgba(10,43,74,.14);
--shadow-md:0 16px 38px rgba(16,24,32,.08);
--shadow-sm:0 10px 24px rgba(16,24,32,.06);
--container:1240px;
--font-display:'Sora',sans-serif;
--font-body:'DM Sans',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
font-family:var(--font-body);
color:var(--text);
background:var(--white);
text-rendering:optimizeLegibility;
-webkit-font-smoothing:antialiased;
overflow-x:hidden;
overflow-x:clip;
}
a{text-decoration:none}
img{display:block;max-width:100%}
.container-site{max-width:var(--container);margin-inline:auto;padding-inline:28px}
.section{padding:110px 0}
/* ─── EYEBROW ─────────────────────────────────────────── */
.eyebrow{
display:inline-flex;
align-items:center;
gap:9px;
padding:8px 18px;
border-radius:999px;
background:var(--accent-soft);
border:1px solid rgba(10,43,74,.12);
color:var(--accent);
font-size:.72rem;
font-weight:700;
font-family:var(--font-display);
letter-spacing:.12em;
text-transform:uppercase;
margin-bottom:20px;
}
.eyebrow::before{
content:"";
width:6px;height:6px;
border-radius:50%;
background:var(--accent);
flex:0 0 auto;
}
/* ─── SECTION HEAD ────────────────────────────────────── */
.section-head{
max-width:780px;
margin:0 auto 60px;
text-align:center;
}
.section-title{
font-family:var(--font-display);
font-size:clamp(1.82rem,3.25vw,2.85rem);
line-height:1.08;
letter-spacing:-.04em;
font-weight:800;
color:var(--text);
}
.section-subtitle{
margin:16px auto 0;
max-width:680px;
color:var(--muted);
font-size:1.05rem;
line-height:1.9;
font-weight:300;
}
/* ─── NAVBAR ─────────────────────────────────────────── */
.navbar{
padding:0;
background:rgba(255,255,255,.92);
border-bottom:1px solid rgba(10,43,74,.07);
backdrop-filter:blur(20px);
-webkit-backdrop-filter:blur(20px);
transition:box-shadow .3s;
}
.navbar.scrolled{
box-shadow:0 4px 40px rgba(10,43,74,.08);
}
.navbar .container-site{
display:flex;
align-items:center;
justify-content:space-between;
padding-block:16px;
}
.navbar-brand{
display:flex;
align-items:center;
gap:12px;
color:var(--text);
}
.brand-logo,.footer-logo{
height:38px;width:auto;object-fit:contain;flex:0 0 auto;
}
.brand-text{
font-family:var(--font-display);
font-size:.88rem;
font-weight:700;
color:var(--text);
letter-spacing:-.02em;
line-height:1.2;
}
.brand-text small{
display:block;
font-family:var(--font-body);
font-size:.7rem;
font-weight:400;
color:var(--muted);
letter-spacing:.04em;
text-transform:uppercase;
}
.navbar-nav-wrap{
display:flex;
align-items:center;
gap:4px;
min-width:0;
}
.nav-link{
font-family:var(--font-body);
color:var(--muted);
font-size:.84rem;
font-weight:500;
padding:.6rem 1rem !important;
border-radius:10px;
transition:color .2s, background .2s;
}
.nav-link:hover,.nav-link.active{
color:var(--accent);
background:var(--accent-soft);
}
.nav-cta{
margin-left:8px;
padding:.6rem 1.4rem !important;
background:var(--accent);
color:#fff !important;
border-radius:999px;
font-weight:600;
font-size:.88rem;
transition:background .2s, transform .2s, box-shadow .2s;
}
.nav-cta:hover{
background:var(--accent-dark) !important;
transform:translateY(-1px);
box-shadow:0 8px 24px rgba(10,43,74,.2);
}
.navbar-toggler{
border:1px solid rgba(10,43,74,.14);
box-shadow:none !important;
padding:.5rem .7rem;
border-radius:12px;
}
.navbar-toggler-icon{
background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(16,24,32,.85)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}
.navbar-collapse{
flex-grow:0;
min-width:0;
}
/* ─── HERO ───────────────────────────────────────────── */
.hero{
position:relative;
padding:156px 0 96px;
background:#fff;
overflow:hidden;
}
/* Decorative grid */
.hero::before{
content:"";
position:absolute;
inset:0;
background-image:
linear-gradient(rgba(10,43,74,.04) 1px, transparent 1px),
linear-gradient(90deg, rgba(10,43,74,.04) 1px, transparent 1px);
background-size:48px 48px;
mask-image:radial-gradient(ellipse 80% 60% at 50% 0%, black 40%, transparent 100%);
pointer-events:none;
}
/* Top gradient wash */
.hero::after{
content:"";
position:absolute;
top:0;left:0;right:0;
height:400px;
background:linear-gradient(180deg, var(--accent-soft) 0%, transparent 100%);
pointer-events:none;
}
.hero-inner{
position:relative;
z-index:2;
}
.hero-grid{
display:grid;
grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);
gap:52px;
align-items:center;
}
.hero-copy{}
.hero-title{
font-family:var(--font-display);
font-size:clamp(2.35rem,4.35vw,4rem);
line-height:1.01;
letter-spacing:-.06em;
font-weight:800;
color:var(--text);
margin-top:4px;
}
.hero-title .accent{
color:var(--accent);
display:block;
position:relative;
}
.hero-title .accent::after{
content:"";
position:absolute;
left:0;bottom:-4px;
width:100%;height:3px;
background:linear-gradient(90deg,var(--accent),transparent);
border-radius:99px;
opacity:.35;
}
.hero-text{
margin:24px 0 0;
color:var(--muted);
font-size:1.06rem;
line-height:1.94;
max-width:560px;
font-weight:300;
}
.hero-points{
display:grid;
grid-template-columns:repeat(2,minmax(0,1fr));
gap:10px;
margin:32px 0 38px;
}
.hero-point{
display:flex;
align-items:center;
gap:11px;
padding:14px 16px;
border-radius:14px;
background:#fff;
border:1px solid rgba(10,43,74,.09);
box-shadow:var(--shadow-sm);
font-size:.9rem;
font-weight:600;
color:var(--text);
transition:border-color .2s, transform .2s;
}
.hero-point:hover{
border-color:rgba(10,43,74,.18);
transform:translateY(-2px);
}
.hero-point-icon{
width:32px;height:32px;
border-radius:9px;
background:var(--accent-soft);
display:flex;align-items:center;justify-content:center;
flex:0 0 auto;
}
.hero-point-icon svg{
width:15px;height:15px;
stroke:var(--accent);
}
.hero-actions{
display:flex;
flex-wrap:wrap;
gap:12px;
align-items:center;
}
.hero-trust{
margin-top:44px;
display:flex;
align-items:center;
gap:16px;
padding-top:32px;
border-top:1px solid var(--line);
}
.trust-avatars{
display:flex;
}
.trust-avatar{
width:36px;height:36px;
border-radius:50%;
border:2px solid #fff;
background:linear-gradient(135deg,var(--accent-soft),var(--line));
display:flex;align-items:center;justify-content:center;
font-size:.7rem;font-weight:700;color:var(--accent);
margin-left:-8px;
}
.trust-avatar:first-child{margin-left:0}
.trust-text{
font-size:.86rem;
color:var(--muted);
line-height:1.4;
}
.trust-text strong{
display:block;
font-size:.9rem;
color:var(--text);
font-weight:600;
}
/* Hero visual */
.hero-visual{
position:relative;
}
.hero-frame{
position:relative;
border-radius:32px;
background:#fff;
border:1px solid rgba(10,43,74,.08);
box-shadow:var(--shadow-lg);
overflow:hidden;
padding:0;
}
.hero-image{
width:100%;
aspect-ratio:4/3.8;
object-fit:cover;
display:block;
}
/* Decorative corner accent */
.hero-frame-deco{
position:absolute;
top:-20px;right:-20px;
width:160px;height:160px;
border-radius:50%;
background:radial-gradient(circle, rgba(10,43,74,.06), transparent 70%);
pointer-events:none;
}
.hero-badge{
position:absolute;
left:-10px;
bottom:20px;
max-width:180px;
padding:12px 12px 10px;
border-radius:14px;
background:rgba(255,255,255,.97);
border:1px solid rgba(10,43,74,.1);
box-shadow:var(--shadow-md);
backdrop-filter:blur(10px);
}
.hero-badge-icon{
width:30px;
height:30px;
border-radius:8px;
background:linear-gradient(135deg,var(--accent),var(--accent-mid));
display:flex;
align-items:center;
justify-content:center;
margin-bottom:8px;
}
.hero-badge-icon svg{
width:16px;
height:16px;
stroke:#fff;
}
.hero-badge strong{
display:block;
margin-bottom:3px;
font-size:.95rem;
font-weight:800;
font-family:var(--font-display);
color:var(--accent);
letter-spacing:-.02em;
}
.hero-badge span{
display:block;
color:var(--muted);
font-size:.75rem;
line-height:1.4;
}
/* Floating stat chip top right */
.hero-stat-chip{
position:absolute;
top:28px;
right:-16px;
padding:12px 18px;
border-radius:14px;
background:#fff;
border:1px solid rgba(10,43,74,.09);
box-shadow:var(--shadow-sm);
display:flex;align-items:center;gap:10px;
}
.hero-stat-chip-dot{
width:8px;height:8px;
border-radius:50%;
background:#22c55e;
box-shadow:0 0 0 3px rgba(34,197,94,.2);
flex:0 0 auto;
animation:pulse 2s infinite;
}
@keyframes pulse{
0%,100%{box-shadow:0 0 0 3px rgba(34,197,94,.2)}
50%{box-shadow:0 0 0 6px rgba(34,197,94,.1)}
}
.hero-stat-chip span{
font-size:.82rem;
font-weight:600;
color:var(--text);
}
/* ─── BUTTONS ────────────────────────────────────────── */
.btn-main,.btn-soft,.btn-whatsapp{
min-height:54px;
border-radius:999px;
padding:0 28px;
display:inline-flex;
align-items:center;
justify-content:center;
font-size:.95rem;
font-weight:600;
font-family:var(--font-body);
transition:transform .22s ease, box-shadow .22s ease, background .22s ease, color .22s ease, border-color .22s ease;
gap:8px;
cursor:pointer;
border:none;
}
.btn-main{
background:var(--accent);
color:#fff;
box-shadow:0 12px 32px rgba(10,43,74,.22);
}
.btn-main:hover{
color:#fff;
background:var(--accent-dark);
transform:translateY(-2px);
box-shadow:0 18px 40px rgba(10,43,74,.28);
}
.btn-soft{
background:#fff;
color:var(--text);
border:1px solid rgba(10,43,74,.13) !important;
}
.btn-soft:hover{
color:var(--accent);
border-color:rgba(10,43,74,.22) !important;
box-shadow:var(--shadow-sm);
transform:translateY(-2px);
}
.btn-whatsapp{
background:#25D366;
color:#fff;
box-shadow:0 10px 28px rgba(37,211,102,.2);
}
.btn-whatsapp:hover{
color:#fff;
background:#1fb85a;
transform:translateY(-2px);
box-shadow:0 16px 36px rgba(37,211,102,.28);
}
/* ─── ABOUT ──────────────────────────────────────────── */
.about-section{
background:var(--soft);
position:relative;
overflow:hidden;
}
.about-section::before{
content:"";
position:absolute;
top:-120px;right:-120px;
width:480px;height:480px;
border-radius:50%;
background:radial-gradient(circle,rgba(10,43,74,.05),transparent 70%);
pointer-events:none;
}
.about-grid{
display:grid;
grid-template-columns:minmax(0,1.25fr) minmax(0,.75fr);
gap:24px;
align-items:stretch;
}
.about-card{
padding:44px;
background:#fff;
border:1px solid rgba(10,43,74,.07);
border-radius:var(--radius-xl);
box-shadow:var(--shadow-sm);
height:100%;
}
.about-copy p{
color:var(--muted);
line-height:1.94;
font-size:.99rem;
font-weight:300;
margin-bottom:18px;
}
.about-copy p:last-child{margin-bottom:0}
.about-copy p strong{
color:var(--text);
font-weight:600;
}
.about-side{
display:grid;
gap:20px;
}
.mini-stat{
padding:32px;
background:#fff;
border:1px solid rgba(10,43,74,.07);
border-radius:var(--radius-xl);
box-shadow:var(--shadow-sm);
position:relative;
overflow:hidden;
transition:transform .22s, box-shadow .22s;
}
.mini-stat:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.mini-stat::before{
content:"";
position:absolute;
top:0;left:0;right:0;
height:3px;
background:linear-gradient(90deg,var(--accent),var(--accent-mid));
border-radius:3px 3px 0 0;
}
.mini-stat-value{
display:block;
font-family:var(--font-display);
font-size:3.2rem;
line-height:1;
font-weight:800;
letter-spacing:-.06em;
color:var(--accent);
margin-bottom:10px;
}
.mini-stat-label{
display:block;
color:var(--muted);
font-size:.95rem;
line-height:1.7;
font-weight:400;
}
/* ─── SERVICES ───────────────────────────────────────── */
.services-section{background:#fff}
.services-grid{
display:grid;
grid-template-columns:repeat(3,minmax(0,1fr));
gap:20px;
}
.service-card{
padding:36px 32px;
border-radius:var(--radius-xl);
background:#fff;
border:1px solid rgba(10,43,74,.08);
box-shadow:var(--shadow-sm);
height:100%;
transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
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-mid));
transform:scaleX(0);
transform-origin:left;
transition:transform .3s ease;
}
.service-card:hover{
transform:translateY(-6px);
box-shadow:var(--shadow-md);
border-color:rgba(10,43,74,.14);
}
.service-card:hover::after{
transform:scaleX(1);
}
.icon-chip{
width:60px;height:60px;
border-radius:18px;
display:inline-flex;
align-items:center;justify-content:center;
background:linear-gradient(135deg,var(--accent) 0%,var(--accent-mid) 100%);
color:#fff;
box-shadow:0 10px 28px rgba(10,43,74,.2);
margin-bottom:24px;
flex:0 0 auto;
}
.icon-chip svg{
width:26px;height:26px;
stroke:currentColor;
}
.service-card h3,.why-card h3{
font-family:var(--font-display);
margin:0 0 10px;
font-size:1.02rem;
line-height:1.2;
letter-spacing:-.03em;
font-weight:700;
color:var(--text);
}
.service-card p,.why-card p{
margin:0;
color:var(--muted);
font-size:.93rem;
line-height:1.86;
font-weight:300;
}
/* ─── WHY SECTION ─────────────────────────────────────── */
.why-section{
background:var(--accent);
position:relative;
overflow:hidden;
}
.why-section::before{
content:"";
position:absolute;
inset:0;
background-image:
linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
background-size:48px 48px;
pointer-events:none;
}
.why-section .section-head .eyebrow{
background:rgba(255,255,255,.12);
border-color:rgba(255,255,255,.2);
color:rgba(255,255,255,.9);
}
.why-section .section-head .eyebrow::before{
background:#fff;
}
.why-section .section-title{
color:#fff;
}
.why-section .section-subtitle{
color:rgba(255,255,255,.7);
}
.why-grid{
display:grid;
grid-template-columns:repeat(3,minmax(0,1fr));
gap:20px;
}
.why-card{
padding:34px 30px;
border-radius:var(--radius-xl);
background:rgba(255,255,255,.07);
border:1px solid rgba(255,255,255,.12);
height:100%;
transition:transform .25s ease, background .25s ease, border-color .25s ease;
backdrop-filter:blur(4px);
}
.why-card:hover{
transform:translateY(-5px);
background:rgba(255,255,255,.11);
border-color:rgba(255,255,255,.2);
}
.why-card .icon-chip{
background:rgba(255,255,255,.14);
border:1px solid rgba(255,255,255,.18);
box-shadow:none;
}
.why-card h3{color:#fff;}
.why-card p{color:rgba(255,255,255,.72);}
/* ─── GALLERY (leave untouched per instructions) ────── */
.gallery-panel{max-width:1020px;margin:0 auto}
.gal-gallery .carousel{max-width:1000px;margin-inline:auto;position:relative}
.gal-frame{
height:clamp(280px,58vh,500px);
background:#fff;
border:1px solid rgba(10,43,74,.08);
border-radius:28px;
overflow:hidden;
display:flex;align-items:center;justify-content:center;
padding:12px;
box-shadow:var(--shadow-lg);
}
.gal-img{
width:auto !important;max-width:100%;
height:auto !important;max-height:100%;
object-fit:contain !important;object-position:center;
display:block;cursor:zoom-in;border-radius:18px;
}
.gal-gallery .carousel-control-prev,
.gal-gallery .carousel-control-next{
z-index:20;width:56px;height:56px;
top:50%;transform:translateY(-50%);
opacity:1;background:rgba(10,43,74,.88);
border-radius:50%;margin:0 10px;
box-shadow:0 12px 28px rgba(10,43,74,.18);
}
.gal-gallery .carousel-control-prev{left:0}
.gal-gallery .carousel-control-next{right:0}
.gal-gallery .gal-ctrl-icon{width:2.4rem;height:2.4rem;background-size:56% 56%}
.gal-gallery .carousel-indicators{z-index:10;bottom:-52px;margin-bottom:0}
.gal-gallery .carousel-indicators button{
width:11px;height:11px;border:none;border-radius:50%;
background:rgba(10,43,74,.28);margin:0 5px;
}
.gal-gallery .carousel-indicators button.active{background:var(--accent)}
.gal-gallery{padding-bottom:58px}
#galLightbox .modal-content{background:#000;border:none}
#galLightboxImg{max-height:86vh;width:100%;height:auto;object-fit:contain;background:#000}
.gal-lightbox-nav{
position:absolute;top:50%;transform:translateY(-50%);
border:0;width:48px;height:48px;border-radius:999px;
background:rgba(255,255,255,.18);color:#fff;
font-size:34px;line-height:48px;text-align:center;
z-index:5;cursor:pointer;
}
.gal-lightbox-nav:hover{background:rgba(255,255,255,.28)}
.gal-lightbox-nav.gal-prev{left:12px}
.gal-lightbox-nav.gal-next{right:12px}
/* ─── FAQ ─────────────────────────────────────────────── */
.faq-section{background:var(--soft)}
.faq-shell{
max-width:860px;
margin:0 auto;
display:grid;
gap:12px;
}
.faq-item{
background:#fff;
border:1px solid rgba(10,43,74,.08);
border-radius:20px;
box-shadow:var(--shadow-sm);
overflow:hidden;
transition:border-color .2s, box-shadow .2s;
}
.faq-item.open{
border-color:rgba(10,43,74,.16);
box-shadow:var(--shadow-md);
}
.faq-question{
width:100%;
display:flex;align-items:center;
justify-content:space-between;
gap:16px;
padding:24px 28px;
background:none;
border:none;
cursor:pointer;
text-align:left;
}
.faq-question span{
font-family:var(--font-display);
font-size:.95rem;
font-weight:700;
color:var(--text);
letter-spacing:-.02em;
line-height:1.3;
flex:1;
}
.faq-item.open .faq-question span{color:var(--accent)}
.faq-toggle{
width:32px;height:32px;
border-radius:10px;
background:var(--soft);
border:1px solid var(--line);
display:flex;align-items:center;justify-content:center;
flex:0 0 auto;
transition:background .2s, transform .3s;
}
.faq-item.open .faq-toggle{
background:var(--accent);
border-color:var(--accent);
transform:rotate(45deg);
}
.faq-toggle svg{
width:14px;height:14px;
stroke:var(--muted);
transition:stroke .2s;
}
.faq-item.open .faq-toggle svg{stroke:#fff}
.faq-answer{
max-height:0;overflow:hidden;
transition:max-height .4s cubic-bezier(.4,0,.2,1), padding .3s;
padding:0 28px;
}
.faq-answer-inner{
padding-bottom:24px;
color:var(--muted);
font-size:.96rem;
line-height:1.88;
font-weight:300;
border-top:1px solid var(--line);
padding-top:18px;
}
.faq-item.open .faq-answer{
max-height:300px;
}
/* ─── CONTACT ────────────────────────────────────────── */
.contact-grid{
display:grid;
grid-template-columns:minmax(0,.88fr) minmax(0,1.12fr);
gap:24px;
align-items:stretch;
}
.contact-card,.form-card{
padding:44px;
background:#fff;
border:1px solid rgba(10,43,74,.08);
border-radius:var(--radius-xl);
box-shadow:var(--shadow-sm);
height:100%;
}
.contact-card h3,.form-card h3{
font-family:var(--font-display);
font-size:1.32rem;
font-weight:800;
color:var(--text);
letter-spacing:-.04em;
margin-bottom:10px;
}
.contact-card>p,.form-card>p{
color:var(--muted);
font-size:.96rem;
line-height:1.8;
font-weight:300;
}
.contact-list{
display:grid;gap:12px;margin-top:28px;
}
.contact-item{
display:flex;align-items:flex-start;gap:14px;
padding:18px 20px;
border-radius:16px;
background:var(--soft);
border:1px solid rgba(10,43,74,.06);
transition:border-color .2s, transform .2s;
}
.contact-item:hover{
border-color:rgba(10,43,74,.14);
transform:translateX(3px);
}
.contact-item-icon{
width:40px;height:40px;
border-radius:12px;
background:var(--accent-soft);
display:flex;align-items:center;justify-content:center;
flex:0 0 auto;
}
.contact-item-icon svg{
width:18px;height:18px;
color:var(--accent);
}
.contact-item strong{
display:block;
font-size:.9rem;
font-weight:600;
color:var(--text);
margin-bottom:3px;
}
.contact-item span,.contact-item a{
color:var(--muted);
font-size:.94rem;
line-height:1.6;
word-break:break-word;
font-weight:300;
}
.contact-item a:hover{color:var(--accent)}
.contact-actions{
display:flex;flex-wrap:wrap;gap:10px;margin-top:28px;
}
/* Form */
.form-text-intro{
margin-bottom:28px;
}
.form-label{
font-size:.85rem;
font-weight:600;
color:var(--text);
margin-bottom:8px;
display:block;
letter-spacing:.01em;
}
.form-control,.form-select{
min-height:52px;
border-radius:14px;
border:1.5px solid rgba(10,43,74,.12);
padding:13px 16px;
box-shadow:none !important;
font-size:.95rem;
color:var(--text);
font-family:var(--font-body);
background:#fff;
transition:border-color .2s;
}
textarea.form-control{min-height:140px;resize:vertical;}
.form-control:focus,.form-select:focus{
border-color:var(--accent);
outline:none;
}
.form-control::placeholder{color:rgba(93,102,112,.55)}
/* ─── FOOTER ─────────────────────────────────────────── */
.footer{
padding:80px 0 0;
background:var(--accent);
color:#fff;
}
.footer-inner{
padding-bottom:48px;
}
.footer-grid{
display:grid;
grid-template-columns:1.3fr .85fr 1fr;
gap:40px;
padding-bottom:40px;
border-bottom:1px solid rgba(255,255,255,.12);
}
.footer-brand{
display:flex;align-items:center;gap:12px;margin-bottom:18px;
}
.footer-brand-text{
font-family:var(--font-display);
font-size:.9rem;
font-weight:700;
color:#fff;
line-height:1.3;
letter-spacing:-.02em;
}
.footer p{
color:rgba(255,255,255,.65);
font-size:.93rem;
line-height:1.84;
font-weight:300;
}
.footer-title{
font-family:var(--font-display);
font-size:.76rem;
font-weight:700;
letter-spacing:.12em;
text-transform:uppercase;
color:rgba(255,255,255,.5);
margin:0 0 20px;
}
.footer-list{
list-style:none;padding:0;margin:0;
display:grid;gap:10px;
}
.footer-list a,.footer-list li{
color:rgba(255,255,255,.78);
font-size:.93rem;
line-height:1.6;
font-weight:300;
transition:color .2s;
}
.footer-list a:hover{color:#fff}
.footer-bottom{
padding:22px 0;
display:flex;align-items:center;justify-content:space-between;
gap:16px;flex-wrap:wrap;
}
.footer-bottom p{
margin:0;
color:rgba(255,255,255,.5);
font-size:.85rem;
}
.footer-bottom a{
color:rgba(255,255,255,.65);
transition:color .2s;
}
.footer-bottom a:hover{color:#fff}
/* ─── SCROLL ANIMATIONS ──────────────────────────────── */
.reveal{
opacity:0;
transform:translateY(28px);
transition:opacity .65s ease, transform .65s ease;
}
.reveal.visible{
opacity:1;transform:translateY(0);
}
/* ─── RESPONSIVE ─────────────────────────────────────── */
@media (max-width:1199.98px){
.hero-grid,.about-grid,.contact-grid,.footer-grid{grid-template-columns:1fr}
.hero-badge{left:16px}
.hero-stat-chip{right:16px}
.services-grid,.why-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:991.98px){
.section{padding:88px 0}
.hero{padding:148px 0 80px}
.navbar .container-site{
width:100%;
max-width:100%;
padding-inline:16px;
gap:12px;
flex-wrap:wrap;
}
.navbar-brand{
min-width:0;
flex:1 1 auto;
max-width:calc(100% - 64px);
overflow:hidden;
}
.brand-text,
.brand-text small{
white-space:nowrap;
overflow:hidden;
text-overflow:ellipsis;
}
.navbar-toggler{
margin-left:auto;
flex:0 0 auto;
}
.navbar-collapse{
width:100%;
flex-basis:100%;
margin-top:12px;
padding:16px;
border-radius:20px;
background:#fff;
border:1px solid rgba(10,43,74,.08);
box-shadow:var(--shadow-sm);
overflow:hidden;
}
.navbar-nav-wrap{
display:block;
width:100%;
}
.navbar-nav{
width:100%;
}
.nav-item{
width:100%;
}
.nav-link{
display:flex;
width:100%;
justify-content:flex-start;
}
.nav-cta{
margin-left:0;
justify-content:center;
}
.hero-points{grid-template-columns:1fr}
.hero-trust{display:none}
}
@media (max-width:767.98px){
.section{padding:72px 0}
.hero{padding:128px 0 68px}
.hero-grid{
display:flex;
flex-direction:column;
gap:22px;
}
.hero-copy{
display:contents;
}
.hero-copy .eyebrow{order:1}
.hero-copy .hero-title{order:2}
.hero-copy .hero-text{order:3}
.hero-visual{
order:4;
width:100%;
}
.hero-points{order:5}
.hero-actions{
order:6;
flex-direction:column;
align-items:stretch;
}
.btn-main,.btn-soft,.btn-whatsapp{width:100%;justify-content:center}
.hero-badge{position:static;max-width:none;margin-top:16px}
.hero-stat-chip{display:none}
.about-card,.service-card,.why-card,.contact-card,.form-card,.mini-stat{padding:28px}
.services-grid,.why-grid{grid-template-columns:1fr;gap:16px}
.gal-frame{height:clamp(230px,44vh,360px)}
}
@media (max-width:575.98px){
.container-site{padding-inline:16px}
.navbar-brand{max-width:calc(100% - 64px)}
.brand-logo{height:34px}
.brand-text{font-size:.82rem}
.brand-text small{font-size:.62rem}
.hero-title{font-size:clamp(2.15rem,9vw,2.95rem)}
.section-title{font-size:clamp(1.62rem,7.2vw,2.35rem)}
.hero-image{aspect-ratio:1/1}
.accordion-button{padding:22px 18px 18px;font-size:.97rem}
.faq-question{padding:20px 20px}
.faq-answer{padding:0 20px}
.gal-gallery .carousel-control-prev,
.gal-gallery .carousel-control-next{width:48px;height:48px}
}
/* ===== INLINE <style> BLOCK #2 ===== */
.wa-float{
position:fixed;
right:18px;
bottom:18px;
z-index:2147483647;
display:flex;
flex-direction:column;
align-items:flex-end;
font-family:inherit;
}
.social-float-stack{
display:grid;
gap:10px;
margin-bottom:12px;
transition:opacity .22s ease, transform .22s ease;
}
.social-float-btn{
width:52px;
height:52px;
border-radius:50%;
color:#fff;
display:grid;
place-items:center;
box-shadow:0 10px 28px rgba(10,43,74,.22);
transition:transform .22s ease, box-shadow .22s ease, filter .22s ease;
}
.social-float-btn:hover{
color:#fff;
transform:translateY(-3px) scale(1.05);
box-shadow:0 14px 36px rgba(10,43,74,.3);
filter:saturate(1.08);
}
.social-float-btn svg{
width:24px;
height:24px;
}
.social-facebook{
background:linear-gradient(135deg,#1877f2,#0b5fce);
}
.social-instagram{
background:linear-gradient(135deg,#833ab4,#fd1d1d 52%,#fcb045);
}
.social-tiktok{
background:linear-gradient(135deg,#111,#000);
}
.wa-float.wa-open .social-float-stack{
opacity:0;
pointer-events:none;
transform:translateY(8px);
}
.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, box-shadow .25s;
}
.wa-btn:hover{
transform:translateY(-3px) scale(1.05);
box-shadow:0 14px 36px rgba(37,211,102,.55);
}
.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;
}
.wa-head{
display:flex;
align-items:center;
gap:12px;
padding:14px;
background:linear-gradient(135deg,#25D366,#128C7E);
color:#fff;
}
.wa-avatar{
width:40px;
height:40px;
background:#fff;
border-radius:10px;
display:grid;
place-items:center;
overflow:hidden;
}
.wa-avatar img{
width:26px;
height:26px;
object-fit:contain;
}
.wa-title{
font-weight:800;
}
.wa-status{
font-size:.85rem;
opacity:.9;
}
.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);
}
.wa-body{
padding:14px;
max-height:40vh;
overflow:auto;
background:#f8f9fa;
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;
}
.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-send{
background:#25D366;
color:#fff;
border:none;
border-radius:12px;
padding:0 16px;
cursor:pointer;
}
.wa-send:hover{
background:#1fb85a;
}
@media (max-width:480px){
.wa-float{
right:12px;
bottom:12px;
}
.social-float-stack{
gap:9px;
margin-bottom:10px;
}
.social-float-btn{
width:48px;
height:48px;
}
.social-float-btn svg{
width:22px;
height:22px;
}
.wa-card{
width:calc(100vw - 24px);
}
}