:root {
--ff-green: #1e7d2f;
--ff-green-dark: #155a22;
--ff-yellow: #f5c518;
--ff-yellow-soft: #ffd84d;
--ff-blue: #0b3a8c;
--ff-blue-dark: #061f4d;
--ff-white: #ffffff;
--ff-cream: #faf8f3;
--ff-ink: #0a1430;
--ff-muted: #4b5a72;
--ff-border: #e6e9f0;
--ff-stroke: #e6e9f0;
--gradient-brand: linear-gradient(135deg, var(--ff-green) 0%, var(--ff-blue) 100%);
--gradient-flag: linear-gradient(135deg, var(--ff-green) 0%, var(--ff-yellow) 60%, var(--ff-blue) 100%);
--gradient-hero: linear-gradient(
120deg,
rgba(6, 31, 77, 0.92) 0%,
rgba(21, 90, 34, 0.85) 60%,
rgba(11, 58, 140, 0.78) 100%
);
--shadow-soft: 0 10px 30px -12px rgba(6, 31, 77, 0.25);
--shadow-strong: 0 20px 50px -20px rgba(6, 31, 77, 0.45);
--radius: 0.625rem;
} html,
body {
background: var(--ff-cream);
color: var(--ff-ink);
font-family: "Inter", system-ui, -apple-system, sans-serif;
-webkit-font-smoothing: antialiased;
scroll-behavior: smooth;
}
h1, h2, h3, h4, h5, h6,
.display-1, .display-2, .display-3, .display-4, .display-5, .display-6 {
font-family: "Manrope", "Inter", sans-serif;
font-weight: 800;
letter-spacing: -0.02em;
color: var(--ff-ink);
} .btn {
font-weight: 600;
padding: 0.7rem 1.5rem;
border-radius: 999px;
transition: transform 0.25s ease, box-shadow 0.25s ease, background-color 0.25s ease;
}
.btn:hover { transform: translateY(-2px); }
.btn-ff-primary { background: var(--ff-green); color: #fff; border: 2px solid var(--ff-green); }
.btn-ff-primary:hover { background: var(--ff-green-dark); color: #fff; box-shadow: var(--shadow-soft); }
.btn-ff-secondary { background: var(--ff-yellow); color: var(--ff-blue-dark); border: 2px solid var(--ff-yellow); }
.btn-ff-secondary:hover { background: var(--ff-yellow-soft); color: var(--ff-blue-dark); }
.btn-ff-outline { background: transparent; color: #fff; border: 2px solid rgba(255, 255, 255, 0.7); }
.btn-ff-outline:hover { background: #fff; color: var(--ff-blue-dark); }
.btn-ff-ghost { background: transparent; color: var(--ff-blue-dark); border: 2px solid var(--ff-blue-dark); }
.btn-ff-ghost:hover { background: var(--ff-blue-dark); color: #fff; } .bg-ff-green { background: var(--ff-green); color: #fff; }
.bg-ff-blue { background: var(--ff-blue-dark); color: #fff; }
.bg-ff-yellow { background: var(--ff-yellow); color: var(--ff-blue-dark); }
.bg-ff-cream { background: var(--ff-cream); }
.bg-ff-gradient { background: var(--gradient-brand); color: #fff; }
.text-ff-green { color: var(--ff-green); }
.text-ff-blue { color: var(--ff-blue-dark); }
.text-ff-yellow { color: var(--ff-yellow); }
.text-ff-muted { color: var(--ff-muted); } .ff-navbar {
position: sticky;
top: 0;
z-index: 1030;
background: rgba(255, 255, 255, 0.92);
backdrop-filter: saturate(180%) blur(14px);
border-bottom: 1px solid var(--ff-border);
transition: background-color 0.3s ease, border-color 0.3s ease, backdrop-filter 0.3s ease;
}
.ff-navbar-transparent {
position: absolute;
left: 0;
right: 0;
top: 0;
background: transparent;
border-bottom-color: transparent;
backdrop-filter: none;
}
.ff-navbar-transparent .nav-link,
.ff-navbar-transparent .nav-link:hover,
.ff-navbar-transparent .nav-link.active { color: #fff !important; }
.ff-navbar-transparent .nav-link::after { background: var(--ff-yellow); }
.ff-navbar .nav-link {
color: var(--ff-ink);
font-weight: 500;
padding: 0.65rem 1rem !important;
position: relative;
}
.ff-navbar .nav-link::after {
content: "";
position: absolute;
left: 1rem; right: 1rem; bottom: 0.35rem;
height: 2px;
background: var(--ff-green);
transform: scaleX(0);
transform-origin: left;
transition: transform 0.3s ease;
}
.ff-navbar .nav-link:hover::after,
.ff-navbar .nav-link.active::after { transform: scaleX(1); }
.ff-navbar .nav-link.active { color: var(--ff-green) !important; } .ff-logo-dark { display: none; }
.ff-navbar-transparent .ff-logo-light { display: inline-block; }
.ff-navbar-transparent .ff-logo-dark { display: none; }
.ff-navbar:not(.ff-navbar-transparent) .ff-logo-light { display: none; }
.ff-navbar:not(.ff-navbar-transparent) .ff-logo-dark { display: inline-block; } .ff-hero {
position: relative;
min-height: 1080px;
padding: 100px 0 0;
display: flex;
align-items: center;
color: #fff;
overflow: hidden;
background: var(--ff-blue-dark);
}
@media (max-width: 991.98px) {
.ff-hero { min-height: auto; padding: 140px 0 80px; }
}
.ff-hero::before {
content: "";
position: absolute;
inset: 0;
background: var(--gradient-hero), url(//www.flaviafrancischini.com.br/wp-content/themes/francischini/assets/img/hero-bg.jpg) center/cover no-repeat;
background-blend-mode: multiply;
z-index: 0;
}
.ff-hero.ff-hero--carousel::before { display: none; }
.ff-hero > .container { position: relative; z-index: 2; }
.ff-hero h1 { color: #fff; font-size: clamp(2.4rem, 5vw, 4.5rem); line-height: 1.02; }
.ff-hero .lead { color: rgba(255, 255, 255, 0.85); font-size: 1.15rem; max-width: 640px; }
@keyframes ffFadeInLeft {
from { opacity: 0; transform: translateX(-40px); }
to { opacity: 1; transform: translateX(0); }
}
@keyframes ffFadeInBottom {
from { opacity: 0; transform: translateY(40px); }
to { opacity: 1; transform: translateY(0); }
}
.ff-fade-in-left { animation: ffFadeInLeft 1s ease both; }
.ff-fade-in-left.delay-1 { animation-delay: 0.15s; }
.ff-fade-in-left.delay-2 { animation-delay: 0.3s; }
.ff-fade-in-left.delay-3 { animation-delay: 0.45s; }
.ff-fade-in-bottom { animation: ffFadeInBottom 1.1s ease both; animation-delay: 0.25s; }
.ff-hero-accent {
display: inline-block;
background: var(--ff-yellow);
color: var(--ff-blue-dark);
font-weight: 700;
padding: 0.35rem 0.9rem;
border-radius: 999px;
font-size: 0.85rem;
letter-spacing: 0.04em;
text-transform: uppercase;
} .ff-slide { position: absolute; inset: 0; background-size: cover; background-position: center; opacity: 0; transition: opacity 1s ease; }
.ff-slide.is-active { opacity: 1; }
.ff-hero-textblock { display: none; }
.ff-hero-textblock.is-active { display: block; } .ff-section { padding: 6rem 0; }
.ff-section-tight { padding: 4rem 0; }
.ff-eyebrow {
display: inline-block;
font-size: 0.8rem;
font-weight: 700;
letter-spacing: 0.18em;
text-transform: uppercase;
color: var(--ff-green);
padding-bottom: 0.5rem;
border-bottom: 2px solid var(--ff-yellow);
margin-bottom: 1rem;
} .ff-card {
background: #fff;
border: 1px solid var(--ff-border);
border-radius: 1rem;
padding: 2rem;
height: 100%;
transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease;
}
.ff-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-strong); border-color: var(--ff-green); }
.ff-card .icon-wrap {
width: 56px; height: 56px;
border-radius: 14px;
display: flex; align-items: center; justify-content: center;
background: var(--gradient-brand);
color: #fff;
margin-bottom: 1.2rem;
}
.ff-news-card {
background: #fff;
border-radius: 1rem;
overflow: hidden;
border: 1px solid var(--ff-border);
height: 100%;
display: flex;
flex-direction: column;
transition: transform 0.35s ease, box-shadow 0.35s ease;
}
.ff-news-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-strong); }
.ff-news-card .news-img { aspect-ratio: 16/10; background-size: cover; background-position: center top; }
.ff-news-card .news-body { padding: 1.5rem; display: flex; flex-direction: column; gap: 0.75rem; flex: 1; }
.ff-news-card .news-tag {
font-size: 0.72rem; font-weight: 700; letter-spacing: 0.12em;
text-transform: uppercase; color: var(--ff-green);
}
.ff-news-card h5 { font-size: 1.15rem; line-height: 1.3; } .ff-timeline { position: relative; padding-left: 2.2rem; }
.ff-timeline::before {
content: ""; position: absolute; left: 0.55rem; top: 0.25rem; bottom: 0; width: 3px;
background: linear-gradient(180deg, var(--ff-green), var(--ff-yellow), var(--ff-blue));
border-radius: 3px;
}
.ff-timeline-item { position: relative; padding: 0 0 2.5rem 0; }
.ff-timeline-item::before {
content: ""; position: absolute; left: -2.05rem; top: 0.35rem; width: 18px; height: 18px;
border-radius: 50%; background: #fff; border: 4px solid var(--ff-green);
box-shadow: 0 0 0 4px rgba(30, 125, 47, 0.15);
}
.ff-timeline-year { font-family: "Manrope", sans-serif; font-weight: 800; color: var(--ff-green); font-size: 1.1rem; letter-spacing: 0.02em; } .ff-stat { padding: 1.5rem 0; }
.ff-stat .num {
font-family: "Manrope", sans-serif; font-weight: 900;
font-size: clamp(2.2rem, 4vw, 3.2rem);
background: var(--gradient-flag);
-webkit-background-clip: text; background-clip: text; color: transparent;
line-height: 1;
}
.ff-stat .label { color: rgba(255, 255, 255, 0.85); margin-top: 0.5rem; font-weight: 500; } .ff-cta {
background: var(--gradient-brand);
color: #fff;
border-radius: 1.5rem;
padding: 3.5rem;
position: relative;
overflow: hidden;
}
.ff-cta::after {
content: ""; position: absolute; right: -60px; top: -60px; width: 280px; height: 280px;
border-radius: 50%; background: var(--ff-yellow); opacity: 0.15;
} .ff-footer { background: var(--ff-blue-dark); color: rgba(255, 255, 255, 0.85); padding: 4rem 0 2rem; }
.ff-footer a { color: rgba(255, 255, 255, 0.85); text-decoration: none; }
.ff-footer a:hover { color: var(--ff-yellow); }
.ff-footer h6 { color: #fff; font-weight: 700; letter-spacing: 0.04em; } .ff-sticker-bar { display: flex; gap: 2rem; flex-wrap: wrap; align-items: center; justify-content: center; }
.ff-sticker-bar img {
max-height: 130px; width: auto;
transition: transform 0.3s ease;
filter: drop-shadow(0 8px 18px rgba(6, 31, 77, 0.18));
}
.ff-sticker-bar img:hover { transform: scale(1.05) rotate(-2deg); } .ff-causas {
position: relative; padding: 6rem 0; color: #fff; overflow: hidden;
background:
linear-gradient(135deg, rgba(6, 31, 77, 0.92) 0%, rgba(21, 90, 34, 0.88) 60%, rgba(11, 58, 140, 0.92) 100%),
radial-gradient(circle at 20% 30%, rgba(245, 197, 24, 0.25), transparent 50%), var(--ff-blue-dark);
}
.ff-causas h2, .ff-causas .ff-eyebrow { color: #fff; }
.ff-causas .ff-eyebrow { border-bottom-color: var(--ff-yellow); }
.ff-causas p { color: rgba(255, 255, 255, 0.85); } .reveal { opacity: 0; transform: translateY(28px); transition: opacity 0.9s ease, transform 0.9s ease; will-change: opacity, transform; }
.reveal.in-view { opacity: 1; transform: translateY(0); }
.reveal.delay-1 { transition-delay: 0.12s; }
.reveal.delay-2 { transition-delay: 0.24s; }
.reveal.delay-3 { transition-delay: 0.36s; }
.reveal.delay-4 { transition-delay: 0.48s; }
@keyframes ffFadeInUp {
from { opacity: 0; transform: translateY(24px); }
to { opacity: 1; transform: translateY(0); }
}
.ff-fade-in { animation: ffFadeInUp 0.9s ease both; }
.ff-fade-in.delay-1 { animation-delay: 0.15s; }
.ff-fade-in.delay-2 { animation-delay: 0.3s; }
.ff-fade-in.delay-3 { animation-delay: 0.45s; } .ff-page-header {
background: var(--gradient-brand);
color: #fff;
padding: 7rem 0 4rem;
position: relative;
overflow: hidden;
}
.ff-page-header h1 { color: #fff; font-size: clamp(2rem, 4vw, 3.4rem); }
.ff-page-header .breadcrumb-trail { color: rgba(255, 255, 255, 0.8); font-size: 0.9rem; letter-spacing: 0.05em; }
.ff-page-header .breadcrumb-trail a { color: rgba(255, 255, 255, 0.8); text-decoration: none; } .ff-article-body .lead { font-size: 1.25rem; font-weight: 500; color: var(--ff-ink); line-height: 1.7; margin-bottom: 2rem; }
.ff-article-body h2 { color: var(--ff-blue-dark); margin-top: 2.5rem; margin-bottom: 1rem; font-weight: 800; font-family: "Manrope", sans-serif; }
.ff-article-body p { color: var(--ff-muted); font-size: 1.1rem; line-height: 1.85; margin-bottom: 1.5rem; }
.ff-article-body blockquote {
border-left: 4px solid var(--ff-green);
padding: 0.5rem 0 0.5rem 1.5rem;
margin: 2.5rem 0;
font-style: italic; font-size: 1.3rem; color: var(--ff-blue-dark); font-weight: 500; line-height: 1.6;
}