Preview de mixed.css
/* MIXED CSS PACK */
/* Template: reformassierras.com.ar/index.html */
/* Template mtime: 2026-02-27 12:20:22 */
/* external link (no embedded): https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&display=swap */
/* external link (no embedded): https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css */
/* external link (no embedded): https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0-beta3/css/all.min.css */
/* ===== INLINE <style> BLOCK #1 ===== */
:root {
--accent: #ffff00;
--accent-dark: #e6e600;
--ink: #0b0b0b;
--muted: #5b5b5b;
--line: rgba(0, 0, 0, 0.08);
--soft: rgba(0, 0, 0, 0.02);
--radius: 24px;
--radius-sm: 16px;
--radius-xs: 12px;
--shadow: 0 20px 40px -12px rgba(0, 0, 0, 0.1);
--shadow-hover: 0 30px 50px -12px rgba(0, 0, 0, 0.18);
--shadow-card: 0 4px 20px rgba(0, 0, 0, 0.03), 0 2px 6px rgba(0, 0, 0, 0.05);
--transition: all 0.25s cubic-bezier(0.2, 0, 0, 1);
/* Actualizamos la fuente principal a 'Outfit' que es más redondeada y moderna */
--font-sans: 'Outfit', 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}
html { scroll-behavior: smooth; }
html, body { width: 100%; overflow-x: hidden !important; }
body {
background: #ffffff;
color: var(--ink);
font-family: var(--font-sans);
font-weight: 400;
line-height: 1.5;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}
/* IMPORTANTE: NO tocar SVG global porque te lo vuelve gigante */
img, video, canvas { max-width: 100%; height: auto; }
svg { max-width: none; height: auto; }
.section { padding: clamp(80px, 10vw, 120px) 0; }
.anchor-offset { scroll-margin-top: 90px; }
.eyebrow {
display: inline-block;
font-weight: 700;
font-size: 0.75rem;
letter-spacing: 0.1em;
text-transform: uppercase;
padding: 0.4rem 1rem;
background: var(--accent);
border: 1px solid rgba(0, 0, 0, 0.05);
border-radius: 100px;
color: var(--ink);
margin-bottom: 1.5rem;
backdrop-filter: blur(4px);
}
.section-title {
font-weight: 900;
font-size: clamp(2.2rem, 6vw, 3.2rem);
letter-spacing: -0.02em;
line-height: 1.1;
margin-bottom: 1.2rem;
color: var(--ink);
}
.section-subtitle {
color: var(--muted);
font-size: 1.2rem;
max-width: 70ch;
margin-left: auto;
margin-right: auto;
font-weight: 400;
}
.btn-accent, .btn-ghost {
font-weight: 700;
padding: 0.9rem 2rem;
border-radius: 60px;
transition: var(--transition);
text-decoration: none;
display: inline-flex;
align-items: center;
justify-content: center;
gap: 0.5rem;
border: 1px solid transparent;
font-size: 1rem;
line-height: 1;
}
.btn-accent {
background: var(--accent);
color: var(--ink);
box-shadow: 0 8px 18px -8px rgba(255, 255, 0, 0.4);
border-color: rgba(0, 0, 0, 0.1);
}
.btn-accent:hover {
background: var(--accent-dark);
transform: translateY(-3px);
box-shadow: 0 15px 25px -10px rgba(255, 255, 0, 0.5);
}
.btn-ghost {
background: transparent;
color: var(--ink);
border: 1px solid var(--line);
}
.btn-ghost:hover {
background: rgba(0, 0, 0, 0.02);
border-color: rgba(0, 0, 0, 0.2);
transform: translateY(-2px);
}
.navbar {
background: rgba(255, 255, 255, 0.85);
backdrop-filter: blur(12px);
-webkit-backdrop-filter: blur(12px);
border-bottom: 1px solid var(--line);
padding: 0.75rem 0;
}
.brand {
display: flex;
align-items: center;
gap: 0.7rem;
text-decoration: none;
color: var(--ink);
}
.brand img {
height: 48px;
width: auto;
border-radius: var(--radius-xs);
}
.brand span {
font-weight: 800;
font-size: 1.3rem;
letter-spacing: -0.02em;
}
.nav-link {
color: var(--ink);
font-weight: 500;
position: relative;
padding: 0.5rem 1rem !important;
font-size: 1rem;
transition: color 0.2s ease;
}
.nav-link::after {
content: '';
position: absolute;
bottom: 0;
left: 50%;
transform: translateX(-50%) scaleX(0);
width: 70%;
height: 2px;
background: var(--accent);
transition: transform 0.2s ease-in-out;
border-radius: 2px;
}
.nav-link:hover::after {
transform: translateX(-50%) scaleX(1);
}
.hero { padding-top: 130px; }
.hero-card {
border: 1px solid var(--line);
border-radius: var(--radius);
background: #fff;
box-shadow: var(--shadow-card), var(--shadow);
overflow: hidden;
transition: var(--transition);
}
.hero h1 {
font-weight: 900;
font-size: clamp(2.8rem, 7vw, 4.5rem);
letter-spacing: -0.03em;
line-height: 1.1;
margin-bottom: 1.5rem;
}
.hero .lead {
color: var(--muted);
font-size: 1.25rem;
font-weight: 400;
}
.kpi {
display: flex;
flex-wrap: wrap;
gap: 0.8rem;
margin: 2rem 0;
}
.pill {
display: inline-flex;
align-items: center;
gap: 0.6rem;
padding: 0.5rem 1.2rem;
background: var(--soft);
border: 1px solid var(--line);
border-radius: 100px;
font-weight: 500;
font-size: 0.9rem;
color: var(--ink);
}
.dot {
width: 8px;
height: 8px;
border-radius: 50%;
background: var(--accent);
border: 1px solid rgba(0, 0, 0, 0.1);
}
.hero-media {
background: linear-gradient(135deg, rgba(255, 255, 0, 0.05) 0%, transparent 100%);
border-left: 1px solid var(--line);
display: flex;
align-items: center;
justify-content: center;
padding: 2rem;
min-height: 450px;
}
.hero-media img {
max-width: 100%;
max-height: 380px;
width: auto;
height: auto;
border-radius: 20px;
box-shadow: var(--shadow-hover);
display:block;
transition: var(--transition);
}
.hero-media img:hover {
transform: scale(1.02);
}
@media (max-width: 991.98px) {
.hero-media {
border-left: 0;
border-top: 1px solid var(--line);
min-height: auto;
}
}
.soft-card {
border: 1px solid var(--line);
border-radius: var(--radius-sm);
background: #fff;
padding: 2rem 1.5rem;
height: 100%;
transition: var(--transition);
box-shadow: var(--shadow-card);
display: flex;
flex-direction: column;
gap: 1rem;
}
.soft-card:hover {
transform: translateY(-6px);
box-shadow: var(--shadow-hover);
border-color: transparent;
}
.soft-card .icon {
width: 64px;
height: 64px;
border-radius: 20px;
background: rgba(255, 255, 0, 0.15);
display: flex;
align-items: center;
justify-content: center;
color: var(--ink);
transition: var(--transition);
margin-bottom: 0.5rem;
flex: 0 0 auto;
}
.soft-card:hover .icon {
background: var(--accent);
transform: scale(1.05) rotate(2deg);
}
.soft-card .icon svg {
width: 32px;
height: 32px;
stroke-width: 1.8;
}
.soft-card h3 {
font-weight: 800;
font-size: 1.5rem;
margin-bottom: 0.5rem;
letter-spacing: -0.01em;
}
.soft-card p {
color: var(--muted);
margin: 0;
font-size: 1rem;
line-height: 1.6;
font-weight: 400;
}
.service-grid-item {
background: #fff;
border: 1px solid var(--line);
border-radius: var(--radius-sm);
padding: 2.2rem 1.8rem;
height: 100%;
transition: var(--transition);
display: flex;
flex-direction: column;
align-items: flex-start;
gap: 1rem;
position: relative;
overflow: hidden;
box-shadow: var(--shadow-card);
}
.service-grid-item::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
height: 4px;
background: var(--accent);
transform: translateX(-100%);
transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.service-grid-item:hover {
transform: translateY(-6px);
box-shadow: var(--shadow-hover);
}
.service-grid-item:hover::before {
transform: translateX(0);
}
.service-icon {
width: 72px;
height: 72px;
border-radius: 24px;
background: rgba(255, 255, 0, 0.15);
display: flex;
align-items: center;
justify-content: center;
color: var(--ink);
transition: var(--transition);
flex: 0 0 auto;
}
.service-grid-item:hover .service-icon {
background: var(--accent);
transform: scale(1.05) rotate(3deg);
}
.service-icon svg {
width: 36px;
height: 36px;
stroke-width: 1.8;
}
.service-grid-item h3 {
font-weight: 800;
font-size: 1.6rem;
margin: 0.5rem 0 0.25rem;
letter-spacing: -0.01em;
}
.service-grid-item .service-desc {
color: var(--muted);
font-size: 0.95rem;
line-height: 1.6;
margin-bottom: 1rem;
}
.service-link {
color: var(--ink);
font-weight: 700;
text-decoration: none;
display: inline-flex;
align-items: center;
gap: 0.5rem;
margin-top: auto;
transition: var(--transition);
border-bottom: 2px solid transparent;
padding-bottom: 2px;
}
.service-link:hover {
gap: 1rem;
color: var(--ink);
border-bottom-color: var(--accent);
}
.service-link svg {
width: 20px;
height: 20px;
}
.gal-gallery .carousel {
max-width: 1000px;
margin: 0 auto;
}
.gal-frame {
height: clamp(320px, 55vh, 520px);
background: #f8f8f8;
border-radius: var(--radius);
display: flex;
align-items: center;
justify-content: center;
padding: 1rem;
box-shadow: var(--shadow-card), var(--shadow);
border: 1px solid var(--line);
}
.gal-img {
max-width: 100%;
max-height: 100%;
width: auto !important;
height: auto !important;
object-fit: contain;
border-radius: 16px;
cursor: zoom-in;
display:block;
transition: var(--transition);
}
.gal-img:hover {
opacity: 0.95;
}
.gal-gallery .carousel-control-prev,
.gal-gallery .carousel-control-next {
width: 52px;
height: 52px;
top: 50%;
transform: translateY(-50%);
background: rgba(255, 255, 255, 0.9);
border: 1px solid var(--line);
border-radius: 50%;
opacity: 1;
box-shadow: 0 10px 20px rgba(0,0,0,0.1);
backdrop-filter: blur(4px);
}
.gal-gallery .carousel-control-prev-icon,
.gal-gallery .carousel-control-next-icon {
filter: invert(1) grayscale(100);
}
.gal-gallery .carousel-indicators {
bottom: -50px;
}
.gal-gallery .carousel-indicators button {
width: 10px;
height: 10px;
border-radius: 50%;
background: rgba(0,0,0,0.3);
border: none;
}
.gal-gallery .carousel-indicators button.active {
background: var(--accent);
}
#galLightbox .modal-content {
background: rgba(0, 0, 0, 0.95);
}
#galLightboxImg {
max-height: 90vh;
object-fit: contain;
}
.gal-lightbox-nav {
position: absolute;
top: 50%;
transform: translateY(-50%);
width: 60px;
height: 60px;
border: none;
border-radius: 50%;
background: rgba(255, 255, 255, 0.2);
color: white;
font-size: 40px;
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
transition: var(--transition);
z-index: 1060;
backdrop-filter: blur(8px);
border: 1px solid rgba(255,255,255,0.1);
}
.gal-lightbox-nav:hover {
background: rgba(255, 255, 255, 0.4);
}
.gal-prev { left: 20px; }
.gal-next { right: 20px; }
.contact-wrap {
border: 1px solid var(--line);
border-radius: var(--radius);
background: #fff;
box-shadow: var(--shadow-card), var(--shadow);
overflow: hidden;
}
.contact-side {
background: linear-gradient(135deg, rgba(255, 255, 0, 0.08) 0%, transparent 100%);
border-right: 1px solid var(--line);
padding: 2.5rem 2rem;
height: 100%;
}
.kv {
display: flex;
gap: 1rem;
align-items: flex-start;
padding: 1.2rem;
background: #fff;
border: 1px solid var(--line);
border-radius: var(--radius-sm);
margin-bottom: 1rem;
transition: var(--transition);
}
.kv:hover {
box-shadow: var(--shadow);
border-color: transparent;
}
.kv strong {
display: block;
font-weight: 800;
margin-bottom: 0.2rem;
}
.kv span, .kv a {
color: var(--muted);
text-decoration: none;
font-weight: 500;
}
.form-control, .form-select {
border: 1px solid var(--line);
border-radius: 18px;
padding: 0.9rem 1.3rem;
font-size: 1rem;
transition: var(--transition);
font-family: var(--font-sans);
}
.form-control:focus, .form-select:focus {
border-color: var(--accent);
box-shadow: 0 0 0 4px rgba(255, 255, 0, 0.2);
outline: none;
}
.form-label {
font-weight: 600;
font-size: 0.9rem;
margin-bottom: 0.3rem;
color: var(--ink);
}
/* ===== FOOTER (SÓLIDO ACCENT + NEGRO) ===== */
footer, .footer, #footer {
background: var(--accent) !important;
color: var(--ink) !important;
border-top: 1px solid rgba(0,0,0,0.18) !important;
padding: 4rem 0 1.5rem;
margin-top: 2rem;
}
footer *, .footer *, #footer * { color: var(--ink) !important; }
.footer-logo {
display: flex;
align-items: center;
gap: 0.8rem;
margin-bottom: 1rem;
}
.footer-logo img { height: 50px; width: auto; border-radius: var(--radius-xs); }
.footer-logo span {
font-weight: 900;
font-size: 1.4rem;
letter-spacing: -0.02em;
}
.footer-tagline {
color: var(--ink) !important;
opacity: 0.85;
font-size: 0.95rem;
line-height: 1.6;
margin-bottom: 1.5rem;
max-width: 280px;
}
.footer-title {
font-weight: 800;
font-size: 1.1rem;
margin-bottom: 1.2rem;
letter-spacing: -0.01em;
position: relative;
padding-bottom: 0.5rem;
}
.footer-title::after {
content: '';
position: absolute;
bottom: 0;
left: 0;
width: 40px;
height: 3px;
background: var(--ink) !important;
opacity: 0.9;
border-radius: 2px;
}
.footer-links { list-style: none; padding: 0; margin: 0; }
.footer-links li { margin-bottom: 0.8rem; }
.footer-links a {
color: var(--ink) !important;
text-decoration: none;
font-weight: 500;
transition: var(--transition);
display: inline-flex;
align-items: center;
gap: 0.5rem;
}
.footer-links a:hover {
opacity: 0.75;
transform: translateX(5px);
text-decoration: underline;
}
.footer-links a i { color: var(--ink) !important; opacity: 0.9; }
.contact-info { list-style: none; padding: 0; margin: 0; }
.contact-info li {
display: flex;
align-items: center;
gap: 1rem;
margin-bottom: 1rem;
}
.contact-info li i {
width: 36px;
height: 36px;
background: rgba(0, 0, 0, 0.08) !important;
border: 1px solid rgba(0,0,0,0.12);
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
color: var(--ink) !important;
transition: var(--transition);
flex: 0 0 auto;
}
.contact-info li:hover i {
background: rgba(0, 0, 0, 0.12) !important;
transform: scale(1.05);
}
.contact-info li a, .contact-info li span {
color: var(--ink) !important;
text-decoration: none;
font-weight: 500;
transition: var(--transition);
}
.contact-info li a:hover {
opacity: 0.75;
text-decoration: underline;
}
.social-icons {
display: flex;
gap: 0.8rem;
margin-top: 1rem;
flex-wrap: wrap;
}
.social-icons a {
width: 42px;
height: 42px;
background: rgba(0, 0, 0, 0.08) !important;
border: 1px solid rgba(0,0,0,0.12);
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
color: var(--ink) !important;
font-size: 1.2rem;
transition: var(--transition);
text-decoration: none;
}
.social-icons a:hover {
background: rgba(0, 0, 0, 0.12) !important;
transform: translateY(-5px);
}
.footer-bottom {
border-top: 1px solid rgba(0,0,0,0.18) !important;
margin-top: 2.5rem;
padding-top: 1.5rem;
display: flex;
flex-wrap: wrap;
align-items: center;
justify-content: space-between;
gap: 1rem;
}
.footer-bottom p {
margin: 0;
color: var(--ink) !important;
opacity: 0.85;
font-size: 0.9rem;
}
.footer-bottom .developer {
display: flex;
align-items: center;
gap: 0.3rem;
}
.footer-bottom .developer i { color: var(--ink) !important; opacity: 0.9; }
.footer-bottom .developer a {
color: var(--ink) !important;
text-decoration: none;
font-weight: 700;
transition: var(--transition);
}
.footer-bottom .developer a:hover {
opacity: 0.75;
text-decoration: underline;
}
/* =========================
FIX: SVG sprite suelto (si aparece)
========================= */
body > svg{
position: absolute !important;
width: 0 !important;
height: 0 !important;
overflow: hidden !important;
opacity: 0 !important;
pointer-events: none !important;
left: -9999px !important;
top: -9999px !important;
}
/* =========================
FIX: WhatsApp flotante (clave para que NO crezca el SVG)
========================= */
/* ===== INLINE <style> BLOCK #2 ===== */
:root{
--wa:#25D366;
--wa-dark:#1fb85a;
--light-bg:#ffffff;
--light-bg-soft:#f6f8f7;
--light-border:#dde4df;
--dark-text:#1c1f1d;
--muted-text:#6c756f;
}
.wa-float{
position:fixed; right:18px; bottom:18px;
z-index:9999; font-family:inherit;
}
.wa-btn{
background:var(--wa);
color:#fff;
border:0;
width:60px; height:60px; border-radius:50%;
display:grid; place-items:center;
box-shadow:0 10px 30px rgba(0,0,0,.22);
cursor:pointer; transition:transform .3s, box-shadow .3s, filter .3s;
position:relative; overflow:hidden;
}
.wa-btn:hover{
transform:translateY(-3px) scale(1.05);
box-shadow:0 14px 36px rgba(0,0,0,.28);
filter:brightness(.98);
}
.wa-card{
position:absolute; right:0; bottom:74px;
width:min(360px,92vw);
background:var(--light-bg);
color:var(--dark-text);
border-radius:18px;
overflow:hidden;
box-shadow:0 18px 60px rgba(0,0,0,.25);
border:1px solid var(--light-border);
transform:translateY(10px);
opacity:0;
transition:transform .3s, opacity .3s;
z-index:10000;
}
.wa-card[aria-modal="true"]{
transform:translateY(0);
opacity:1;
}
.wa-head{
display:flex; align-items:center; gap:12px;
padding:14px 16px;
background:linear-gradient(135deg, #ffffff, #ecf6f0);
border-bottom:1px solid var(--light-border);
}
.wa-avatar{
width:40px; height:40px; border-radius:10px;
background:#e9f7ef;
display:grid; place-items:center;
border:1px solid #cfeeda;
overflow:hidden;
}
.wa-title{
font-weight:800;
font-size:1.02rem;
}
.wa-status{
font-size:.85rem;
color:var(--muted-text);
display:flex; align-items:center; gap:6px;
}
.wa-status::before{
content:""; width:8px; height:8px; border-radius:50%;
background:var(--wa);
}
.wa-close{
margin-left:auto;
background:transparent;
color:var(--muted-text);
border:0;
font-size:24px;
cursor:pointer;
opacity:.75;
width:32px; height:32px;
border-radius:50%;
display:flex; align-items:center; justify-content:center;
transition:.2s;
}
.wa-close:hover{
opacity:1;
background:rgba(0,0,0,.04);
}
.wa-body{
padding:12px 14px;
max-height:40vh;
overflow:auto;
background:var(--light-bg-soft);
display:flex;
flex-direction:column;
gap:8px;
}
.wa-bubble{
max-width:88%;
padding:9px 11px;
border-radius:14px;
line-height:1.35;
box-shadow:0 3px 10px rgba(0,0,0,.06);
animation:fadeIn .25s ease;
font-size:0.9rem;
}
@keyframes fadeIn{
from{opacity:0; transform:translateY(5px)}
to{opacity:1; transform:none}
}
.wa-bot{
background:#ffffff;
border:1px solid var(--light-border);
align-self:flex-start;
border-bottom-left-radius:4px;
}
.wa-user{
background:var(--wa);
color:#fff;
align-self:flex-end;
border-bottom-right-radius:4px;
}
.wa-compose{
display:grid;
grid-template-columns:1fr auto;
gap:8px;
padding:10px 12px;
background:#ffffff;
border-top:1px solid var(--light-border);
}
.wa-compose textarea{
resize:none;
border-radius:12px;
padding:10px 12px;
border:1px solid var(--light-border);
background:#f9fbfa;
color:var(--dark-text);
outline:none;
min-height:44px;
font-family:inherit;
font-size:0.9rem;
transition:.2s;
}
.wa-compose textarea:focus{
border-color:var(--wa);
box-shadow:0 0 0 2px rgba(37,211,102,.15);
background:#ffffff;
}
.wa-send{
background:var(--wa);
color:#ffffff;
border:0;
border-radius:12px;
padding:0 16px;
font-weight:700;
cursor:pointer;
display:flex;
align-items:center;
justify-content:center;
transition:.2s;
}
.wa-send:hover{
background:var(--wa-dark);
transform:scale(1.04);
}
.wa-body::-webkit-scrollbar{ width:6px; }
.wa-body::-webkit-scrollbar-track{ background:rgba(0,0,0,.03); border-radius:3px; }
.wa-body::-webkit-scrollbar-thumb{ background:rgba(0,0,0,.12); border-radius:3px; }
.wa-body::-webkit-scrollbar-thumb:hover{ background:rgba(0,0,0,.18); }
@media (max-width:480px){
.wa-float{ right:12px; bottom:12px; }
.wa-card{ width:calc(100vw - 24px); right:0; }
}