roñacastropasiondebox.com.ar
https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.csshttps://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0/css/all.min.csshttps://fonts.googleapis.com/css2?family=Oswald:wght@400;500;600;700&family=Inter:wght@400;500;600;700;800&display=swaphttps://cdn.jsdelivr.net/npm/[email protected]/font/bootstrap-icons.css/* --------------------------------
RESET Y VARIABLES (PALETA ORIGINAL RESPETADA)
----------------------------------- */
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
:root {
--rojo-box: #8B0000;
--negro-box: #0A0A0A;
--gris-lona: #2A2A2A;
--blanco: #FFFFFF;
--dorado: #B8860B;
--shadow-fuerte: 0 10px 25px -5px rgba(0,0,0,0.5);
--border-ring: 3px solid var(--rojo-box);
/* Mejoras visuales */
--transition-smooth: all 0.3s ease;
--glass-bg: rgba(10, 10, 10, 0.7);
--glass-border: 1px solid rgba(255, 255, 255, 0.1);
/* Tema */
--text-main: var(--blanco);
--text-muted: rgba(255,255,255,0.80);
--text-soft: rgba(255,255,255,0.72);
--panel-bg: rgba(0,0,0,0.30);
--panel-bg-2: rgba(0,0,0,0.40);
--panel-border: rgba(255,255,255,0.10);
--input-border: rgba(255,255,255,0.25);
--input-border-2: rgba(255,255,255,0.20);
--iframe-scale: 1;
}
/* --------------------------------
LIGHT MODE (toggle con body.light-mode)
----------------------------------- */
body.light-mode {
/* Invertimos superficies manteniendo acentos */
--negro-box: #F6F6F7;
--blanco: #0A0A0A;
--gris-lona: #E7E7E9;
--glass-bg: rgba(255, 255, 255, 0.78);
--glass-border: 1px solid rgba(10, 10, 10, 0.08);
--shadow-fuerte: 0 10px 25px -5px rgba(0,0,0,0.18);
--text-muted: rgba(10,10,10,0.78);
--text-soft: rgba(10,10,10,0.68);
--panel-bg: rgba(255,255,255,0.62);
--panel-bg-2: rgba(255,255,255,0.70);
--panel-border: rgba(10,10,10,0.10);
--input-border: rgba(10,10,10,0.22);
--input-border-2: rgba(10,10,10,0.18);
}
/* Overlay global: en claro aclaramos (no oscurecemos) */
body.light-mode::before {
background: rgba(255,255,255,0.72);
}
/* Text utilities de bootstrap que quedaron "white" en modo oscuro */
body.light-mode .text-white,
body.light-mode .text-white-50,
body.light-mode .text-white-75,
body.light-mode .text-white-25 {
color: rgba(10,10,10,0.92) !important;
}
body.light-mode .text-white-50 { color: rgba(10,10,10,0.62) !important; }
body.light-mode .text-muted { color: rgba(10,10,10,0.62) !important; }
/* Inputs transparentes */
body.light-mode .form-control.bg-transparent,
body.light-mode .form-select.bg-transparent,
body.light-mode .input-group-text.bg-transparent {
color: rgba(10,10,10,0.92) !important;
}
body.light-mode .form-control::placeholder { color: rgba(10,10,10,0.52) !important; }
/* Accordion "dark" pasa a claro */
body.light-mode .accordion-dark .accordion-button {
background: rgba(255,255,255,0.75);
color: rgba(10,10,10,0.92);
border-color: rgba(10,10,10,0.08);
}
body.light-mode .accordion-dark .accordion-button:not(.collapsed){
background: rgba(255,255,255,0.92);
color: rgba(10,10,10,0.92);
}
body.light-mode .accordion-dark .accordion-body {
background: rgba(255,255,255,0.68);
color: rgba(10,10,10,0.72);
}
/* Footer */
body.light-mode .footer-rona {
background: rgba(255,255,255,0.80);
}
body.light-mode .footer-links a { color: rgba(10,10,10,.72); }
body.light-mode .footer-links a:hover { color: var(--rojo-box); }
body.light-mode .social-btn { color: rgba(10,10,10,.72); border-color: rgba(10,10,10,.12); }
body.light-mode .social-btn:hover { color: var(--negro-box); }
/* CTA strip más claro */
body.light-mode .cta-strip {
background: linear-gradient(90deg, rgba(139,0,0,.18) 0%, rgba(255,255,255,.75) 55%, rgba(184,134,11,.12) 100%);
}
/* ===== Ajustes extras para modo claro (contrastes) ===== */
body.light-mode .header-box p { background: rgba(255,255,255,0.70) !important; color: rgba(10,10,10,0.78) !important; border-color: rgba(139,0,0,0.18) !important; }
body.light-mode .section-head .section-lead { color: rgba(10,10,10,0.70) !important; }
body.light-mode .feature-card p,
body.light-mode .benefit-card p,
body.light-mode .review-text,
body.light-mode .review-meta,
body.light-mode .note-text.text-white-50,
body.light-mode .quick-sub.text-white-50,
body.light-mode .meta-row.text-white-50,
body.light-mode .text-white-50 { color: rgba(10,10,10,0.62) !important; }
body.light-mode .feature-card,
body.light-mode .glass-panel,
body.light-mode .review-card,
body.light-mode .note-card,
body.light-mode .contact-card,
body.light-mode .contact-side {
background: rgba(255,255,255,0.78) !important;
border-color: rgba(10,10,10,0.10) !important;
}
body.light-mode .benefit-card {
background: rgba(255,255,255,0.72) !important;
border-color: rgba(10,10,10,0.10) !important;
}
body.light-mode .topbar,
body.light-mode .topbar .topbar-item,
body.light-mode .topbar .topbar-link {
color: rgba(10,10,10,0.78) !important;
}
body.light-mode .topbar { background: rgba(255,255,255,0.65) !important; border-bottom-color: rgba(10,10,10,0.08) !important; }
body.light-mode .topbar .topbar-link { border-color: rgba(10,10,10,0.12) !important; }
body.light-mode .navbar { box-shadow: 0 4px 20px rgba(0,0,0,0.10) !important; }
body.light-mode .nav-link { color: rgba(10,10,10,0.88) !important; }
body.light-mode .nav-link:hover { color: #fff !important; }
body.light-mode .quick-link {
color: rgba(10,10,10,0.88) !important;
background: rgba(255,255,255,0.60) !important;
border-color: rgba(10,10,10,0.10) !important;
}
body.light-mode .quick-link:hover { border-color: rgba(139,0,0,0.35) !important; background: rgba(255,255,255,0.78) !important; }
body.light-mode .btn-outline-light {
color: var(--rojo-box) !important;
border-color: var(--rojo-box) !important;
}
body.light-mode .btn-outline-light:hover { background: var(--rojo-box) !important; color: #fff !important; }
/* Footer sólido en modo claro */
body.light-mode .footer-rona {
background: var(--rojo-box) !important;
color: #fff !important;
border-top: 0 !important;
}
body.light-mode .footer-heading { color: rgba(255,255,255,0.92) !important; }
body.light-mode .footer-title,
body.light-mode .footer-subtitle { color: rgba(255,255,255,0.92) !important; }
body.light-mode .footer-links a { color: rgba(255,255,255,.82) !important; }
body.light-mode .footer-links a:hover { color: var(--dorado) !important; }
body.light-mode .footer-hr { border-color: rgba(255,255,255,.18) !important; }
body.light-mode .social-btn { color: rgba(255,255,255,.90) !important; border-color: rgba(255,255,255,.22) !important; }
body.light-mode .social-btn:hover { background: var(--dorado) !important; color: var(--negro-box) !important; border-color: rgba(255,255,255,.35) !important; }
body.light-mode .footer-box { background: rgba(255,255,255,0.12) !important; border-color: rgba(255,255,255,0.22) !important; }
body.light-mode .footer-legal { color: rgba(255,255,255,0.82) !important; text-decoration: none; }
body.light-mode .footer-legal:hover { color: var(--dorado) !important; }
/* Newsletter strip */
body.light-mode #newsletter { background: rgba(255,255,255,0.70) !important; }
body.light-mode #newsletter .text-white-50 { color: rgba(10,10,10,0.62) !important; }
body {
font-family: 'Inter', sans-serif;
background-color: var(--negro-box);
color: var(--blanco);
min-height: 100vh;
overflow-x: hidden;
}
/* FONDO: imagen centrada en pantalla (exactamente como el original) */
.hero-bg {
position: fixed;
inset: 0;
background: url('img/rona2.jpg') no-repeat center center / auto 90%;
pointer-events: none;
z-index: -2;
}
/* overlay oscuro general (exactamente como el original) */
body::before {
content: '';
position: fixed;
inset: 0;
background: rgba(8,8,8,0.82);
z-index: -1;
}
/* TIPOGRAFÍA */
h1, h2, h3, h4, h5, h6 {
font-family: 'Oswald', sans-serif;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 1px;
}
/* ...cortado... */
.ticker-section {
overflow: hidden;
padding: 60px 0;
}
.ticker-wrapper {
width: 100%;
overflow: hidden;
}
.ticker-track {
display: flex;
gap: 40px;
width: max-content;
animation: tickerMove 18s linear infinite;
}
.ticker-track img {
height: 320px; /* MÁS GRANDES */
width: auto;
object-fit: contain; /* Respeta proporción real */
border-radius: 18px;
box-shadow: 0 20px 40px rgba(0,0,0,0.45);
transition: transform .4s ease;
}
.ticker-track img:hover {
transform: scale(1.08);
}
@keyframes tickerMove {
0% { transform: translateX(0); }
100% { transform: translateX(-50%); }
}
/* Mobile */
@media (max-width: 768px) {
.ticker-track img {
height: 200px;
}
}
.ticker-section {
overflow: hidden;
padding: 60px 0;
}
.ticker-wrapper {
width: 100%;
overflow: hidden;
}
.ticker-track {
display: flex;
gap: 40px;
width: max-content;
animation: tickerMove 18s linear infinite;
}
.ticker-track img {
height: 320px; /* MÁS GRANDES */
width: auto;
object-fit: contain; /* Respeta proporción real */
border-radius: 18px;
box-shadow: 0 20px 40px rgba(0,0,0,0.45);
transition: transform .4s ease;
}
.ticker-track img:hover {
transform: scale(1.08);
}
@keyframes tickerMove {
0% { transform: translateX(0); }
100% { transform: translateX(-50%); }
}
/* Mobile */
@media (max-width: 768px) {
.ticker-track img {
height: 200px;
}
}
:root{
--wa:#25D366;
--wa-dark:#1fb85a;
--light-bg:#ffffff;
--light-bg-soft:#f6f8f7;
--light-border:#dde4df;
--dark-text:#1c1f1d;
--muted-text:#6c756f;
}
/* TikTok button (arriba) */
.tt-float{
position:fixed; right:18px; bottom:166px;
z-index:9997;
width:54px; height:54px; border-radius:50%;
display:grid; place-items:center; color:#fff; text-decoration:none;
background: linear-gradient(180deg, #111111 0%, #000000 100%);
box-shadow:0 10px 30px rgba(0,0,0,.25);
transition:transform .25s, box-shadow .25s, opacity .25s;
}
.tt-float:hover{
transform:translateY(-2px) scale(1.04);
box-shadow:0 14px 36px rgba(0,0,0,.35);
}
/* IG button (medio) */
.ig-float{
position:fixed; right:18px; bottom:92px;
z-index:9998;
width:54px; height:54px; border-radius:50%;
display:grid; place-items:center; color:#fff; text-decoration:none;
background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
box-shadow:0 10px 30px rgba(0,0,0,.25);
transition:transform .25s, box-shadow .25s, opacity .25s;
}
.ig-float:hover{
transform:translateY(-2px) scale(1.04);
box-shadow:0 14px 36px rgba(0,0,0,.35);
}
/* WhatsApp flotante */
.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;
z-index:9999;
}
.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;
color:var(--dark-text);
}
.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){
.tt-float{ right:12px; bottom:160px; width:52px; height:52px; }
.ig-float{ right:12px; bottom:86px; width:52px; height:52px; }
.wa-float{ right:12px; bottom:12px; }
.wa-card{ width:calc(100vw - 24px); right:0; }
}
fundacionreiniciar.com
https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.csshttps://cdn.jsdelivr.net/npm/[email protected]/font/bootstrap-icons.min.csshttps://fonts.googleapis.com/css2?family=Inter:opsz,[email protected],400;14..32,500;14..32,600;14..32,700;14..32,800;14..32,900&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap/* ============================================= */
/* ROOT VARIABLES Y RESET (PALETA RESPETADA) */
/* ============================================= */
:root {
--bg: #ffffff;
--text: #0b0b0b;
--muted: #5b5b5b;
--accent: #3F8D2E;
--accent-dark: #2F6D22;
--accent-soft: #E8F4E5;
--accent-ultra-light: #F3F9F1;
--border: #e8e8e8;
--radius-sm: 12px;
--radius-md: 18px;
--radius-lg: 24px;
--radius-xl: 32px;
--shadow-sm: 0 4px 12px rgba(0,0,0,0.03);
--shadow-md: 0 10px 26px rgba(0,0,0,0.07);
--shadow-lg: 0 20px 40px -12px rgba(0,0,0,0.15);
--shadow-hover: 0 30px 50px -15px rgba(63,141,46,0.25);
--transition: all 0.25s cubic-bezier(0.2, 0, 0, 1);
}
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
html {
scroll-behavior: smooth;
}
body {
background: var(--bg);
color: var(--text);
font-family: 'Inter', system-ui, -apple-system, sans-serif;
line-height: 1.5;
overflow-x: hidden;
}
h1, h2, h3, h4, h5, h6 {
font-family: 'Plus Jakarta Sans', 'Inter', sans-serif;
font-weight: 800;
letter-spacing: -0.02em;
line-height: 1.2;
}
/* ============================================= */
/* NAVBAR PRO - MÁS ELEGANTE Y MODERNA */
/* ============================================= */
.navbar {
background: rgba(255, 255, 255, 0.85);
backdrop-filter: blur(12px);
-webkit-backdrop-filter: blur(12px);
border-bottom: 1px solid rgba(0,0,0,0.05);
box-shadow: 0 4px 30px rgba(0, 0, 0, 0.02);
padding: 8px 0;
transition: var(--transition);
}
.navbar-scrolled {
box-shadow: var(--shadow-md);
background: rgba(255,255,255,0.95);
}
.navbar-brand {
font-weight: 900;
font-size: 1.5rem;
letter-spacing: -0.02em;
color: var(--text) !important;
}
.brand-mark {
width: 42px;
height: 42px;
border-radius: var(--radius-sm);
background: var(--accent-soft);
display: inline-flex;
align-items: center;
justify-content: center;
border: 1px solid rgba(63,141,46,.25);
transition: var(--transition);
}
.navbar-brand:hover .brand-mark {
transform: scale(1.05);
border-color: var(--accent);
}
.brand-mark i {
color: var(--accent);
font-size: 22px;
}
.nav-link {
color: var(--text) !important;
font-weight: 600;
font-size: 0.95rem;
padding: 0.5rem 1rem !important;
border-radius: 100px;
transition: var(--transition);
opacity: 0.8;
}
.nav-link:hover {
opacity: 1;
background: var(--accent-ultra-light);
}
.btn-accent {
background: var(--accent);
border: 1px solid var(--accent);
color: #fff;
border-radius: 100px;
padding: 0.7rem 1.4rem;
font-weight: 700;
font-size: 0.95rem;
transition: var(--transition);
box-shadow: 0 4px 10px rgba(63,141,46,0.3);
}
.btn-accent:hover {
background: var(--accent-dark);
border-color: var(--accent-dark);
transform: translateY(-2px);
box-shadow: 0 8px 20px rgba(63,141,46,0.4);
}
.btn-outline-accent {
border: 1px solid rgba(63,141,46,0.4);
color: var(--accent-dark);
border-radius: 100px;
padding: 0.7rem 1.4rem;
font-weight: 600;
background: transparent;
transition: var(--transition);
}
.btn-outline-accent:hover {
background: var(--accent-soft);
border-color: var(--accent);
transform: translateY(-2px);
}
/* ============================================= */
/* COMPONENTES GLOBALES PREMIUM */
/* ============================================= */
.section {
padding: 100px 0;
position: relative;
}
.section-sm {
padding: 70px 0;
}
.eyebrow {
display: inline-flex;
align-items: center;
gap: 0.5rem;
padding: 0.4rem 1rem;
border-radius: 100px;
background: var(--accent-soft);
color: var(--accent-dark);
font-weight: 800;
font-size: 0.8rem;
letter-spacing: 0.03em;
text-transform: uppercase;
border: 1px solid rgba(63,141,46,.25);
margin-bottom: 1.5rem;
box-shadow: var(--shadow-sm);
}
.section-title {
font-size: clamp(2.2rem, 5vw, 3.2rem);
font-weight: 900;
letter-spacing: -0.03em;
line-height: 1.1;
margin-bottom: 1rem;
}
.section-subtitle {
color: var(--muted);
font-size: 1.2rem;
max-width: 700px;
margin-left: auto;
margin-right: auto;
font-weight: 400;
}
/* ============================================= */
/* CARDS CON MICROINTERACCIONES Y GLOW */
/* ============================================= */
.info-card {
background: #fff;
border: 1px solid var(--border);
border-radius: var(--radius-lg);
padding: 2rem;
height: 100%;
transition: var(--transition);
box-shadow: var(--shadow-sm);
}
.info-card:hover {
transform: translateY(-6px);
box-shadow: var(--shadow-hover);
border-color: rgba(63,141,46,0.3);
}
.icon {
width: 56px;
height: 56px;
border-radius: 16px;
background: var(--accent-soft);
display: flex;
align-items: center;
justify-content: center;
border: 1px solid rgba(63,141,46,.25);
color: var(--accent-dark);
font-size: 26px;
flex-shrink: 0;
transition: var(--transition);
}
.info-card:hover .icon {
background: var(--accent);
color: white;
border-color: var(--accent);
transform: scale(1.05) rotate(-3deg);
}
/* ============================================= */
/* HERO SECTION - ABSOLUTAMENTE MODERNO */
/* ============================================= */
.hero {
padding: 120px 0 80px;
background: linear-gradient(180deg, rgba(63,141,46,0.03) 0%, transparent 30%);
overflow: hidden;
position: relative;
}
.hero::before {
content: '';
position: absolute;
width: 100%;
height: 100%;
top: 0;
left: 0;
background: radial-gradient(600px at 70% 20%, rgba(63,141,46,0.15), transparent 70%);
pointer-events: none;
}
.hero h1 {
font-size: clamp(2.5rem, 6vw, 4rem);
font-weight: 900;
line-height: 1.05;
letter-spacing: -0.03em;
margin-bottom: 1.5rem;
}
.hero p {
font-size: 1.2rem;
color: var(--muted);
margin-bottom: 2rem;
}
.hero-card {
border-radius: var(--radius-xl);
overflow: hidden;
box-shadow: var(--shadow-lg);
background: #fff;
border: 1px solid rgba(0,0,0,0.05);
transition: var(--transition);
}
.hero-card:hover {
box-shadow: var(--shadow-hover);
}
.hero-art {
background: linear-gradient(135deg, var(--accent-soft) 0%, #fff 100%);
min-height: 450px;
display: flex;
align-items: center;
justify-content: center;
position: relative;
padding: 2rem;
}
.art-inner {
width: 100%;
max-width: 500px;
aspect-ratio: 1/1;
background: #fff;
border-radius: 24px;
box-shadow: var(--shadow-lg);
padding: 1.5rem;
display: flex;
align-items: center;
justify-content: center;
}
.art-inner img {
width: 100%;
height: 100%;
object-fit: conta
/* ...cortado... */
/* ================== Scope: rei-* ================== */
/* Usa tu paleta general: --accent, --accent-soft, etc (si no existen, igual anda) */
.rei-brand{
padding:84px 0;
background: linear-gradient(180deg, #ffffff 0%, rgba(63,141,46,.06) 100%);
}
.rei-ticker{
position:relative;
max-width:980px;
margin:0 auto;
}
.rei-tk-viewport{
border-radius:18px;
background:#fff;
box-shadow:0 14px 34px rgba(0,0,0,.12);
border:1px solid rgba(0,0,0,.06);
overflow:hidden;
padding:10px;
cursor:grab;
user-select:none;
}
.rei-tk-viewport:active{cursor:grabbing;}
.rei-tk-track{
display:flex;
gap:14px;
align-items:center;
will-change:transform;
transform:translate3d(0,0,0);
}
.rei-tk-item{
flex:0 0 auto;
width:500px;
height:500px;
border:0;
padding:0;
background:#fff;
border-radius:16px;
overflow:hidden;
display:flex;
align-items:center;
justify-content:center;
box-shadow:0 10px 22px rgba(0,0,0,.10);
cursor:zoom-in;
}
.rei-tk-item img{
width:100%;
height:100%;
object-fit:contain;
background:#fff;
display:block;
}
/* botones prev/next */
.rei-tk-btn{
position:absolute;
top:50%;
transform:translateY(-50%);
width:52px;
height:52px;
border-radius:50%;
border:0;
background:rgba(0,0,0,.55);
color:#fff;
font-size:34px;
line-height:52px;
text-align:center;
z-index:5;
cursor:pointer;
transition:transform .2s, background .2s, box-shadow .2s;
box-shadow:0 10px 24px rgba(0,0,0,.20);
}
.rei-tk-btn:hover{
background:rgba(0,0,0,.65);
transform:translateY(-50%) scale(1.05);
}
.rei-tk-prev{left:10px;}
.rei-tk-next{right:10px;}
/* badges */
.rei-badges{display:flex; flex-wrap:wrap; gap:10px; justify-content:center;}
.rei-badge{
background:#fff;
border:1px solid rgba(0,0,0,.08);
border-radius:999px;
padding:10px 14px;
font-weight:800;
color:#2a2a2a;
box-shadow:0 8px 18px rgba(0,0,0,.06);
}
/* Modal */
.rei-modal{background:#000;border:0;}
.rei-light-img{max-height:86vh; width:100%; height:auto; object-fit:contain; background:#000;}
.rei-light-nav{
position:absolute; top:50%; transform:translateY(-50%);
border:0; width:46px; height:46px; border-radius:999px;
background:rgba(255,255,255,.18); color:#fff;
font-size:32px; line-height:46px; text-align:center;
z-index:5; cursor:pointer;
}
.rei-light-nav:hover{background:rgba(255,255,255,.28);}
.rei-light-nav.rei-prev{left:10px;}
.rei-light-nav.rei-next{right:10px;}
/* Responsive */
@media (max-width: 991.98px){
.rei-tk-item{ width:420px; height:420px; }
.rei-tk-prev{left:8px;}
.rei-tk-next{right:8px;}
}
@media (max-width: 575.98px){
.rei-brand{padding:72px 0;}
.rei-tk-item{ width:84vw; height:84vw; }
.rei-tk-btn{ width:48px; height:48px; font-size:32px; line-height:48px; }
}
.gal-gallery .carousel{max-width:980px;margin-inline:auto;position:relative}
.gal-frame{
height: clamp(220px, 48vh, 440px);
background:#fff;border-radius:16px;overflow:hidden;
box-shadow:0 12px 28px rgba(0,0,0,.12);
display:flex;align-items:center;justify-content:center;padding:8px
}
.gal-img{
width:auto !important;max-width:100%;
height:auto !important;max-height:100%;
object-fit:contain !important;object-position:center;display:block;cursor:zoom-in
}
/* Controles circulares con más contraste */
.gal-gallery .carousel-control-prev,
.gal-gallery .carousel-control-next{
z-index:20;width:50px;height:50px;top:50%;transform:translateY(-50%);
opacity:1;background:rgba(0,0,0,.55);border-radius:50%;margin:0 12px
}
.gal-gallery .carousel-control-prev{left:0}
.gal-gallery .carousel-control-next{right:0}
.gal-gallery .gal-ctrl-icon{width:2.6rem;height:2.6rem;background-size:60% 60%}
/* Indicadores: se sitúan fuera; agregamos espacio inferior para que no se corten */
.gal-gallery .carousel-indicators{z-index:10;bottom:-50px}
.gal-gallery .carousel-indicators button{
width:10px;height:10px;border-radius:50%;
background:rgba(0,0,0,.5);border:none
}
.gal-gallery .carousel-indicators button.active{background:#000}
.gal-gallery{padding-bottom:56px} /* espacio para indicadores */
/* Modal */
#galLightbox .modal-content{background:#000}
#galLightboxImg{max-height:86vh;width:100%;height:auto;object-fit:contain;background:#000}
.gal-lightbox-nav{
position:absolute;top:50%;transform:translateY(-50%);
border:0;width:44px;height:44px;border-radius:999px;
background:rgba(255,255,255,.18);color:#fff;font-size:30px;line-height:44px;text-align:center;z-index:5;cursor:pointer
}
.gal-lightbox-nav:hover{background:rgba(255,255,255,.28)}
.gal-lightbox-nav.gal-prev{left:10px}
.gal-lightbox-nav.gal-next{right:10px}
/* Pequeños ajustes móviles */
@media (max-width: 575.98px){
.gal-frame{height: clamp(200px, 40vh, 360px)}
}
:root{
/* WhatsApp oficial */
--wa:#25D366;
--wa-dark:#1fb85a;
--wa-darker:#189a4a;
/* UI clara */
--light-bg:#ffffff;
--light-bg-soft:#f6f8f7;
--light-border:#dde4df;
--dark-text:#1c1f1d;
--muted-text:#6c756f;
}
/* FACEBOOK button (arriba) */
.fb-float{
position:fixed; right:18px; bottom:92px; /* arriba del WhatsApp */
z-index:9998;
width:54px; height:54px; border-radius:50%;
display:grid; place-items:center; color:#fff; text-decoration:none;
background: linear-gradient(180deg, #1877F2 0%, #0f63d6 100%);
box-shadow:0 10px 30px rgba(0,0,0,.25);
transition:transform .25s, box-shadow .25s, opacity .25s;
}
.fb-float:hover{
transform:translateY(-2px) scale(1.04);
box-shadow:0 14px 36px rgba(0,0,0,.35);
}
/* WhatsApp flotante */
.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;
z-index:9999;
}
.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;
color:var(--dark-text);
}
.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){
.fb-float{ right:12px; bottom:86px; width:52px; height:52px; }
.wa-float{ right:12px; bottom:12px; }
.wa-card{ width:calc(100vw - 24px); right:0; }
}
washexpresslaundry.com.ar
https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swaphttps://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.csshttps://cdn.jsdelivr.net/npm/[email protected]/font/bootstrap-icons.min.csshttps://unpkg.com/[email protected]/dist/aos.css:root{
/* Colores tomados del estilo de las imágenes (azul + verde + naranja) */
--c-teal: #18b6cf;
--c-green: #7bd64f;
--c-orange:#f57c20;
--accent-1: var(--c-teal);
--accent-2: var(--c-green);
--accent-3: var(--c-orange);
--accent-gradient: linear-gradient(135deg, var(--accent-1), var(--accent-2));
--text:#0b1220;
--text-light:#4a5568;
--muted:#64748b;
--bg:#ffffff;
--soft:#f8fafc;
--border:#e2e8f0;
--shadow-sm: 0 4px 6px -1px rgb(0 0 0 / 0.05), 0 2px 4px -2px rgb(0 0 0 / 0.05);
--shadow-md: 0 20px 25px -5px rgb(0 0 0 / 0.05), 0 8px 10px -6px rgb(0 0 0 / 0.05);
--shadow-lg: 0 25px 50px -12px rgb(0 0 0 / 0.15);
--shadow-xl: 0 35px 60px -15px rgba(0,0,0,0.2);
--radius-sm: 12px;
--radius-md: 20px;
--radius-lg: 32px;
--radius-xl: 40px;
--transition: all .28s cubic-bezier(.4,0,.2,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
font-family:"Inter",system-ui,-apple-system,sans-serif;
color:var(--text);
background:var(--bg);
overflow-x:hidden;
line-height:1.5;
letter-spacing:-0.01em;
}
h1,h2,h3,h4,h5,h6{font-weight:800;letter-spacing:-0.02em;line-height:1.15}
.container{max-width:1280px;padding:0 24px}
.section{padding:clamp(78px,10vw,130px) 0;position:relative}
.bg-soft{background:linear-gradient(180deg,var(--bg) 0%,var(--soft) 100%)}
.eyebrow{
display:inline-flex;align-items:center;gap:.5rem;
font-weight:800;font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;
color:var(--accent-1);
background:rgba(24,182,207,.10);
border:1px solid rgba(24,182,207,.18);
padding:.55rem 1rem;border-radius:999px;
backdrop-filter:blur(6px);
}
.section-title{
font-size:clamp(2rem,5vw,3.2rem);
font-weight:900;
margin-bottom:1rem;
color:var(--accent-3);
letter-spacing:-0.03em;
}
.section-subtitle{
font-size:1.18rem;color:var(--text-light);
max-width:780px;margin:0 auto 2.5rem;font-weight:400;
}
/* NAV */
.navbar{
background:rgba(255,255,255,.82);
backdrop-filter:blur(12px);
border-bottom:1px solid rgba(226,232,240,.55);
padding:1rem 0;
transition:var(--transition);
}
.navbar.scrolled{
padding:.55rem 0;background:rgba(255,255,255,.95);
box-shadow:var(--shadow-md);
}
.navbar-brand{
font-weight:900;font-size:1.35rem;letter-spacing:-0.02em;
text-decoration:none;
color:var(--text);
display:flex;align-items:center;gap:.75rem;
}
.brand-dot{
width:12px;height:12px;border-radius:50%;
background:var(--accent-gradient);
box-shadow:0 0 22px rgba(24,182,207,.45);
animation:pulse 2s infinite;
flex:0 0 auto;
}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.12);opacity:.85}}
.nav-link{
font-weight:700;color:var(--text)!important;
padding:.5rem 1rem!important;
position:relative;transition:var(--transition);
}
.nav-link::after{
content:"";position:absolute;left:50%;bottom:0;transform:translateX(-50%) scaleX(0);
width:22px;height:2px;border-radius:2px;background:var(--accent-gradient);
transition:var(--transition);
}
.nav-link:hover::after{transform:translateX(-50%) scaleX(1)}
.navbar-toggler{border:1px solid rgba(11,18,32,.15)}
.navbar-toggler:focus{box-shadow:0 0 0 .25rem rgba(24,182,207,.18)}
/* Buttons */
.btn{
padding:.78rem 1.55rem;
font-weight:800;border-radius:999px;border:none;
transition:var(--transition);position:relative;overflow:hidden;
}
.btn::before{
content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;
background:rgba(255,255,255,.18);transform:translate(-50%,-50%);
transition:width .6s,height .6s;
}
.btn:hover::before{width:320px;height:320px}
.btn-primary-accent{
background:var(--accent-gradient);color:#fff;
box-shadow:0 12px 22px -8px rgba(24,182,207,.45);
}
.btn-primary-accent:hover{transform:translateY(-2px);box-shadow:0 22px 34px -10px rgba(24,182,207,.55)}
.btn-outline-soft{
background:transparent;border:2px solid var(--border);color:var(--text);
}
.btn-outline-soft:hover{border-color:var(--accent-1);background:rgba(24,182,207,.06);transform:translateY(-2px)}
/* Hero */
.hero{
padding-top:120px;
min-height:92vh;display:flex;align-items:center;
background:
radial-gradient(circle at 0% 0%, rgba(24,182,207,.10) 0%, transparent 55%),
radial-gradient(circle at 100% 100%, rgba(123,214,79,.10) 0%, transparent 55%);
}
.hero-card{
background:rgba(255,255,255,.74);
backdrop-filter:blur(18px);
border:1px solid rgba(255,255,255,.55);
border-radius:var(--radius-xl);
box-shadow:var(--shadow-xl);
overflow:hidden;
}
.hero-left{padding:3rem}
.hero h1{
font-size:clamp(2.45rem,5vw,3.8rem);
font-weight:900;line-height:1.05;margin:1.1rem 0 1rem;
color:var(--accent-3);
}
.hero .lead{color:var(--text-light);font-size:1.18rem}
.hero-bullets{display:grid;gap:1rem;margin:1.75rem 0 2rem;padding-left:0;list-style:none}
.hero-bullets li{display:flex;align-items:center;gap:1rem;font-weight:600}
.hero-bullets i{
width:30px;height:30px;border-radius:50%;
display:flex;align-items:center;justify-content:center;
background:var(--accent-gradient);color:#fff;font-size:.95rem;
box-shadow:0 8px 14px rgba(24,182,207,.28);
flex:0 0 auto;
}
.pill{
display:inline-flex;align-items:center;gap:.55rem;
padding:.55rem 1rem;background:#fff;border:1px solid var(--border);
border-radius:999px;font-weight:700;font-size:.92rem;color:var(--text);
box-shadow:var(--shadow-sm);transition:var(--transition)
}
.pill:hover{border-color:var(--accent-1);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.pill i{color:var(--accent-2)}
.hero-actions{display:flex;gap:.9rem;flex-wrap:wrap}
.hero-media{
border-radius:var(--radius-lg);overflow:hidden;
box-shadow:var(--shadow-lg);transition:var(--transition);
background:#fff;border:1px solid var(--border);
}
.hero-media:hover{transform:scale(1.02);box-shadow:var(--shadow-xl)}
.hero-media img{width:100%;height:100%;object-fit:cover}
/* Cards */
.card-clean{
background:#fff;border:1px solid var(--border);
border-radius:var(--radius-lg);
padding:2rem;height:100%;
transition:var(--transition);
position:relative;overflow:hidden;
}
.card-clean::before{
content:"";position:absolute;left:0;right:0;top:0;height:4px;
background:var(--accent-gradient);
transform:translateY(-100%);transition:var(--transition);
}
.card-clean:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.card-clean:hover::before{transform:translateY(0)}
.icon-badge{
width:60px;height:60px;border-radius:18px;
display:flex;align-items:center;justify-content:center;
background:linear-gradient(135deg, rgba(24,182,207,.12), rgba(123,214,79,.12));
border:1px solid rgba(24,182,207,.22);
font-size:1.55rem;color:var(--accent-1);
margin-bottom:1.2rem;transition:var(--transition)
}
.card-clean:hover .icon-badge{transform:scale(1.08);background:var(--accent-gradient);color:#fff}
.text-light{color:var(--text-light)!important}
.text-accent{color:var(--accent-1)!important}
.small-note{color:var(--text-light)}
/* Service i
/* ...cortado... */
.gal-gallery .carousel{max-width:980px;margin-inline:auto;position:relative}
.gal-frame{
height: clamp(220px, 48vh, 440px);
background:#fff;border-radius:16px;overflow:hidden;
box-shadow:0 12px 28px rgba(0,0,0,.12);
display:flex;align-items:center;justify-content:center;padding:8px
}
.gal-img{
width:auto !important;max-width:100%;
height:auto !important;max-height:100%;
object-fit:contain !important;object-position:center;display:block;cursor:zoom-in
}
.gal-gallery .carousel-control-prev,
.gal-gallery .carousel-control-next{
z-index:20;width:50px;height:50px;top:50%;transform:translateY(-50%);
opacity:1;background:rgba(0,0,0,.55);border-radius:50%;margin:0 12px
}
.gal-gallery .carousel-control-prev{left:0}
.gal-gallery .carousel-control-next{right:0}
.gal-gallery .gal-ctrl-icon{width:2.6rem;height:2.6rem;background-size:60% 60%}
.gal-gallery .carousel-indicators{z-index:10;bottom:-50px}
.gal-gallery .carousel-indicators button{
width:10px;height:10px;border-radius:50%;
background:rgba(0,0,0,.5);border:none
}
.gal-gallery .carousel-indicators button.active{background:#000}
.gal-gallery{padding-bottom:56px}
#galLightbox .modal-content{background:#000}
#galLightboxImg{max-height:86vh;width:100%;height:auto;object-fit:contain;background:#000}
.gal-lightbox-nav{
position:absolute;top:50%;transform:translateY(-50%);
border:0;width:44px;height:44px;border-radius:999px;
background:rgba(255,255,255,.18);color:#fff;font-size:30px;line-height:44px;text-align:center;z-index:5;cursor:pointer
}
.gal-lightbox-nav:hover{background:rgba(255,255,255,.28)}
.gal-lightbox-nav.gal-prev{left:10px}
.gal-lightbox-nav.gal-next{right:10px}
@media (max-width: 575.98px){ .gal-frame{height: clamp(200px, 40vh, 360px)} }
:root{
/* Paleta Wash Express (naranja + celeste + verde de tus láminas) */
--brand:#1bb6d9; /* celeste */
--brand-dark:#1598b6;
--brand-darker:#0f738a;
--accent:#ff7a1a; /* naranja */
--accent-dark:#e26610;
--green:#7ac943; /* verde */
--light-bg:#ffffff;
--light-bg-soft:#f6fbfc;
--light-border:#d9e8ec;
--dark-text:#14181a;
--muted-text:#5e6a70;
}
/* IG button (arriba del WA) */
.ig-float{
position:fixed; right:18px; bottom:92px;
z-index:9998;
width:54px; height:54px; border-radius:50%;
display:grid; place-items:center; color:#fff; text-decoration:none;
background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
box-shadow:0 10px 30px rgba(0,0,0,.25);
transition:transform .25s, box-shadow .25s;
}
.ig-float:hover{
transform:translateY(-2px) scale(1.04);
box-shadow:0 14px 36px rgba(0,0,0,.35);
}
/* WhatsApp flotante */
.wa-float{
position:fixed; right:18px; bottom:18px;
z-index:9999; font-family:inherit;
}
.wa-btn{
background:#ffffff;
color:var(--brand);
border:2px solid var(--brand);
width:60px; height:60px; border-radius:50%;
display:grid; place-items:center;
box-shadow:0 8px 24px rgba(0,0,0,.18);
cursor:pointer;
transition:transform .3s, box-shadow .3s, background .3s, color .3s, border-color .3s;
position:relative; overflow:hidden;
}
.wa-btn svg{ color:var(--brand); }
.wa-btn::after{
content:"";
position:absolute; inset:0;
background:radial-gradient(circle at 50% 50%, rgba(255,255,255,.7), rgba(255,255,255,0) 70%);
opacity:0; transition:opacity .3s;
}
.wa-btn:hover{
background:var(--brand);
border-color:var(--brand-dark);
color:#fff;
transform:translateY(-3px) scale(1.05);
box-shadow:0 14px 36px rgba(0,0,0,.28);
}
.wa-btn:hover svg{ color:#fff; }
.wa-btn:hover::after{ opacity:0.2; }
.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;
}
.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, #eaf8fb);
border-bottom:1px solid var(--light-border);
}
.wa-avatar{
width:40px; height:40px; border-radius:10px;
background:#e3f6fb;
display:grid; place-items:center;
border:1px solid #cbeaf2;
overflow:hidden;
}
.wa-title{
font-weight:800;
font-size:1.02rem;
color:var(--dark-text);
}
.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(--green);
}
.wa-close{
margin-left:auto;
background:transparent;
color:var(--muted-text);
border:0;
font-size:24px;
cursor:pointer;
opacity:.7;
width:32px; height:32px;
border-radius:50%;
display:flex; align-items:center; justify-content:center;
transition:.2s;
}
.wa-close:hover{
opacity:1;
background:rgba(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(--accent);
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:#f9fdfe;
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(--brand);
box-shadow:0 0 0 2px rgba(27,182,217,.15);
background:#ffffff;
}
.wa-send{
background:var(--brand);
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(--brand-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){
.ig-float{ right:12px; bottom:86px; width:52px; height:52px; }
.wa-float{ right:12px; bottom:12px; }
.wa-card{ width:calc(100vw - 24px); right:0; }
}
fulldent.com.ar
https://fonts.googleapis.com/css2?family=Inter:opsz,[email protected],300;14..32,400;14..32,500;14..32,600;14..32,700;14..32,800;14..32,900&display=swaphttps://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css/* ---------- VARIABLES Y RESET ---------- */
:root{
--bg: #ffffff;
--surface: #f8fafc;
--card: #ffffff;
--stroke: rgba(0, 0, 0, 0.08);
--stroke-hover: rgba(0, 0, 0, 0.12);
--text-primary: #0f172a;
--text-secondary: #334155;
--text-muted: #64748b;
--accent: #fedb46; /* azul más vibrante */
--accent-soft: #3b82f6;
--accent2: #bd7e08; /* verde‑azulado más elegante */
--accent2-soft: #14b8a6;
--shadow-sm: 0 4px 6px -2px rgba(0, 0, 0, 0.05), 0 2px 4px -2px rgba(0, 0, 0, 0.03);
--shadow-md: 0 20px 30px -12px rgba(0, 0, 0, 0.12), 0 8px 12px -6px rgba(0, 0, 0, 0.02);
--shadow-lg: 0 30px 50px -20px rgba(0, 0, 0, 0.2);
--radius: 24px;
--radius-pill: 999px;
--transition: all 0.2s ease;
}
*{ box-sizing: border-box; }
html,body{height:100%; max-width:100%; overflow-x:hidden; scroll-behavior:smooth;}
body{
font-family: 'Inter', system-ui, -apple-system, sans-serif;
background: var(--bg);
color: var(--text-primary);
line-height: 1.5;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}
/* ---------- TIPOGRAFÍA ---------- */
h1,h2,h3,h4,h5,h6{
font-weight: 700;
letter-spacing: -0.02em;
color: var(--text-primary);
}
.section-title{
font-size: clamp(2rem, 5vw, 2.8rem);
font-weight: 800;
letter-spacing: -0.03em;
line-height: 1.1;
}
.section-subtitle{
font-size: 1.1rem;
color: var(--text-secondary);
max-width: 600px;
margin-left: auto;
margin-right: auto;
}
.eyebrow{
display: inline-block;
padding: 0.4rem 1rem;
background: var(--surface);
border: 1px solid var(--stroke);
border-radius: var(--radius-pill);
font-size: 0.85rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.5px;
color: var(--text-secondary);
margin-bottom: 1.2rem;
}
/* ---------- LAYOUT ---------- */
section{ padding: 80px 0; }
.container{ max-width: 1200px; }
/* ---------- NAVBAR (cristal claro) ---------- */
.navbar{
background: rgba(255,255,255,0.75);
backdrop-filter: blur(12px);
-webkit-backdrop-filter: blur(12px);
border-bottom: 1px solid var(--stroke);
box-shadow: var(--shadow-sm);
}
.navbar .navbar-brand{
font-weight: 800;
font-size: 1.6rem;
letter-spacing: -0.02em;
background: linear-gradient(135deg, var(--accent), var(--accent2));
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
}
.navbar-nav .nav-link{
color: var(--text-secondary) !important;
font-weight: 500;
padding: 0.5rem 1rem !important;
transition: var(--transition);
border-radius: var(--radius-pill);
}
.navbar-nav .nav-link:hover{
color: var(--text-primary) !important;
background: var(--surface);
}
.navbar-toggler{ border: none; }
.navbar-toggler-icon{ background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%280, 0, 0, 0.55%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e"); }
/* Botón CTA principal */
.btn-cta{
border-radius: var(--radius-pill);
padding: 0.65rem 1.5rem;
font-weight: 600;
background: linear-gradient(135deg, var(--accent), var(--accent2));
border: none;
color: white;
box-shadow: var(--shadow-sm);
transition: var(--transition);
}
.btn-cta:hover{
transform: scale(1.02);
box-shadow: var(--shadow-md);
filter: brightness(1.1);
}
.btn-outline{
border-radius: var(--radius-pill);
padding: 0.65rem 1.5rem;
font-weight: 600;
background: white;
border: 1px solid var(--stroke);
color: var(--text-primary);
transition: var(--transition);
}
.btn-outline:hover{
background: var(--surface);
border-color: var(--stroke-hover);
}
/* ---------- CARDS PREMIUM ---------- */
.soft-card{
background: var(--card);
border: 1px solid var(--stroke);
border-radius: var(--radius);
box-shadow: var(--shadow-sm);
transition: var(--transition);
height: 100%;
}
.soft-card:hover{
box-shadow: var(--shadow-md);
border-color: var(--stroke-hover);
}
.soft-card .card-body{ padding: 1.8rem; }
.icon-badge{
width: 56px;
height: 56px;
border-radius: 18px;
display: flex;
align-items: center;
justify-content: center;
background: linear-gradient(135deg, var(--accent), var(--accent2));
color: white;
margin-bottom: 1.2rem;
transition: var(--transition);
box-shadow: 0 10px 20px rgba(0,0,0,0.08);
}
.soft-card:hover .icon-badge{
transform: translateY(-3px) scale(1.05);
box-shadow: 0 18px 30px rgba(0,0,0,0.12);
}
.icon-badge svg{
width: 28px;
height: 28px;
stroke-width: 1.5;
}
/* ---------- HERO ---------- */
.hero{ padding-top: 140px; padding-bottom: 60px; }
.hero-card{
background: var(--card);
border: 1px solid var(--stroke);
border-radius: var(--radius);
box-shadow: var(--shadow-lg);
overflow: hidden;
}
.hero-inner{ padding: 3rem; }
.hero h1{
font-weight: 800;
font-size: clamp(2.2rem, 5vw, 3.5rem);
line-height: 1.1;
margin-bottom: 1.2rem;
}
.hero .lead{
font-size: 1.2rem;
color: var(--text-secondary);
margin-bottom: 1.8rem;
}
.hero-pills{
display: flex;
flex-wrap: wrap;
gap: 0.75rem;
margin: 2rem 0;
}
.pill{
border: 1px solid var(--stroke);
background: var(--surface);
border-radius: var(--radius-pill);
padding: 0.5rem 1rem;
font-size: 0.9rem;
font-weight: 500;
color: var(--text-secondary);
display: inline-flex;
align-items: center;
gap: 0.5rem;
}
.pill svg{ width: 18px; height: 18px; stroke: var(--accent); }
.hero-media{
background: linear-gradient(
135deg,
rgba(254,219,70,0.08),
rgba(189,126,8,0.08)
);
border-left: 1px solid var(--stroke);
height: 100%;
display: flex;
align-items: center;
justify-content: center;
padding: 2rem;
}
.hero-img{
width: 100%;
max-width: 480px;
aspect-ratio: 1/1;
border-radius: var(--radius);
background: white;
box-shadow: var(--shadow-md);
overflow: hidden;
display: flex;
align-items: center;
justify-content: center;
border: 1px solid var(--stroke);
}
.hero-img img{
width: 100%;
height: 100%;
object-fit: cover;
transition: var(--transition);
}
.hero-img:hover img{ transform: scale(1.02); }
.hero-note{ color: var(--text-muted); font-size: 0.85rem; margin-top: 1rem; }
/* ---------- QUIENES SOMOS ---------- */
.feature-list{
list-style: none;
padding: 0;
}
.feature-list li{
display: flex;
gap: 0.8rem;
align-items: center;
margin-bottom: 1rem;
font-weight: 500;
}
.feature-list li svg{
width: 22px;
height: 22px;
stroke: var(--accent2);
flex-shrink: 0;
}
/* ---------- SERVICIOS / CHIPS ---------- */
.service-group-title{
font-weight: 700;
font-size: 1.3rem;
margin-bottom: 1rem;
}
.chi
/* ...cortado... */
.footer-custom {
background: var(--surface);
border-top: 1px solid var(--stroke);
}
.footer-title {
font-weight: 700;
color: var(--text-primary);
position: relative;
padding-bottom: 8px;
}
.footer-title::after {
content: "";
position: absolute;
left: 0;
bottom: 0;
width: 40px;
height: 3px;
background: var(--accent);
border-radius: var(--radius-pill);
}
.footer-links a {
color: var(--text-secondary);
text-decoration: none;
transition: var(--transition);
}
.footer-links a:hover {
color: var(--accent2);
transform: translateX(4px);
}
.footer-divider {
border-color: var(--stroke);
}
.back-top {
color: var(--accent2);
font-weight: 600;
text-decoration: none;
transition: var(--transition);
}
.back-top:hover {
color: var(--accent);
}
:root{
/* WhatsApp oficial */
--wa:#25D366;
--wa-dark:#1fb85a;
--wa-darker:#189a4a;
/* UI clara */
--light-bg:#ffffff;
--light-bg-soft:#f6f8f7;
--light-border:#dde4df;
--dark-text:#1c1f1d;
--muted-text:#6c756f;
}
/* FACEBOOK button (arriba del IG) */
.fb-float{
position:fixed; right:18px; bottom:166px;
z-index:9997;
width:54px; height:54px; border-radius:50%;
display:grid; place-items:center; color:#fff; text-decoration:none;
background: linear-gradient(180deg, #1877F2 0%, #0f63d6 100%);
box-shadow:0 10px 30px rgba(0,0,0,.25);
transition:transform .25s, box-shadow .25s, opacity .25s;
}
.fb-float:hover{
transform:translateY(-2px) scale(1.04);
box-shadow:0 14px 36px rgba(0,0,0,.35);
}
/* IG button (medio) */
.ig-float{
position:fixed; right:18px; bottom:92px;
z-index:9998;
width:54px; height:54px; border-radius:50%;
display:grid; place-items:center; color:#fff; text-decoration:none;
background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
box-shadow:0 10px 30px rgba(0,0,0,.25);
transition:transform .25s, box-shadow .25s, opacity .25s;
}
.ig-float:hover{
transform:translateY(-2px) scale(1.04);
box-shadow:0 14px 36px rgba(0,0,0,.35);
}
/* WhatsApp flotante */
.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;
z-index:9999;
}
.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;
color:var(--dark-text);
}
.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){
.fb-float{ right:12px; bottom:160px; width:52px; height:52px; }
.ig-float{ right:12px; bottom:86px; width:52px; height:52px; }
.wa-float{ right:12px; bottom:12px; }
.wa-card{ width:calc(100vw - 24px); right:0; }
}
factory
https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swaphttps://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css:root{
--accent:#928d8d;
--accent-dark:#7a7575;
--ink:#1e1e1e;
--muted:#5f5f5f;
--soft-bg:#f9f9f9;
--white:#ffffff;
--radius-lg:24px;
--radius-md:16px;
--radius-sm:12px;
--shadow-card:0 20px 35px -8px rgba(0,0,0,0.07), 0 5px 15px rgba(0,0,0,0.03);
--shadow-hover:0 30px 45px -12px rgba(0,0,0,0.15), 0 8px 20px rgba(0,0,0,0.05);
--shadow-btn:0 8px 18px rgba(146,141,141,0.2);
--transition:all .25s cubic-bezier(.2,0,0,1);
--nav-offset:88px;
}
*{ box-sizing:border-box; }
html,body{ height:100%; scroll-behavior:smooth; }
body{
font-family:'Inter',system-ui,-apple-system,sans-serif;
color:var(--ink);
background:var(--white);
overflow-x:hidden;
line-height:1.5;
font-weight:400;
}
html, body{ overflow-x:hidden; width:100%; }
img, video{ max-width:100%; height:auto; }
h1,h2,h3,h4,.h1,.h2,.h3,.h4{ font-weight:700; letter-spacing:-0.02em; }
.fw-black{ font-weight:900; }
.muted{ color:var(--muted); }
.accent{ color:var(--accent); }
section[id],[id].anchor-offset{ scroll-margin-top:var(--nav-offset); }
.btn-accent{
--bs-btn-bg:var(--accent);
--bs-btn-border-color:var(--accent);
--bs-btn-hover-bg:var(--accent-dark);
--bs-btn-hover-border-color:var(--accent-dark);
--bs-btn-color:#fff;
--bs-btn-hover-color:#fff;
--bs-btn-focus-shadow-rgb:146,141,141;
--bs-btn-active-bg:var(--accent-dark);
--bs-btn-active-border-color:var(--accent-dark);
border-radius:60px;
padding:.75rem 1.5rem;
font-weight:600;
font-size:1rem;
transition:var(--transition);
box-shadow:none;
}
.btn-accent:hover{ transform:translateY(-3px); box-shadow:var(--shadow-btn); }
.btn-outline-accent{
--bs-btn-color:var(--accent);
--bs-btn-border-color:var(--accent);
--bs-btn-hover-bg:var(--accent);
--bs-btn-hover-border-color:var(--accent);
--bs-btn-hover-color:#fff;
--bs-btn-focus-shadow-rgb:146,141,141;
--bs-btn-active-bg:var(--accent);
--bs-btn-active-border-color:var(--accent);
border-radius:60px;
padding:.75rem 1.5rem;
font-weight:600;
font-size:1rem;
transition:var(--transition);
}
.btn-outline-accent:hover{ transform:translateY(-3px); box-shadow:var(--shadow-btn); }
.navbar{
backdrop-filter:blur(12px);
background:rgba(255,255,255,.85);
border-bottom:1px solid rgba(0,0,0,.03);
box-shadow:0 4px 20px rgba(0,0,0,.02);
}
.navbar .navbar-brand{
font-weight:800;
letter-spacing:-0.02em;
color:var(--ink);
font-size:1.2rem;
display:flex;
align-items:center;
gap:10px;
min-width:0;
}
.brand-mark{
width:34px;height:34px;
border-radius:12px;
display:grid;place-items:center;
background:rgba(146,141,141,.10);
border:1px solid rgba(146,141,141,.15);
flex:0 0 auto;
overflow:hidden;
}
.brand-mark img{ width:22px;height:22px; object-fit:contain; display:block; }
.navbar .navbar-brand span{
display:block;
max-width:100%;
white-space:nowrap;
overflow:hidden;
text-overflow:ellipsis;
}
.navbar .nav-link{
font-weight:500;
color:var(--ink);
padding:.5rem 1rem !important;
transition:var(--transition);
border-radius:30px;
font-size:.95rem;
}
.navbar .nav-link:hover{
color:var(--accent);
background:rgba(146,141,141,.05);
}
.navbar-toggler{
border:1px solid rgba(0,0,0,.08);
border-radius:12px;
padding:.5rem .6rem;
box-shadow:none;
}
.navbar-toggler:focus{
box-shadow:none;
border-color:var(--accent);
}
.section{ padding:100px 0; }
.anchor-offset{ scroll-margin-top:90px; }
.eyebrow{
display:inline-flex;
align-items:center;
gap:.5rem;
font-size:.8rem;
font-weight:600;
letter-spacing:.08em;
text-transform:uppercase;
color:var(--accent);
background:rgba(146,141,141,.08);
padding:.4rem 1rem;
border-radius:60px;
border:1px solid rgba(146,141,141,.1);
backdrop-filter:blur(4px);
}
.section-title{
font-weight:800;
font-size:clamp(2rem,4vw,2.8rem);
letter-spacing:-.03em;
margin-top:1rem;
margin-bottom:1rem;
line-height:1.2;
}
.section-subtitle{
color:var(--muted);
max-width:70ch;
margin-inline:auto;
font-size:1.1rem;
}
.hero{
padding-top:140px;
padding-bottom:80px;
background:linear-gradient(145deg, rgba(146,141,141,.06) 0%, rgba(255,255,255,0) 70%);
}
.hero h1{
font-weight:900;
letter-spacing:-.03em;
line-height:1.1;
font-size:clamp(2.4rem,5vw,3.6rem);
margin:1rem 0 1.2rem;
}
.hero p{
color:var(--muted);
font-size:1.1rem;
max-width:65ch;
}
.hero-cta{
display:flex;
gap:1rem;
flex-wrap:wrap;
margin:2rem 0 1.5rem;
}
.hero-points{ margin:1.2rem 0 0; }
.hero-point{
display:flex;
gap:.8rem;
align-items:flex-start;
color:var(--ink);
font-weight:500;
margin-bottom:.6rem;
}
.hero-point .dot{
width:10px;height:10px;border-radius:50%;
background:var(--accent);
margin-top:.5rem;
flex:0 0 auto;
box-shadow:0 8px 18px rgba(146,141,141,.22);
}
.hero-media{
border-radius:var(--radius-lg);
background:var(--white);
box-shadow:var(--shadow-card);
border:1px solid rgba(0,0,0,.03);
overflow:hidden;
padding:12px;
max-width:520px;
margin-inline:auto;
transition:var(--transition);
}
.hero-media:hover{ box-shadow:var(--shadow-hover); }
.hero-media .frame{
width:100%;
aspect-ratio:1/1;
background:var(--soft-bg);
border-radius:calc(var(--radius-lg) - 8px);
overflow:hidden;
display:flex;
align-items:center;
justify-content:center;
}
.hero-media img{
width:auto;
max-width:100%;
height:auto;
max-height:100%;
object-fit:contain;
display:block;
}
.card-soft{
border:1px solid rgba(0,0,0,.03);
border-radius:var(--radius-md);
background:var(--white);
box-shadow:var(--shadow-card);
transition:var(--transition);
height:100%;
overflow:hidden;
}
.card-soft:hover{
box-shadow:var(--shadow-hover);
transform:translateY(-5px);
}
.card-soft .card-body{ padding:1.8rem 1.5rem; }
.icon-circle{
width:52px;height:52px;
border-radius:18px;
display:flex;
align-items:center;
justify-content:center;
background:rgba(146,141,141,.1);
color:var(--accent);
border:1px solid rgba(146,141,141,.15);
margin-bottom:1.2rem;
font-size:1.25rem;
transition:var(--transition);
flex:0 0 auto;
}
.card-soft:hover .icon-circle{
background:var(--accent);
color:#fff;
border-color:var(--accent);
}
.service-item{
display:flex;
gap:1rem;
align-items:flex-start;
padding:1.2rem;
border-radius:var(--radius-md);
border:1px solid rgba(0,0,0,.03);
background:var(--white);
box-shadow:var(--shadow-card);
height:100%;
transition:var(--transition);
}
.service-item:hover{ box-shadow:var(--shadow-hover); transform:translateY(-4px); }
.service-item .icon-circle{
width:44px;height:44px;
border-radius:1
/* ...cortado... */
decorservice.com
https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swaphttps://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.csshttps://cdn.jsdelivr.net/npm/[email protected]/font/bootstrap-icons.min.csshttps://fonts.googleapis.com/css2?family=Inter:opsz,[email protected],400;14..32,600;14..32,700;14..32,800;14..32,900&display=swaphttps://unpkg.com/[email protected]/dist/aos.css/* ---------------------------------------------------------- */
/* ROOT - GAMA DE COLORES RESPETADA AL 100% */
/* ---------------------------------------------------------- */
:root {
--accent: #1392e3; /* Tu color principal */
--accent-dim: rgba(19, 146, 227, 0.15);
--accent-glow: rgba(19, 146, 227, 0.4);
--text-primary: #0f172a; /* Texto más profundo */
--text-muted: #475569; /* Gris más elegante */
--bg-soft: #f8fafc; /* Fondo suave general */
--border-light: rgba(15, 23, 42, 0.08);
--border-soft: rgba(15, 23, 42, 0.12);
--card-shadow: 0 20px 35px -8px rgba(0, 0, 0, 0.07), 0 5px 15px -5px rgba(0, 0, 0, 0.03);
--card-shadow-hover: 0 30px 50px -15px rgba(19, 146, 227, 0.25);
--radius-lg: 28px;
--radius-md: 22px;
--radius-sm: 16px;
--transition-bounce: cubic-bezier(0.34, 1.56, 0.64, 1);
}
/* ---------------------------------------------------------- */
/* GLOBAL - RESET Y ESTILOS BASE PREMIUM */
/* ---------------------------------------------------------- */
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
html {
scroll-behavior: smooth;
}
body {
font-family: "Inter", system-ui, -apple-system, sans-serif;
color: var(--text-primary);
background: #ffffff;
line-height: 1.5;
overflow-x: hidden;
padding-top: 85px; /* Ajustado para navbar más elegante */
}
/* Tipografía refinada */
h1, h2, h3, h4, .display-premium {
font-weight: 800;
letter-spacing: -0.03em;
line-height: 1.1;
}
/* ---------------------------------------------------------- */
/* COMPONENTES REUTILIZABLES DE LUJO */
/* ---------------------------------------------------------- */
.section {
padding: 110px 0;
position: relative;
}
.section-bg-soft {
background: var(--bg-soft);
}
.eyebrow {
display: inline-flex;
align-items: center;
gap: 0.6rem;
padding: 0.55rem 1.2rem;
background: #ffffff;
border: 1px solid var(--border-light);
border-radius: 100px;
font-size: 0.8rem;
font-weight: 800;
text-transform: uppercase;
letter-spacing: 0.08em;
color: var(--accent);
box-shadow: 0 2px 10px rgba(0,0,0,0.02);
margin-bottom: 1.5rem;
}
.eyebrow i {
font-size: 1.1rem;
}
.section-title {
font-size: clamp(2.2rem, 5vw, 3.4rem);
font-weight: 900;
color: var(--text-primary);
margin-bottom: 1.2rem;
line-height: 1.1;
}
.section-subtitle {
font-size: 1.2rem;
color: var(--text-muted);
max-width: 700px;
margin-left: auto;
margin-right: auto;
font-weight: 400;
}
/* Botones ultra premium */
.btn-premium {
padding: 0.8rem 2rem;
border-radius: 60px;
font-weight: 700;
font-size: 1rem;
transition: all 0.3s var(--transition-bounce);
border: none;
display: inline-flex;
align-items: center;
justify-content: center;
gap: 0.6rem;
box-shadow: 0 10px 20px -8px rgba(19, 146, 227, 0.3);
letter-spacing: -0.01em;
}
.btn-premium-primary {
background: var(--accent);
color: white;
}
.btn-premium-primary:hover {
background: #0f7bc0; /* Ligeramente más oscuro */
color: white;
transform: translateY(-4px);
box-shadow: 0 20px 30px -8px var(--accent-glow);
}
.btn-premium-outline {
background: transparent;
color: var(--text-primary);
border: 2px solid var(--border-soft);
box-shadow: none;
}
.btn-premium-outline:hover {
border-color: var(--accent);
background: var(--accent-dim);
color: var(--accent);
transform: translateY(-2px);
}
/* Cards de diseño */
.card-premium {
background: white;
border: 1px solid var(--border-light);
border-radius: var(--radius-md);
padding: 2rem 1.8rem;
height: 100%;
transition: all 0.35s ease;
box-shadow: var(--card-shadow);
}
.card-premium:hover {
transform: translateY(-12px);
border-color: var(--accent-dim);
box-shadow: var(--card-shadow-hover);
}
.icon-premium {
width: 60px;
height: 60px;
background: var(--accent-dim);
border: 1px solid rgba(19, 146, 227, 0.25);
border-radius: 20px;
display: flex;
align-items: center;
justify-content: center;
margin-bottom: 1.8rem;
transition: all 0.3s ease;
color: var(--accent);
font-size: 26px;
}
.card-premium:hover .icon-premium {
background: var(--accent);
color: white;
border-color: var(--accent);
}
.card-premium h3 {
font-size: 1.6rem;
font-weight: 800;
margin-bottom: 0.8rem;
}
.card-premium p {
color: var(--text-muted);
font-size: 1rem;
line-height: 1.6;
}
/* Divisor suave */
.divider-soft {
height: 1px;
background: linear-gradient(90deg, transparent, rgba(15,23,42,0.1), transparent);
margin: 1.5rem 0;
}
/* ---------------------------------------------------------- */
/* NAVBAR - PULIDA Y ELEGANTE */
/* ---------------------------------------------------------- */
.navbar {
background: rgba(255, 255, 255, 0.80);
backdrop-filter: blur(16px) saturate(180%);
border-bottom: 1px solid var(--border-light);
padding: 15px 0;
transition: all 0.3s;
}
.navbar .navbar-brand {
font-weight: 900;
font-size: 1.8rem;
letter-spacing: -0.02em;
color: var(--text-primary);
}
.navbar-brand span.dot {
display: inline-block;
width: 12px;
height: 12px;
background: var(--accent);
border-radius: 100px;
margin-right: 8px;
box-shadow: 0 0 0 4px rgba(19, 146, 227, 0.2);
}
.brand-icon{
display:inline-block;
object-fit:contain;
flex:0 0 auto;
border-radius: 6px;
}
.navbar-nav .nav-link {
color: var(--text-primary);
font-weight: 600;
font-size: 1rem;
padding: 0.6rem 1rem !important;
border-radius: 60px;
transition: all 0.2s;
}
.navbar-nav .nav-link:hover {
background: var(--accent-dim);
color: var(--accent);
}
/* ---------------------------------------------------------- */
/* HERO - IMPACTANTE */
/* ---------------------------------------------------------- */
.hero {
padding: 20px 0 80px;
}
.hero-card {
background: white;
border: 1px solid var(--border-light);
border-radius: var(--radius-lg);
padding: 3rem;
box-shadow: var(--card-shadow);
}
.hero h1 {
font-size: clamp(2.8rem, 6vw, 4rem);
font-weight: 900;
line-height: 1.05;
margin: 1.2rem 0 1.2rem;
}
.hero-highlight {
color: var(--accent);
text-decoration: underline;
text-decoration-thickness: 4px;
text-underline-offset: 8px;
}
.hero-list {
list-style: none;
padding: 0;
margin: 2rem 0;
}
.hero-list li {
display: flex;
gap: 1rem;
align-items: center;
font-size: 1.15rem;
font-weight: 500;
margin-bottom: 1rem;
}
.hero-list li i {
color: var(--accent);
font-size: 1.5rem;
background: var(--accent-dim);
paddin
/* ...cortado... */
/* Flotante WhatsApp (Decor Service) */
:root{
--ds-accent:#1392e3;
--ds-accent-dark:#0f79bf;
--wa-border:#e3e6ea;
}
.wa-float{
position:fixed;
right:18px;
bottom:18px;
z-index:9999;
font-family:inherit;
}
/* botón */
.wa-btn{
width:60px;
height:60px;
border-radius:50%;
border:none;
background:linear-gradient(135deg,#25D366,#128C7E); /* WhatsApp */
color:#fff;
display:grid;
place-items:center;
cursor:pointer;
box-shadow:0 10px 30px rgba(37,211,102,.45);
transition:transform .3s, box-shadow .3s;
}
.wa-btn:hover{
transform:translateY(-3px) scale(1.05);
box-shadow:0 14px 36px rgba(37,211,102,.55);
}
/* tarjeta */
.wa-card{
position:absolute;
right:0;
bottom:74px;
width:min(360px,92vw);
background:#fff;
border-radius:18px;
border:1px solid var(--wa-border);
box-shadow:0 18px 60px rgba(0,0,0,.25);
overflow:hidden;
transform:translateY(10px);
opacity:0;
transition:.3s;
}
.wa-card[aria-modal="true"]{ transform:none; opacity:1; }
.wa-head{
display:flex;
align-items:center;
gap:12px;
padding:14px;
background:linear-gradient(135deg,var(--ds-accent),var(--ds-accent-dark));
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; letter-spacing:-.2px; }
.wa-status{ font-size:.85rem; opacity:.95; }
.wa-close{
margin-left:auto;
border:none;
background:transparent;
color:#fff;
font-size:24px;
cursor:pointer;
line-height:1;
}
.wa-body{
padding:14px;
max-height:40vh;
overflow:auto;
background:#f7f9fb;
display:flex;
flex-direction:column;
gap:8px;
}
.wa-bubble{
max-width:90%;
padding:10px 12px;
border-radius:14px;
font-size:.95rem;
box-shadow:0 4px 10px rgba(0,0,0,.08);
}
.wa-bot{
background:#ffffff;
border:1px solid var(--wa-border);
align-self:flex-start;
}
.wa-user{
background:rgba(19,146,227,.10);
border:1px solid rgba(19,146,227,.25);
align-self:flex-end;
}
.wa-mini{
font-size:.82rem;
color:#5f6b76;
padding-top:2px;
}
.wa-compose{
display:grid;
grid-template-columns:1fr auto;
gap:8px;
padding:10px;
border-top:1px solid var(--wa-border);
background:#ffffff;
}
.wa-compose textarea{
resize:none;
border-radius:12px;
padding:10px;
border:1px solid var(--wa-border);
font-family:inherit;
outline:none;
}
.wa-compose textarea:focus{
border-color:rgba(19,146,227,.55);
box-shadow:0 0 0 4px rgba(19,146,227,.12);
}
.wa-send{
background:var(--ds-accent);
color:#fff;
border:none;
border-radius:12px;
padding:0 16px;
cursor:pointer;
}
.wa-send:hover{ background:var(--ds-accent-dark); }
@media(max-width:480px){
.wa-card{ width:calc(100vw - 24px); }
}