Preview de mixed.css
/* MIXED CSS PACK */
/* Template: jardineriamimorita.com.ar/index.html */
/* Template mtime: 2026-04-24 12:05:01 */
/* external link (no embedded): https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Playfair+Display:wght@700;800&display=swap */
/* external link (no embedded): https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css */
/* ===== INLINE <style> BLOCK #1 ===== */
/* ─── 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);
}
:root{
--accent:#287a52;
--accent-dark:#1e6040;
--accent-light:#3a9e6a;
--accent-soft:rgba(40,122,82,.08);
--accent-soft2:rgba(40,122,82,.14);
--accent-border:rgba(40,122,82,.18);
--text:#111111;
--muted:#585858;
--surface:#ffffff;
--surface-soft:#f6f7f5;
--border:rgba(17,17,17,.08);
--shadow-sm:0 10px 30px rgba(17,17,17,.06);
--shadow-md:0 24px 60px rgba(17,17,17,.10);
--shadow-lg:0 40px 80px rgba(17,17,17,.13);
--radius-lg:28px;
--radius-md:22px;
--radius-sm:16px;
--container:1240px;
}
*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
font-family:"Manrope",sans-serif;
color:var(--text);
background:#fff;
line-height:1.65;
text-rendering:optimizeLegibility;
-webkit-font-smoothing:antialiased;
overflow-x:hidden;
}
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
.container{ max-width:var(--container); padding-inline:1.5rem; }
/* ─── EYEBROW ─── */
.eyebrow{
display:inline-flex;
align-items:center;
gap:.55rem;
padding:.45rem 1rem;
border-radius:999px;
background:var(--accent-soft);
border:1px solid var(--accent-border);
color:var(--accent);
font-size:.78rem;
font-weight:800;
letter-spacing:.16em;
text-transform:uppercase;
}
/* ─── SECTION ─── */
.section{ padding:120px 0; }
.section-head{ max-width:680px; margin-bottom:4rem; }
.section-title{
font-family:"Playfair Display",serif;
margin:.85rem 0 .85rem;
font-size:clamp(2.1rem,4vw,3.4rem);
line-height:1.08;
font-weight:800;
letter-spacing:-.02em;
color:var(--text);
}
.section-subtitle{
margin:0;
font-size:1.06rem;
color:var(--muted);
line-height:1.7;
}
/* ─── NAVBAR ─── */
.topbar{
position:sticky;
top:0;
z-index:1030;
padding:.85rem 0;
background:rgba(255,255,255,.9);
backdrop-filter:blur(20px);
-webkit-backdrop-filter:blur(20px);
border-bottom:1px solid rgba(17,17,17,.06);
transition:box-shadow .3s ease;
}
.topbar.scrolled{
box-shadow:0 4px 30px rgba(17,17,17,.06);
}
.navbar-inner{
display:flex;
align-items:center;
justify-content:space-between;
gap:1.5rem;
}
.navbar-brand{
display:flex;
align-items:center;
gap:.85rem;
font-size:1.05rem;
font-weight:800;
letter-spacing:-.03em;
color:var(--text);
flex-shrink:0;
}
.brand-logo{
width:46px;
height:46px;
object-fit:contain;
border-radius:14px;
background:#fff;
padding:.35rem;
box-shadow:inset 0 0 0 1px rgba(17,17,17,.08), 0 4px 12px rgba(17,17,17,.07);
}
.nav-links{
display:flex;
align-items:center;
gap:.2rem;
list-style:none;
}
.nav-links a{
color:var(--muted);
font-weight:600;
font-size:.9rem;
padding:.55rem 1rem;
border-radius:999px;
transition:background .22s, color .22s;
letter-spacing:-.01em;
white-space:nowrap;
}
.nav-links a:hover{
color:var(--accent);
background:var(--accent-soft);
}
.navbar-toggler{
display:none;
border:0;
padding:.5rem .7rem;
border-radius:14px;
background:var(--surface-soft);
cursor:pointer;
flex-shrink:0;
}
.navbar-toggler span{
display:block;
width:22px;
height:2px;
background:var(--text);
border-radius:2px;
transition:transform .3s, opacity .3s;
margin:4px 0;
}
.nav-cta{
flex-shrink:0;
}
.mobile-nav{
display:none;
}
/* ─── BUTTONS ─── */
.btn{
display:inline-flex;
align-items:center;
justify-content:center;
gap:.5rem;
border-radius:999px;
font-weight:700;
font-size:.95rem;
padding:.88rem 1.75rem;
border:none;
cursor:pointer;
transition:transform .22s cubic-bezier(.34,1.56,.64,1), box-shadow .22s ease, background .22s ease;
letter-spacing:-.01em;
}
.btn:hover{ transform:translateY(-2px); }
.btn-accent{
color:#fff;
background:var(--accent);
box-shadow:0 14px 32px rgba(40,122,82,.24), inset 0 1px 0 rgba(255,255,255,.15);
}
.btn-accent:hover{
color:#fff;
background:var(--accent-dark);
box-shadow:0 22px 44px rgba(40,122,82,.30);
}
.btn-ghost{
color:var(--text);
background:transparent;
border:1.5px solid var(--border);
box-shadow:none;
}
.btn-ghost:hover{
background:var(--surface-soft);
border-color:rgba(17,17,17,.18);
}
/* ─── HERO ─── */
.hero{
padding:80px 0 100px;
position:relative;
overflow:hidden;
}
.hero::before{
content:"";
position:absolute;
width:900px;
height:900px;
border-radius:50%;
background:radial-gradient(circle, rgba(40,122,82,.07) 0%, transparent 70%);
top:-300px;
right:-200px;
pointer-events:none;
}
.hero::after{
content:"";
position:absolute;
width:600px;
height:600px;
border-radius:50%;
background:radial-gradient(circle, rgba(40,122,82,.05) 0%, transparent 70%);
bottom:-200px;
left:-100px;
pointer-events:none;
}
.hero-grid{
display:grid;
grid-template-columns:1fr 1fr;
align-items:center;
gap:5rem;
}
.hero-eyebrow-row{
display:flex;
align-items:center;
gap:1rem;
margin-bottom:1.5rem;
}
.hero-dot{
width:8px;
height:8px;
border-radius:50%;
background:var(--accent);
animation:pulse-dot 2.5s infinite;
}
@keyframes pulse-dot{
0%,100%{ transform:scale(1); opacity:1; }
50%{ transform:scale(1.4); opacity:.6; }
}
.hero-title{
font-family:"Playfair Display",serif;
font-size:clamp(2.9rem,5.5vw,5rem);
line-height:1.04;
font-weight:800;
letter-spacing:-.03em;
margin-bottom:1.4rem;
}
.hero-title em{
font-style:normal;
color:var(--accent);
position:relative;
}
.hero-text{
font-size:1.08rem;
color:var(--muted);
line-height:1.75;
margin-bottom:2.25rem;
max-width:520px;
}
.hero-actions{
display:flex;
gap:1rem;
flex-wrap:wrap;
margin-bottom:3rem;
}
.hero-stats{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:1px;
background:var(--border);
border-radius:20px;
overflow:hidden;
border:1px solid var(--border);
}
.stat-item{
background:#fff;
padding:1.25rem 1.1rem;
display:flex;
flex-direction:column;
gap:.25rem;
}
.stat-item strong{
font-size:1.5rem;
font-weight:800;
letter-spacing:-.04em;
color:var(--accent);
line-height:1;
}
.stat-item span{
font-size:.8rem;
color:var(--muted);
font-weight:600;
letter-spacing:.01em;
}
/* ─── HERO VISUAL ─── */
.hero-copy{
display:flex;
flex-direction:column;
}
.hero-visual-wrap{
position:relative;
}
.hero-visual-mobile{
display:none;
}
.hero-visual{
position:relative;
border-radius:36px;
overflow:hidden;
min-height:580px;
box-shadow:var(--shadow-lg);
}
.hero-visual::before{
content:"";
position:absolute;
inset:0;
background:linear-gradient(180deg, transparent 50%, rgba(17,17,17,.55) 100%);
z-index:1;
pointer-events:none;
}
.hero-visual img{
width:100%;
height:100%;
min-height:580px;
object-fit:cover;
object-position:center;
display:block;
}
.hero-badge{
position:absolute;
top:24px;
left:24px;
z-index:2;
background:rgba(255,255,255,.92);
backdrop-filter:blur(12px);
border:1px solid rgba(255,255,255,.6);
border-radius:999px;
padding:.55rem 1.1rem;
display:flex;
align-items:center;
gap:.6rem;
font-size:.8rem;
font-weight:700;
color:var(--text);
}
.hero-badge-dot{
width:8px;
height:8px;
border-radius:50%;
background:#22c55e;
box-shadow:0 0 0 3px rgba(34,197,94,.25);
}
.hero-panel{
position:absolute;
left:20px;
right:20px;
bottom:20px;
z-index:2;
padding:1.4rem 1.5rem;
border-radius:24px;
background:rgba(255,255,255,.92);
backdrop-filter:blur(16px);
border:1px solid rgba(255,255,255,.7);
box-shadow:0 20px 50px rgba(17,17,17,.15);
}
.hero-panel-label{
display:block;
font-size:.72rem;
font-weight:800;
letter-spacing:.14em;
text-transform:uppercase;
color:var(--accent);
margin-bottom:.5rem;
}
.hero-panel p{
margin:0;
font-weight:700;
font-size:.97rem;
line-height:1.5;
color:var(--text);
}
.hero-float{
position:absolute;
right:-28px;
top:50%;
transform:translateY(-50%);
background:#fff;
border:1px solid var(--border);
border-radius:22px;
padding:1.1rem 1.2rem;
box-shadow:var(--shadow-md);
display:flex;
flex-direction:column;
gap:.4rem;
min-width:148px;
}
.hero-float-icon{
width:40px;
height:40px;
border-radius:12px;
background:var(--accent-soft);
display:flex;
align-items:center;
justify-content:center;
color:var(--accent);
margin-bottom:.3rem;
}
.hero-float strong{
font-size:1.05rem;
font-weight:800;
letter-spacing:-.03em;
}
.hero-float span{
font-size:.78rem;
color:var(--muted);
font-weight:600;
}
/* ─── ABOUT ─── */
#quienes-somos{
background:var(--surface-soft);
position:relative;
}
#quienes-somos::before{
content:"";
position:absolute;
top:0; left:0; right:0; height:1px;
background:linear-gradient(90deg, transparent, var(--accent-border), transparent);
}
.about-wrapper{
display:grid;
grid-template-columns:1fr 1fr;
gap:3rem;
align-items:start;
}
.about-left .section-head{
margin-bottom:2rem;
}
.about-copy{
font-size:1.06rem;
color:var(--muted);
line-height:1.8;
}
.about-signature{
margin-top:2rem;
display:flex;
align-items:center;
gap:1rem;
padding:1.2rem 1.4rem;
border-radius:20px;
background:#fff;
border:1px solid var(--border);
box-shadow:var(--shadow-sm);
}
.about-signature-avatar{
width:48px;
height:48px;
border-radius:50%;
background:var(--accent-soft);
border:2px solid var(--accent-border);
display:flex;
align-items:center;
justify-content:center;
color:var(--accent);
flex-shrink:0;
}
.about-signature strong{
display:block;
font-size:.95rem;
font-weight:800;
letter-spacing:-.02em;
}
.about-signature span{
font-size:.82rem;
color:var(--muted);
font-weight:600;
}
.about-cards{
display:grid;
gap:1.25rem;
}
.about-card{
padding:1.8rem;
border-radius:var(--radius-md);
background:#fff;
border:1px solid var(--border);
box-shadow:var(--shadow-sm);
transition:transform .28s cubic-bezier(.34,1.56,.64,1), box-shadow .28s ease;
position:relative;
overflow:hidden;
}
.about-card::before{
content:"";
position:absolute;
top:0;left:0;
width:4px;
height:100%;
background:var(--accent);
border-radius:0 4px 4px 0;
opacity:0;
transition:opacity .28s;
}
.about-card:hover{
transform:translateY(-4px);
box-shadow:var(--shadow-md);
}
.about-card:hover::before{
opacity:1;
}
.about-card-icon{
width:48px;
height:48px;
border-radius:14px;
background:var(--accent-soft);
display:flex;
align-items:center;
justify-content:center;
color:var(--accent);
margin-bottom:1.1rem;
}
.about-card h3{
font-size:1.1rem;
font-weight:800;
letter-spacing:-.03em;
margin-bottom:.6rem;
}
.about-card p{
color:var(--muted);
font-size:.95rem;
line-height:1.7;
margin:0;
}
/* ─── SERVICES ─── */
#servicios{
background:#fff;
}
.services-grid{
display:grid;
grid-template-columns:repeat(2,1fr);
gap:2rem;
}
.service-block{
border-radius:var(--radius-lg);
border:1px solid var(--border);
background:#fff;
box-shadow:var(--shadow-sm);
overflow:hidden;
transition:transform .28s cubic-bezier(.34,1.56,.64,1), box-shadow .28s ease;
display:flex;
flex-direction:column;
}
.service-block:hover{
transform:translateY(-6px);
box-shadow:var(--shadow-md);
}
.service-block-head{
padding:2.2rem 2.2rem 1.5rem;
background:linear-gradient(135deg, var(--accent-soft) 0%, rgba(40,122,82,.02) 100%);
border-bottom:1px solid var(--accent-border);
}
.service-icon{
width:60px;
height:60px;
border-radius:18px;
background:var(--accent);
display:flex;
align-items:center;
justify-content:center;
color:#fff;
margin-bottom:1.2rem;
box-shadow:0 8px 24px rgba(40,122,82,.28);
}
.service-block h3{
font-family:"Playfair Display",serif;
font-size:1.5rem;
font-weight:800;
letter-spacing:-.02em;
margin:0;
color:var(--text);
}
.service-block-body{
padding:1.8rem 2.2rem 2.2rem;
flex:1;
display:flex;
flex-direction:column;
}
.service-list{
list-style:none;
padding:0;
margin:0 0 1.5rem;
display:grid;
gap:.7rem;
}
.service-list li{
display:flex;
align-items:flex-start;
gap:.8rem;
font-weight:600;
font-size:.95rem;
color:var(--text);
}
.service-list li::before{
content:"";
flex-shrink:0;
width:20px;
height:20px;
border-radius:50%;
background:var(--accent-soft);
border:1.5px solid var(--accent-border);
background-image:url("data:image/svg+xml,%3Csvg width='10' height='8' viewBox='0 0 10 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 4l2.5 2.5L9 1' stroke='%23287a52' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
background-repeat:no-repeat;
background-position:center;
margin-top:2px;
}
.service-desc{
font-size:.94rem;
color:var(--muted);
line-height:1.72;
margin-top:auto;
}
/* ─── WHY US ─── */
#por-que-elegirnos{
background:var(--surface-soft);
}
.why-grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:1.5rem;
}
.why-card{
padding:2rem;
border-radius:var(--radius-md);
background:#fff;
border:1px solid var(--border);
box-shadow:var(--shadow-sm);
height:100%;
transition:transform .28s cubic-bezier(.34,1.56,.64,1), box-shadow .28s ease, border-color .28s;
position:relative;
overflow:hidden;
}
.why-card::after{
content:"";
position:absolute;
inset:0;
background:linear-gradient(135deg, var(--accent-soft) 0%, transparent 60%);
opacity:0;
transition:opacity .28s;
pointer-events:none;
}
.why-card:hover{
transform:translateY(-5px);
box-shadow:var(--shadow-md);
border-color:var(--accent-border);
}
.why-card:hover::after{
opacity:1;
}
.why-icon{
width:56px;
height:56px;
border-radius:16px;
background:var(--accent-soft);
border:1px solid var(--accent-border);
display:flex;
align-items:center;
justify-content:center;
color:var(--accent);
margin-bottom:1.3rem;
position:relative;
z-index:1;
transition:background .28s, box-shadow .28s;
}
.why-card:hover .why-icon{
background:var(--accent);
color:#fff;
box-shadow:0 8px 20px rgba(40,122,82,.28);
}
.why-card h3{
font-size:1.1rem;
font-weight:800;
letter-spacing:-.03em;
margin-bottom:.65rem;
position:relative;
z-index:1;
}
.why-card p{
color:var(--muted);
font-size:.93rem;
line-height:1.72;
margin:0;
position:relative;
z-index:1;
}
/* ─── GALLERY (untouched) ─── */
.gal-gallery{
padding-top:0;
padding-bottom:56px;
}
.gal-gallery .carousel{
max-width:980px;
margin-inline:auto;
position:relative;
}
.gal-frame{
height:clamp(220px,48vh,440px);
background:#fff;
border-radius:28px;
overflow:hidden;
box-shadow:0 24px 50px rgba(17,17,17,.10);
display:flex;
align-items:center;
justify-content:center;
padding:14px;
border:1px solid rgba(17,17,17,.05);
}
.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:54px;
height:54px;
top:50%;
transform:translateY(-50%);
opacity:1;
background:rgba(17,17,17,.72);
border-radius:50%;
margin:0 12px;
backdrop-filter:blur(8px);
}
.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:-54px;
}
.gal-gallery .carousel-indicators button{
width:10px;
height:10px;
border-radius:50%;
background:rgba(17,17,17,.34);
border:none;
margin:0 6px;
}
.gal-gallery .carousel-indicators button.active{
background:var(--accent);
}
#galLightbox .modal-content{
background:#000;
border-radius:24px;
overflow:hidden;
}
#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:46px;
height:46px;
border-radius:999px;
background:rgba(255,255,255,.18);
color:#fff;
font-size:30px;
line-height:46px;
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; }
/* ─── FAQ ─── */
#preguntas-frecuentes{
background:#fff;
}
#preguntas-frecuentes .section-head{
max-width:680px;
margin:0 auto 4rem;
text-align:center;
}
.faq-wrap{
max-width:800px;
margin-inline:auto;
}
.faq-item{
border-radius:var(--radius-sm);
border:1px solid var(--border);
background:#fff;
overflow:hidden;
margin-bottom:.85rem;
transition:border-color .25s, box-shadow .25s;
}
.faq-item.open{
border-color:var(--accent-border);
box-shadow:0 8px 28px rgba(40,122,82,.08);
}
.faq-btn{
width:100%;
display:flex;
align-items:center;
justify-content:space-between;
gap:1rem;
padding:1.3rem 1.4rem;
background:none;
border:none;
cursor:pointer;
text-align:left;
font-family:"Manrope",sans-serif;
font-size:1rem;
font-weight:700;
color:var(--text);
transition:color .25s, background .25s;
}
.faq-btn:hover{ color:var(--accent); }
.faq-item.open .faq-btn{
color:var(--accent);
background:var(--accent-soft);
}
.faq-icon{
flex-shrink:0;
width:32px;
height:32px;
border-radius:50%;
background:var(--surface-soft);
border:1px solid var(--border);
display:flex;
align-items:center;
justify-content:center;
color:var(--muted);
transition:background .25s, color .25s, transform .28s cubic-bezier(.34,1.56,.64,1), border-color .25s;
}
.faq-item.open .faq-icon{
background:var(--accent);
color:#fff;
border-color:var(--accent);
transform:rotate(45deg);
}
.faq-body{
padding:0 1.4rem;
max-height:0;
overflow:hidden;
transition:max-height .35s cubic-bezier(.4,0,.2,1), padding .35s;
color:var(--muted);
font-size:.97rem;
line-height:1.75;
}
.faq-item.open .faq-body{
max-height:400px;
padding:0 1.4rem 1.4rem;
}
/* ─── CONTACT ─── */
#contacto{
background:var(--surface-soft);
}
.contact-panel{
border-radius:var(--radius-lg);
border:1px solid var(--border);
background:#fff;
box-shadow:var(--shadow-md);
overflow:hidden;
display:grid;
grid-template-columns:5fr 7fr;
}
.contact-copy{
padding:clamp(2rem,3.5vw,3.5rem);
background:linear-gradient(160deg, var(--accent) 0%, var(--accent-dark) 100%);
color:#fff;
display:flex;
flex-direction:column;
}
.contact-copy .eyebrow{
background:rgba(255,255,255,.15);
border-color:rgba(255,255,255,.25);
color:#fff;
}
.contact-copy .section-title{
color:#fff;
font-size:clamp(1.8rem,3vw,2.6rem);
}
.contact-copy > p{
color:rgba(255,255,255,.82);
font-size:1rem;
line-height:1.75;
}
.contact-list{
display:grid;
gap:.85rem;
margin-top:2rem;
}
.contact-item{
display:flex;
align-items:center;
gap:1rem;
padding:.95rem 1.1rem;
border-radius:16px;
background:rgba(255,255,255,.12);
border:1px solid rgba(255,255,255,.18);
transition:background .25s;
}
.contact-item:hover{
background:rgba(255,255,255,.2);
}
.contact-item-icon{
width:42px;
height:42px;
border-radius:12px;
background:rgba(255,255,255,.18);
display:flex;
align-items:center;
justify-content:center;
color:#fff;
flex-shrink:0;
}
.contact-item-text strong{
display:block;
font-size:.72rem;
font-weight:800;
text-transform:uppercase;
letter-spacing:.12em;
color:rgba(255,255,255,.65);
margin-bottom:.2rem;
}
.contact-item-text a,
.contact-item-text span{
color:#fff;
font-weight:700;
font-size:.95rem;
}
.contact-form-wrap{
padding:clamp(2rem,3.5vw,3.5rem);
background:#fff;
}
.form-shell{
display:grid;
gap:1.4rem;
}
.form-row{
display:grid;
grid-template-columns:1fr 1fr;
gap:1.2rem;
}
.form-group{
display:flex;
flex-direction:column;
gap:.55rem;
}
.form-label{
font-weight:700;
font-size:.88rem;
letter-spacing:.01em;
color:var(--text);
}
.form-control{
border-radius:14px;
padding:.9rem 1.05rem;
border:1.5px solid var(--border);
background:#fff;
font-family:"Manrope",sans-serif;
font-size:.97rem;
color:var(--text);
transition:border-color .22s, box-shadow .22s;
outline:none;
width:100%;
}
textarea.form-control{
min-height:140px;
resize:vertical;
}
.form-control:focus{
border-color:var(--accent);
box-shadow:0 0 0 3px rgba(40,122,82,.12);
}
.form-control::placeholder{
color:rgba(88,88,88,.5);
}
.form-submit-row{
display:flex;
flex-direction:column;
align-items:flex-start;
gap:.9rem;
}
.microcopy{
font-size:.87rem;
color:var(--muted);
line-height:1.6;
}
/* ─── FOOTER ─── */
.site-footer{
background:linear-gradient(160deg, #1a5c3d 0%, #0f3b28 100%);
color:#fff;
padding:88px 0 32px;
position:relative;
overflow:hidden;
}
.site-footer::before{
content:"";
position:absolute;
width:600px;
height:600px;
border-radius:50%;
background:radial-gradient(circle, rgba(255,255,255,.04) 0%, transparent 70%);
top:-200px;
right:-100px;
pointer-events:none;
}
.footer-grid{
display:grid;
grid-template-columns:1.6fr 1fr 1fr;
gap:3rem;
align-items:start;
position:relative;
}
.footer-brand{
display:flex;
align-items:center;
gap:1rem;
margin-bottom:1.2rem;
}
.footer-brand img{
width:54px;
height:54px;
object-fit:contain;
border-radius:16px;
background:rgba(255,255,255,.12);
padding:.4rem;
}
.footer-brand strong{
font-family:"Playfair Display",serif;
font-size:1.4rem;
font-weight:800;
letter-spacing:-.03em;
}
.footer-text{
color:rgba(255,255,255,.72);
font-size:.97rem;
line-height:1.75;
max-width:340px;
}
.footer-title{
font-size:.75rem;
letter-spacing:.18em;
text-transform:uppercase;
font-weight:800;
margin-bottom:1.2rem;
color:rgba(255,255,255,.55);
}
.footer-links{
list-style:none;
padding:0;
margin:0;
display:grid;
gap:.65rem;
}
.footer-links a,
.footer-links span{
color:rgba(255,255,255,.85);
font-weight:600;
font-size:.95rem;
transition:color .22s;
}
.footer-links a:hover{
color:#fff;
}
.footer-bottom{
margin-top:3rem;
padding-top:1.5rem;
border-top:1px solid rgba(255,255,255,.12);
display:flex;
justify-content:space-between;
align-items:center;
gap:1rem;
flex-wrap:wrap;
position:relative;
}
.footer-bottom p{
margin:0;
color:rgba(255,255,255,.6);
font-size:.88rem;
}
.footer-bottom a{
color:rgba(255,255,255,.85);
font-weight:700;
transition:color .22s;
}
.footer-bottom a:hover{
color:#fff;
}
/* ─── ANIMATIONS ─── */
.fade-up{
opacity:0;
transform:translateY(32px);
transition:opacity .7s cubic-bezier(.4,0,.2,1), transform .7s cubic-bezier(.4,0,.2,1);
}
.fade-up.visible{
opacity:1;
transform:translateY(0);
}
/* ─── RESPONSIVE ─── */
@media(max-width:991.98px){
.hero-grid{
grid-template-columns:1fr;
gap:3rem;
}
.about-wrapper{
grid-template-columns:1fr;
}
.services-grid,
.why-grid{
grid-template-columns:1fr;
}
.contact-panel{
grid-template-columns:1fr;
}
.footer-grid{
grid-template-columns:1fr 1fr;
}
.hero-float{
display:none;
}
.nav-links,
.nav-cta{
display:none;
}
.navbar-toggler{
display:block;
}
.navbar-inner{
position:relative;
}
.mobile-nav{
position:absolute;
top:calc(100% + 1rem);
left:0;
right:0;
background:rgba(255,255,255,.98);
backdrop-filter:blur(20px);
border-radius:24px;
border:1px solid var(--border);
box-shadow:var(--shadow-md);
padding:1.2rem;
display:none;
z-index:100;
}
.mobile-nav.open{
display:block;
}
.mobile-nav ul{
list-style:none;
padding:0;
margin:0 0 1rem;
display:grid;
gap:.3rem;
}
.mobile-nav a{
display:block;
padding:.75rem 1rem;
border-radius:12px;
font-weight:600;
color:var(--muted);
transition:color .22s, background .22s;
}
.mobile-nav a:hover{
color:var(--accent);
background:var(--accent-soft);
}
.form-row{
grid-template-columns:1fr;
}
}
@media(max-width:767.98px){
.section{ padding:84px 0; }
.hero{ padding:60px 0 80px; }
.hero-grid{ gap:2rem; }
.hero-title{ font-size:clamp(2.4rem,12vw,3.5rem); }
.hero-text{ max-width:100%; }
.hero-visual-desktop{ display:none; }
.hero-visual-mobile{
display:block;
margin:1.4rem 0 1.6rem;
}
.hero-visual-fit{
min-height:auto;
overflow:hidden;
}
.hero-visual-fit::before{
display:none;
}
.hero-visual-fit img{
width:100%;
height:auto;
min-height:0;
max-height:420px;
object-fit:contain;
object-position:center;
background:#fff;
}
.hero-visual-fit .hero-badge{
top:14px;
left:14px;
padding:.45rem .9rem;
font-size:.74rem;
}
.hero-visual-fit{
display:flex;
flex-direction:column;
background:#fff;
}
.hero-visual-fit .hero-panel{
position:static;
left:auto;
right:auto;
bottom:auto;
margin:0;
padding:1rem 1.05rem 1.1rem;
border-radius:0 0 24px 24px;
box-shadow:none;
border-top:1px solid rgba(17,17,17,.06);
background:#fff;
}
.hero-actions{ flex-direction:column; }
.hero-actions .btn{ width:100%; }
.hero-stats{ grid-template-columns:1fr; }
.footer-grid{ grid-template-columns:1fr; }
.footer-bottom{ flex-direction:column; align-items:flex-start; }
.services-grid{ grid-template-columns:1fr; }
}
/* ===== 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;
}
.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-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);
}
.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:.9rem;
}
@keyframes fadeIn{
from{opacity:0;transform:translateY(5px)}
to{opacity:1;transform:none}
}
.wa-bot{
background:#fff;
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:#fff;
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:.9rem;
transition:.2s;
}
.wa-compose textarea:focus{
border-color:var(--wa);
box-shadow:0 0 0 2px rgba(37,211,102,.15);
background:#fff;
}
.wa-send{
background:var(--wa);
color:#fff;
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;
}
}