Preview de mixed.css
/* MIXED CSS PACK */
/* Template: institutogranadino.com/index.html */
/* Template mtime: 2026-05-05 19:27:04 */
/* external link (no embedded): https://fonts.googleapis.com/css2?family=Domine:wght@400;600;700&family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&display=swap */
/* external link (no embedded): https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css */
/* external link (no embedded): https://cdn.jsdelivr.net/npm/[email protected]/font/bootstrap-icons.css */
/* ===== INLINE <style> BLOCK #1 ===== */
/* ─── VARIABLES ─────────────────────────────────────────────── */
:root{
--brand:#111111;
--brand-2:#2b2b2b;
--accent:#cfbc79;
--accent-dark:#9f8946;
--accent-light:#f4ecd2;
--paper:#faf8f1;
--soft:#f7f3e6;
--ink:#111111;
--muted:#6d665c;
--line:#e8dfc7;
--white:#ffffff;
--shadow:0 14px 34px rgba(17,17,17,.08);
--shadow-lg:0 24px 54px rgba(17,17,17,.12);
--radius:18px;
--radius-lg:28px;
--nav-h:72px;
--t:all .35s cubic-bezier(.4,0,.2,1);
}
/* ─── RESET / BASE ──────────────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:90px}
html,body{max-width:100%;overflow-x:hidden}
body{font-family:'Plus Jakarta Sans',system-ui,sans-serif;background:#fff;color:var(--ink);line-height:1.72;-webkit-font-smoothing:antialiased}
img,video{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,h5{font-family:'Domine',Georgia,serif;color:var(--brand);letter-spacing:-.025em;line-height:1.1}
.text-muted{color:var(--muted)!important}
/* ─── BUTTONS ───────────────────────────────────────────────── */
.btn{font-weight:700;letter-spacing:.01em;border:0;border-radius:999px;padding:.7rem 1.6rem;font-size:.97rem;transition:var(--t);display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;font-family:inherit}
.btn-brand{background:var(--brand);color:#fff;box-shadow:0 8px 24px rgba(17,17,17,.18)}
.btn-brand:hover{background:#000;color:#fff;transform:translateY(-2px);box-shadow:0 14px 32px rgba(17,17,17,.22)}
.btn-accent{background:var(--accent);color:#111;box-shadow:0 8px 24px rgba(207,188,121,.35)}
.btn-accent:hover{background:var(--accent-dark);color:#fff;transform:translateY(-2px);box-shadow:0 14px 32px rgba(159,137,70,.38)}
.btn-ghost{background:transparent;color:var(--brand);border:2px solid var(--line);padding:.65rem 1.5rem}
.btn-ghost:hover{border-color:var(--accent);background:var(--accent-light);color:var(--brand);transform:translateY(-2px)}
.btn-outline-wa{background:transparent;color:#25d366;border:2px solid #25d366;padding:.65rem 1.5rem}
.btn-outline-wa:hover{background:#25d366;color:#fff;transform:translateY(-2px)}
/* ─── NAVBAR ────────────────────────────────────────────────── */
.navbar{
position:sticky;top:0;z-index:1030;
min-height:var(--nav-h);
padding:.7rem 0;
background:rgba(255,255,255,.92);
backdrop-filter:saturate(200%) blur(20px);
-webkit-backdrop-filter:saturate(200%) blur(20px);
border-bottom:1px solid rgba(232,223,199,.6);
box-shadow:0 2px 20px rgba(17,17,17,.04);
transition:var(--t)
}
.navbar.scrolled{
background:rgba(255,255,255,.98);
box-shadow:0 4px 30px rgba(17,17,17,.09);
border-bottom-color:rgba(232,223,199,.9)
}
.navbar .container{flex-wrap:nowrap}
.navbar-brand{
display:flex;align-items:center;gap:.75rem;
color:var(--brand);font-family:'Domine',Georgia,serif;
font-weight:700;font-size:1.1rem;letter-spacing:-.01em
}
.navbar-brand img{height:44px;width:auto;object-fit:contain;flex:0 0 auto}
.navbar-brand span{white-space:nowrap}
/* Separator dot */
.navbar-brand::after{content:'';display:none}
.nav-link{
color:var(--brand);font-weight:600;font-size:.9rem;
padding:.45rem .75rem!important;border-radius:10px;
position:relative;transition:var(--t);letter-spacing:.01em
}
.nav-link::after{
content:'';position:absolute;left:50%;bottom:4px;
width:0;height:2px;background:var(--accent);
transform:translateX(-50%);transition:var(--t);border-radius:2px
}
.nav-link:hover,.nav-link.active{color:var(--accent-dark)}
.nav-link:hover::after,.nav-link.active::after{width:55%}
.navbar-toggler{border:0;box-shadow:none!important;padding:.4rem}
.navbar-toggler:focus{box-shadow:none!important}
/* Custom hamburger */
.toggler-bar{
display:block;width:22px;height:2px;background:var(--ink);
border-radius:2px;transition:var(--t);margin:5px 0
}
.nav-cta{
background:var(--brand);color:#fff!important;
border-radius:999px;padding:.5rem 1.1rem!important;
margin-left:.5rem;font-weight:700;font-size:.88rem;
box-shadow:0 6px 18px rgba(17,17,17,.16);
transition:var(--t);letter-spacing:.01em
}
.nav-cta:hover{background:var(--accent);color:#111!important;transform:translateY(-2px)}
.nav-cta::after{display:none!important}
/* ─── HERO ──────────────────────────────────────────────────── */
.hero{
position:relative;
height:clamp(380px,58svh,560px);
min-height:380px;
overflow:hidden;
background:var(--paper);
}
.hero-img{
position:absolute;inset:0;
width:100%;height:100%;
object-fit:cover;object-position:50% 45%;
transform:scale(1.04);
animation:heroZoom 12s ease-out forwards;
will-change:transform;
}
@keyframes heroZoom{to{transform:scale(1)}}
/* Dark gradient overlay at bottom for text readability */
.hero::after{
content:'';position:absolute;inset:0;pointer-events:none;
background:linear-gradient(180deg,
rgba(17,17,17,.0) 0%,
rgba(17,17,17,.05) 60%,
rgba(17,17,17,.18) 100%);
}
@supports not (height:1svh){.hero{height:clamp(380px,58vh,560px)}}
@media(max-width:991.98px){
.hero{height:clamp(330px,50svh,470px);min-height:330px}
.hero-img{object-position:50% 38%}
}
@media(max-width:767px){
.hero{height:clamp(260px,42svh,360px)!important;min-height:260px!important}
.hero-img{object-position:50% 30%!important}
}
/* ─── INTRO (below hero) ────────────────────────────────────── */
.intro-section{
background:#fff;
padding:88px 0 80px;
position:relative;
overflow:hidden;
}
/* subtle decorative circle */
.intro-section::before{
content:'';position:absolute;top:-180px;right:-180px;
width:560px;height:560px;border-radius:50%;
background:radial-gradient(circle,rgba(207,188,121,.12) 0%,transparent 70%);
pointer-events:none
}
.intro-eyebrow{
display:flex;align-items:center;justify-content:center;gap:.5rem;
width:fit-content;max-width:100%;
font-weight:700;letter-spacing:.1em;text-transform:uppercase;
font-size:.76rem;padding:.42rem 1rem;border-radius:999px;
background:var(--accent-light);color:var(--accent-dark);
margin:0 auto 1.2rem;
clear:both;
}
.intro-eyebrow i{font-size:.9rem}
.intro-title{
font-size:clamp(2.4rem,5vw,4.4rem);
line-height:1.04;
max-width:900px;
margin:0 auto 1.3rem;
letter-spacing:-.03em;
}
.intro-title em{
font-style:normal;
color:var(--accent-dark);
position:relative;display:inline-block;
}
.intro-title em::after{
content:'';position:absolute;
left:0;bottom:-4px;right:0;height:3px;
background:linear-gradient(90deg,var(--accent-dark),var(--accent));
border-radius:3px;opacity:.6;
}
.intro-lead{
font-size:clamp(1rem,1.3vw,1.14rem);
color:var(--muted);max-width:800px;margin:0 auto 2.2rem;
font-weight:400;line-height:1.78
}
.intro-actions{
display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;
}
/* Stats strip */
.intro-stats{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:1.2rem;
max-width:780px;
margin:3rem auto 0;
}
.intro-stat{
background:var(--paper);
border:1px solid var(--line);
border-radius:20px;
padding:1.4rem 1.2rem;
text-align:center;
position:relative;
overflow:hidden;
transition:var(--t);
}
.intro-stat::before{
content:'';position:absolute;inset-x:0;top:0;height:3px;
background:linear-gradient(90deg,var(--accent-dark),var(--accent));
border-radius:3px 3px 0 0;
}
.intro-stat:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.intro-stat-num{
font-family:'Domine',Georgia,serif;
font-size:2rem;font-weight:700;
color:var(--brand);letter-spacing:-.03em;
display:block;line-height:1
}
.intro-stat-label{
font-size:.82rem;font-weight:600;
color:var(--muted);margin-top:.4rem;
display:block;letter-spacing:.03em;text-transform:uppercase
}
@media(max-width:600px){
.intro-stats{grid-template-columns:1fr}
.intro-actions .btn{width:100%;justify-content:center}
}
/* ─── SECTIONS SHARED ───────────────────────────────────────── */
.section{padding:96px 0;position:relative}
.section-paper{background:var(--paper)}
.section-white{background:#fff}
.section-after-ticker{padding-top:58px}
@media(max-width:767.98px){.section-after-ticker{padding-top:46px}}
.eyebrow{
display:flex;align-items:center;justify-content:center;gap:.45rem;
width:fit-content;max-width:100%;
font-weight:700;letter-spacing:.1em;text-transform:uppercase;
font-size:.76rem;padding:.42rem 1rem;border-radius:999px;
background:var(--accent-light);color:var(--accent-dark);
margin:0 0 1.1rem;
clear:both;
}
.section-heading{
font-size:clamp(1.8rem,3.5vw,2.8rem);
margin:0 0 1rem;letter-spacing:-.025em;
}
.section-heading mark{
background:linear-gradient(transparent 55%,rgba(207,188,121,.32) 0);
padding:0 .2em;border-radius:6px;
color:inherit;
}
/* Gold underline decoration */
.heading-line{
display:block;width:52px;height:3px;margin:1rem 0 1.3rem;
background:linear-gradient(90deg,var(--accent-dark),var(--accent));
border-radius:3px;
}
.text-center .heading-line{margin-left:auto;margin-right:auto}
.section-sub{
font-size:1.05rem;color:var(--muted);max-width:780px;
line-height:1.78;
}
/* Eyebrow siempre arriba del título */
.eyebrow + .section-heading,
.intro-eyebrow + .intro-title{
display:block;
width:100%;
clear:both;
}
.text-center .eyebrow,
.text-center .intro-eyebrow{
margin-left:auto;
margin-right:auto;
}
.section-heading{
display:block;
width:100%;
}
/* ─── QUIÉNES SOMOS ─────────────────────────────────────────── */
.about-card{
background:#fff;
border:1px solid var(--line);
border-radius:var(--radius-lg);
padding:2.2rem 2rem;
box-shadow:var(--shadow);
position:relative;overflow:hidden;
}
.about-card::before{
content:'';position:absolute;top:0;left:0;right:0;height:4px;
background:linear-gradient(90deg,var(--accent-dark),var(--accent),var(--accent-light));
}
.about-card p{color:var(--muted);line-height:1.8;margin-bottom:1rem}
.about-card p:last-child{margin-bottom:0}
.about-card strong{color:var(--brand)}
.check-list{list-style:none;padding:0;margin:1.6rem 0 0;display:grid;gap:.8rem}
.check-list li{
display:flex;gap:.85rem;align-items:flex-start;
font-size:.97rem;color:var(--muted);
}
.check-list li .icon-check{
flex:0 0 auto;width:22px;height:22px;border-radius:50%;
background:var(--accent-light);color:var(--accent-dark);
display:grid;place-items:center;font-size:.8rem;margin-top:.1rem
}
.media-frame{
border-radius:var(--radius-lg);overflow:hidden;
border:1px solid var(--line);box-shadow:var(--shadow-lg);
background:#fff;min-height:420px;
display:flex;align-items:center;justify-content:center;padding:12px;
}
.media-frame img{
width:100%;height:100%;max-height:520px;
object-fit:contain;display:block;background:#fff;border-radius:18px;
}
/* ─── SERVICIOS ─────────────────────────────────────────────── */
.service-card{
height:100%;background:#fff;
border:1px solid var(--line);
border-radius:var(--radius);
padding:1.75rem 1.6rem;
box-shadow:0 4px 20px rgba(17,17,17,.05);
transition:var(--t);
position:relative;overflow:hidden;
}
.service-card::after{
content:'';position:absolute;
inset-x:0;bottom:0;height:0;
background:linear-gradient(0deg,rgba(207,188,121,.08),transparent);
transition:height .4s ease;
}
.service-card:hover{
transform:translateY(-6px);
box-shadow:0 20px 50px rgba(17,17,17,.11);
border-color:rgba(207,188,121,.55);
}
.service-card:hover::after{height:100%}
.service-icon{
width:56px;height:56px;border-radius:16px;
background:var(--accent-light);color:var(--accent-dark);
display:grid;place-items:center;font-size:1.4rem;
margin-bottom:1.15rem;
transition:var(--t);
}
.service-card:hover .service-icon{
background:var(--brand);color:var(--accent);
}
.service-card h3{font-size:1.06rem;margin-bottom:.6rem}
.service-card p{color:var(--muted);margin:0;font-size:.93rem;line-height:1.7}
/* ─── IMAGE TICKER ─────────────────────────────────────────── */
.image-ticker-section{
background:#fff;
padding:72px 0 70px;
overflow:hidden;
border-top:1px solid rgba(232,223,199,.72);
border-bottom:1px solid rgba(232,223,199,.72);
}
.image-ticker{
position:relative;
width:100%;
overflow:hidden;
}
.image-ticker-track{
display:flex;
align-items:center;
gap:42px;
width:max-content;
animation:imageTickerMove 72s linear infinite;
will-change:transform;
}
.image-ticker:hover .image-ticker-track{animation-play-state:paused}
.image-ticker-item{
flex:0 0 auto;
width:auto;
height:clamp(420px,34vw,560px);
margin:0;
border-radius:28px;
overflow:visible;
background:transparent;
border:0;
box-shadow:none;
}
.image-ticker-item img{
height:100%;
width:auto;
max-width:none;
object-fit:contain;
object-position:center;
display:block;
border-radius:28px;
background:#fff;
border:1px solid var(--line);
box-shadow:0 18px 44px rgba(17,17,17,.14);
}
@keyframes imageTickerMove{
from{transform:translateX(0)}
to{transform:translateX(-50%)}
}
@media(max-width:991.98px){
.image-ticker-section{padding:56px 0 54px}
.image-ticker-track{gap:30px;animation-duration:62s}
.image-ticker-item{height:clamp(330px,48vw,430px);border-radius:24px}
.image-ticker-item img{border-radius:24px}
}
@media(max-width:575.98px){
.image-ticker-section{padding:42px 0 40px}
.image-ticker-track{gap:22px;animation-duration:50s}
.image-ticker-item{height:clamp(260px,72vw,340px);border-radius:20px}
.image-ticker-item img{border-radius:20px}
}
/* ─── POR QUÉ ELEGIRNOS ─────────────────────────────────────── */
.why-card{
height:100%;
padding:1.8rem 1.6rem;
border-radius:var(--radius);
border:1px solid var(--line);
background:#fff;
box-shadow:0 4px 20px rgba(17,17,17,.05);
transition:var(--t);
position:relative;overflow:hidden;
}
.why-card::before{
content:'';position:absolute;
left:0;top:0;bottom:0;width:3px;
background:linear-gradient(180deg,var(--accent-dark),var(--accent));
border-radius:0 3px 3px 0;
transform:scaleY(0);transform-origin:bottom;
transition:transform .4s ease;
}
.why-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:rgba(207,188,121,.4)}
.why-card:hover::before{transform:scaleY(1)}
.why-icon{
width:52px;height:52px;border-radius:14px;
display:grid;place-items:center;
background:var(--brand);color:var(--accent);
font-size:1.3rem;margin-bottom:1.1rem;
transition:var(--t);
}
.why-card:hover .why-icon{background:var(--accent);color:var(--brand)}
.why-card h3{font-size:1.02rem;margin-bottom:.5rem;font-weight:700}
.why-card p{color:var(--muted);margin:0;font-size:.93rem;line-height:1.7}
/* ─── GALLERY (unchanged functionally, subtle polish) ────────── */
.gal-gallery .carousel{max-width:980px;margin-inline:auto;position:relative}
.gal-frame{
height:clamp(260px,52vh,500px);background:#fff;
border-radius:20px;overflow:hidden;box-shadow:var(--shadow-lg);
display:flex;align-items:center;justify-content:center;
padding:10px;border:1px solid var(--line)
}
.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:52px;height:52px;top:50%;transform:translateY(-50%);
opacity:1;background:rgba(17,17,17,.66);border-radius:50%;
margin:0 12px;transition:var(--t)
}
.gal-gallery .carousel-control-prev:hover,.gal-gallery .carousel-control-next:hover{background:#111}
.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:-52px}
.gal-gallery .carousel-indicators button{
width:10px;height:10px;border-radius:50%;
background:rgba(17,17,17,.35);border:none
}
.gal-gallery .carousel-indicators button.active{background:#111}
.gal-gallery{padding-bottom:60px}
#galLightbox .modal-content{background:#000;border:0;border-radius:20px;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:32px;
line-height:44px;text-align:center;z-index:5;cursor:pointer;transition:var(--t)
}
.gal-lightbox-nav:hover{background:rgba(255,255,255,.3)}
.gal-lightbox-nav.gal-prev{left:12px}
.gal-lightbox-nav.gal-next{right:12px}
/* ─── FAQs ──────────────────────────────────────────────────── */
.faq-wrap .accordion-item{
border:1px solid var(--line)!important;
border-radius:16px!important;overflow:hidden;
margin-bottom:.9rem;background:#fff;
box-shadow:0 4px 16px rgba(17,17,17,.04);
transition:var(--t);
}
.faq-wrap .accordion-item:hover{box-shadow:var(--shadow)}
.faq-wrap .accordion-button{
font-weight:700;color:var(--brand);
background:#fff;padding:1.2rem 1.4rem;
font-family:'Plus Jakarta Sans',sans-serif;
font-size:.97rem;gap:.75rem;
}
.faq-wrap .accordion-button::before{
content:'';flex:0 0 20px;height:20px;border-radius:50%;
background:var(--accent-light);
background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='%239f8946' d='M8 4a.5.5 0 0 1 .5.5v3h3a.5.5 0 0 1 0 1h-3v3a.5.5 0 0 1-1 0v-3h-3a.5.5 0 0 1 0-1h3v-3A.5.5 0 0 1 8 4z'/%3E%3C/svg%3E");
background-size:100%;background-repeat:no-repeat;
transition:var(--t);
}
.faq-wrap .accordion-button:not(.collapsed)::before{
background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='%239f8946' d='M4 8a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7A.5.5 0 0 1 4 8z'/%3E%3C/svg%3E");
background:var(--accent-light);
}
.faq-wrap .accordion-button:not(.collapsed){
background:var(--paper);color:var(--brand);box-shadow:none;
}
.faq-wrap .accordion-button:focus{
box-shadow:0 0 0 .2rem rgba(207,188,121,.22);
}
.faq-wrap .accordion-button::after{display:none}
.faq-wrap .accordion-body{
color:var(--muted);padding:0 1.4rem 1.2rem 3.3rem;
font-size:.96rem;line-height:1.78;
}
/* ─── CONTACT ───────────────────────────────────────────────── */
.contact-info-card{
height:100%;
background:var(--brand);
border-radius:var(--radius-lg);
padding:2.4rem 2rem;
color:#fff;
position:relative;overflow:hidden;
}
.contact-info-card::before{
content:'';position:absolute;
right:-80px;top:-80px;
width:300px;height:300px;border-radius:50%;
background:rgba(207,188,121,.08);pointer-events:none
}
.contact-info-card::after{
content:'';position:absolute;
left:-60px;bottom:-60px;
width:220px;height:220px;border-radius:50%;
background:rgba(207,188,121,.06);pointer-events:none
}
.contact-info-card h3{color:#fff;margin-bottom:1.5rem;font-size:1.3rem}
.ci-item{
display:flex;gap:1rem;align-items:flex-start;
margin-bottom:1.4rem;color:rgba(255,255,255,.82)
}
.ci-item:last-child{margin-bottom:0}
.ci-icon{
flex:0 0 42px;height:42px;border-radius:12px;
background:rgba(207,188,121,.18);color:var(--accent);
display:grid;place-items:center;font-size:1.1rem;
}
.ci-label{font-weight:700;color:#fff;display:block;margin-bottom:.2rem;font-size:.9rem}
.ci-value{font-size:.93rem;line-height:1.5}
.ci-value a{color:rgba(255,255,255,.82);transition:color .2s}
.ci-value a:hover{color:var(--accent)}
.contact-form-card{
height:100%;
background:#fff;
border:1px solid var(--line);
border-radius:var(--radius-lg);
padding:2.4rem 2rem;
box-shadow:var(--shadow);
}
.form-label{font-weight:700;color:var(--brand);margin-bottom:.45rem;font-size:.9rem}
.form-control,.form-select{
padding:.85rem 1.1rem;
border-radius:12px;
border:1.5px solid var(--line);
transition:var(--t);background:#fff;
font-family:inherit;font-size:.96rem;
color:var(--ink)
}
.form-control:focus,.form-select:focus{
border-color:var(--accent-dark);
box-shadow:0 0 0 .2rem rgba(207,188,121,.18);
outline:none;
}
.form-control::placeholder{color:#aaa}
/* ─── FOOTER ────────────────────────────────────────────────── */
footer{
background:var(--brand);color:#fff;
padding:60px 0 28px;
position:relative;overflow:hidden;
}
footer::before{
content:'';position:absolute;
right:-200px;top:-200px;
width:600px;height:600px;border-radius:50%;
background:radial-gradient(circle,rgba(207,188,121,.07) 0%,transparent 70%);
pointer-events:none
}
.footer-brand{display:flex;align-items:center;gap:.8rem;margin-bottom:1rem}
.footer-brand img{height:42px;width:auto;object-fit:contain;flex:0 0 auto}
.footer-brand-name{
font-family:'Domine',Georgia,serif;
font-weight:700;font-size:1.05rem;color:#fff
}
.footer-desc{max-width:440px;color:rgba(255,255,255,.6);font-size:.92rem;line-height:1.72}
.footer-divider{
width:40px;height:2px;
background:linear-gradient(90deg,var(--accent-dark),var(--accent));
border-radius:2px;margin:1.2rem 0;
}
.footer-heading{
font-size:.78rem;font-weight:800;
text-transform:uppercase;letter-spacing:.1em;
color:var(--accent);margin-bottom:1rem
}
.footer-links{display:grid;gap:.55rem}
.footer-links a{
font-size:.9rem;font-weight:500;
color:rgba(255,255,255,.65);transition:color .2s;
}
.footer-links a:hover{color:#fff}
.footer-bottom{
border-top:1px solid rgba(255,255,255,.08);
margin-top:40px;padding-top:22px;
display:flex;flex-wrap:wrap;gap:1rem;
justify-content:space-between;align-items:center;
font-size:.86rem;color:rgba(255,255,255,.5)
}
.netfan-link{font-weight:700;color:rgba(255,255,255,.75);text-decoration:underline;text-underline-offset:3px}
.netfan-link:hover{color:#fff}
/* ─── WHATSAPP FLOAT ────────────────────────────────────────── */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:10050}
.wa-btn{
background:#25d366;color:#fff;border:0;
width:62px;height:62px;border-radius:50%;
display:grid;place-items:center;
box-shadow:0 8px 30px rgba(37,211,102,.38);
cursor:pointer;transition:var(--t);font-size:1.6rem;
}
.wa-btn:hover{transform:translateY(-3px) scale(1.06)}
.wa-card{
position:absolute;right:0;bottom:78px;
width:min(360px,92vw);background:#111;color:#fff;
border-radius:22px;overflow:hidden;
box-shadow:0 20px 60px rgba(0,0,0,.45);
border:1px solid rgba(255,255,255,.08);
transform:translateY(12px);opacity:0;
transition:transform .32s cubic-bezier(.4,0,.2,1),opacity .32s ease;
}
.wa-card[aria-modal="true"]{transform:translateY(0);opacity:1}
.wa-head{
display:flex;align-items:center;gap:12px;
padding:14px 16px;background:#161616;
border-bottom:1px solid rgba(255,255,255,.07)
}
.wa-avatar{
width:40px;height:40px;border-radius:12px;
background:var(--accent);color:#111;
display:grid;place-items:center;font-weight:900;font-size:1rem
}
.wa-title{font-weight:800;font-size:1.02rem}
.wa-status{
font-size:.82rem;color:rgba(255,255,255,.65);
display:flex;align-items:center;gap:6px
}
.wa-status::before{
content:'';width:7px;height:7px;border-radius:50%;background:#25d366
}
.wa-close{
margin-left:auto;background:transparent;color:#fff;border:0;
font-size:22px;cursor:pointer;opacity:.7;
width:30px;height:30px;border-radius:50%;transition:var(--t)
}
.wa-close:hover{opacity:1;background:rgba(255,255,255,.1)}
.wa-body{
padding:14px 16px;max-height:40vh;overflow:auto;
background:#111;display:flex;flex-direction:column;gap:10px
}
.wa-bubble{
max-width:88%;padding:10px 14px;border-radius:14px;
line-height:1.4;box-shadow:0 4px 12px rgba(0,0,0,.2);font-size:.93rem
}
.wa-bot{
background:#202020;border:1px solid rgba(255,255,255,.06);
align-self:flex-start;border-bottom-left-radius:4px
}
.wa-user{background:#128c7e;align-self:flex-end;border-bottom-right-radius:4px}
.wa-compose{
display:grid;grid-template-columns:1fr auto;gap:8px;
padding:10px 12px;background:#111;
border-top:1px solid rgba(255,255,255,.07)
}
.wa-compose textarea{
resize:none;border-radius:12px;padding:10px 14px;
border:1px solid rgba(255,255,255,.13);
background:#1c1c1c;color:#fff;outline:0;
min-height:44px;font-family:inherit;font-size:.93rem
}
.wa-send{
background:#25d366;color:#111;border:0;
border-radius:12px;padding:0 18px;
font-weight:900;cursor:pointer;font-size:.95rem;
transition:var(--t)
}
.wa-send:hover{background:#1fba5a}
/* ─── REVEAL ANIMATION ──────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .75s ease,transform .75s ease}
.reveal.active{opacity:1;transform:translateY(0)}
/* ─── RESPONSIVE ────────────────────────────────────────────── */
@media(max-width:991.98px){
:root{--nav-h:66px}
.navbar{padding:.6rem 0}
.navbar-collapse{
position:absolute;left:12px;right:12px;
top:calc(100% + 8px);background:#fff;
border:1px solid var(--line);border-radius:22px;
padding:16px;box-shadow:var(--shadow-lg);
}
.nav-cta{display:inline-flex;margin-top:.5rem;margin-left:0}
.media-frame{min-height:340px}
}
@media(max-width:767.98px){
.section{padding:66px 0}
.contact-info-card,.contact-form-card{padding:1.8rem 1.5rem}
.wa-float{right:14px;bottom:14px}
.wa-card{width:calc(100vw - 28px)}
.intro-stats{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
.intro-stats{grid-template-columns:1fr}
}