/* ==========================================================================
   Facility Imóveis — Site público (redesign 2026)
   Estilo "tech + descontraído": base clara, hero escuro com gradiente,
   cards arredondados, microanimações. Autocontido e prefixado .fac-* para
   não conflitar com o tema legado (Content/Site.css). Carregado por último.
   ========================================================================== */

:root {
    /* Marca Facility: azul-navy predominante (com gradiente) + dourado de destaque */
    --fac-navy-900: #051e3e;   /* azul escuro principal */
    --fac-navy-800: #08335f;
    --fac-navy-700: #134a8f;
    --fac-indigo:   #0a3a73;   /* azul base */
    --fac-violet:   #4088fb;   /* azul vivo — realces/links/texto de destaque */
    --fac-magenta:  #4088fb;   /* azul vivo (fim do gradiente) */
    --fac-gold:     #eab63c;   /* dourado — só em texto e botões */
    --fac-gold-600: #d99a1f;

    --fac-grad-hero: radial-gradient(1100px 560px at 84% -12%, rgba(130,175,255,.26), transparent 62%),
                     radial-gradient(820px 460px at -4% 108%, rgba(64,136,251,.16), transparent 58%),
                     linear-gradient(155deg, #07233f 0%, #0c3257 56%, #123f6d 100%);
    --fac-grad-brand: linear-gradient(135deg, #0c3a6e 0%, #2f6fe0 55%, #4088fb 100%);
    --fac-grad-gold:  linear-gradient(135deg, #f5cd5e 0%, #eab63c 50%, #d99a1f 100%);

    /* Neutros claros */
    --fac-bg:      #f7f9fe;
    --fac-surface: #ffffff;
    --fac-ink:     #121831;
    --fac-ink-2:   #3a4258;
    --fac-muted:   #5b6480;
    --fac-line:    #e7eaf4;

    --fac-r-sm: 12px;
    --fac-r:    18px;
    --fac-r-lg: 28px;
    --fac-r-xl: 36px;

    --fac-shadow-sm: 0 4px 16px -6px rgba(18,24,49,.18);
    --fac-shadow:    0 18px 50px -18px rgba(18,24,49,.28);
    --fac-shadow-lg: 0 40px 90px -30px rgba(18,24,49,.40);
    --fac-shadow-brand: 0 18px 40px -14px rgba(27,93,192,.55);

    --fac-font: 'Poppins', 'Roboto', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* ----- Base / reset suave (escopo .fac-body) ----------------------------- */
body.fac-body {
    margin: 0;
    font-family: var(--fac-font);
    color: var(--fac-ink);
    background: var(--fac-bg);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
}

.fac-body * { box-sizing: border-box; }

.fac-body a { text-decoration: none; color: inherit; }
.fac-body img { max-width: 100%; display: block; }

.fac-container {
    width: 100%;
    max-width: 1180px;
    margin: 0 auto;
    padding: 0 24px;
}

.fac-section { padding: 96px 0; position: relative; }
.fac-section--sm { padding: 64px 0; }
.fac-section--tight { padding: 40px 0; }

html { scroll-behavior: smooth; }
.fac-body [id] { scroll-margin-top: 96px; }

/* ----- Tipografia helpers ------------------------------------------------ */
.fac-eyebrow {
    display: inline-flex; align-items: center; gap: 8px;
    font-size: 13px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase;
    color: var(--fac-violet);
    background: rgba(64,136,251,.10);
    border: 1px solid rgba(64,136,251,.22);
    padding: 7px 14px; border-radius: 999px;
}
.fac-eyebrow--light { color: #bcdcf5; background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.18); }

/* color: inherit => herdam a cor do contexto (clara sobre seções escuras,
   escura sobre seções claras) e vencem a regra legada h1..h6 { color:#29293a } */
.fac-h1 { font-size: clamp(2.3rem, 5vw, 3.6rem); line-height: 1.05; font-weight: 800; letter-spacing: -.02em; margin: 0; color: inherit; }
.fac-h2 { font-size: clamp(1.9rem, 3.6vw, 2.7rem); line-height: 1.12; font-weight: 800; letter-spacing: -.02em; margin: 0; color: inherit; }
.fac-h3 { font-size: 1.35rem; font-weight: 700; margin: 0; color: inherit; }
.fac-lead { font-size: clamp(1.02rem, 1.6vw, 1.18rem); line-height: 1.6; color: var(--fac-muted); margin: 16px 0 0; }
.fac-text-grad { background: var(--fac-grad-brand); -webkit-background-clip: text; background-clip: text; color: transparent; }
.fac-text-gold { background: var(--fac-grad-gold); -webkit-background-clip: text; background-clip: text; color: transparent; }

.fac-section-head { text-align: center; max-width: 720px; margin: 0 auto 56px; }
.fac-section-head .fac-lead { margin-top: 18px; }

/* ----- Botões ------------------------------------------------------------ */
.fac-btn {
    --b: transparent;
    display: inline-flex; align-items: center; justify-content: center; gap: 10px;
    font-family: var(--fac-font); font-weight: 600; font-size: 1rem; line-height: 1;
    padding: 15px 28px; border-radius: 999px; border: 1.5px solid var(--b);
    cursor: pointer; transition: transform .18s ease, box-shadow .25s ease, background .25s ease, color .2s ease;
    white-space: nowrap; text-align: center;
}
.fac-btn:hover { transform: translateY(-2px); }
.fac-btn:active { transform: translateY(0); }
.fac-btn--lg { padding: 18px 34px; font-size: 1.06rem; }
.fac-btn--block { width: 100%; }

.fac-btn--primary { background: linear-gradient(135deg, #4088fb 0%, #2a64d4 100%); color: #fff; box-shadow: 0 8px 20px -9px rgba(42,100,212,.5); }
.fac-btn--primary:hover { background: linear-gradient(135deg, #5096ff 0%, #3573e6 100%); box-shadow: 0 14px 26px -11px rgba(42,100,212,.55); }

.fac-btn--gold { background: var(--fac-grad-gold); color: #2a2200; box-shadow: 0 9px 22px -10px rgba(234,182,60,.5); }
.fac-btn--gold:hover { background: linear-gradient(135deg, #ffd968 0%, #f1be40 50%, #e2a615 100%); box-shadow: 0 15px 28px -10px rgba(234,182,60,.58); }

.fac-btn--light { background: #fff; color: var(--fac-navy-800); box-shadow: var(--fac-shadow-sm); }
.fac-btn--ghost { background: rgba(255,255,255,.08); color: #fff; --b: rgba(255,255,255,.3); backdrop-filter: blur(6px); }
.fac-btn--ghost:hover { background: rgba(255,255,255,.16); }
.fac-btn--outline { background: transparent; color: #2f6fe0; --b: rgba(64,136,251,.38); }
.fac-btn--outline:hover { background: rgba(64,136,251,.07); border-color: rgba(64,136,251,.6); }

/* ----- Navbar ------------------------------------------------------------ */
.fac-nav {
    position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
    transition: background .3s ease, box-shadow .3s ease, padding .3s ease, backdrop-filter .3s ease;
    padding: 14px 0;
    background: rgba(255,255,255,.85);
    backdrop-filter: saturate(160%) blur(14px);
    box-shadow: 0 6px 30px -18px rgba(18,24,49,.5);
    border-bottom: 1px solid var(--fac-line);
}
/* sobre o hero escuro (e no topo): transparente com texto claro */
.fac-nav.is-transparent {
    background: transparent; box-shadow: none; border-bottom-color: transparent; padding: 18px 0;
    backdrop-filter: none;
}
.fac-nav__inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.fac-nav__brand { display: inline-flex; align-items: center; gap: 10px; font-weight: 800; font-size: 1.15rem; color: var(--fac-ink); }
.fac-nav.is-transparent .fac-nav__brand { color: #fff; }
.fac-nav__logo {
    width: 40px; height: 40px; display: grid; place-items: center; color: var(--fac-gold); flex: 0 0 auto;
}
.fac-nav__logo svg { width: 100%; height: 100%; display: block; }
/* logos por contexto: clara (navy/preto) na nav sólida, escura (dourado/branco) sobre o hero.
   Seletores com 2 classes p/ vencer .fac-body img { display:block } (0,1,1) */
.fac-nav__logo-img { height: 40px; width: auto; flex: 0 0 auto; }
.fac-nav__logo-img.fac-logo-dark { display: none; }
.fac-nav__logo-img.fac-logo-light { display: block; }
.fac-nav.is-transparent .fac-nav__logo-img.fac-logo-dark { display: block; }
.fac-nav.is-transparent .fac-nav__logo-img.fac-logo-light { display: none; }
.fac-nav__links { display: flex; align-items: center; gap: 6px; margin: 0; padding: 0; list-style: none; }
.fac-nav__link {
    font-weight: 500; font-size: .96rem; color: var(--fac-muted);
    padding: 9px 16px; border-radius: 999px; transition: color .2s ease, background .2s ease;
}
.fac-nav__link:hover { color: var(--fac-ink); background: rgba(64,136,251,.08); }
.fac-nav.is-transparent .fac-nav__link { color: rgba(255,255,255,.85); }
.fac-nav.is-transparent .fac-nav__link:hover { color: #fff; background: rgba(255,255,255,.10); }
.fac-nav__actions { display: flex; align-items: center; gap: 12px; }
.fac-nav.is-transparent .fac-nav__actions .fac-btn--outline { color: #fff; --b: rgba(255,255,255,.4); }
.fac-nav__toggle { display: none; background: none; border: 0; cursor: pointer; padding: 8px; }
.fac-nav__toggle span { display: block; width: 24px; height: 2px; background: var(--fac-ink); border-radius: 2px; margin: 5px 0; transition: .25s; }
.fac-nav.is-transparent .fac-nav__toggle span { background: #fff; }

@media (max-width: 991px) {
    .fac-nav__toggle { display: block; }
    .fac-nav__menu {
        position: fixed; inset: 0 0 0 auto; width: min(320px, 84vw);
        background: #fff; box-shadow: var(--fac-shadow-lg);
        flex-direction: column; align-items: stretch; justify-content: flex-start;
        padding: 92px 24px 32px; gap: 14px;
        transform: translateX(110%); transition: transform .32s cubic-bezier(.4,0,.2,1);
        display: flex;
    }
    .fac-nav__menu.is-open { transform: translateX(0); }
    .fac-nav__links { flex-direction: column; align-items: stretch; gap: 4px; }
    .fac-nav__link { color: var(--fac-ink) !important; font-size: 1.05rem; padding: 12px 14px; }
    .fac-nav__actions { flex-direction: column; align-items: stretch; margin-top: 12px; }
    .fac-nav__backdrop { position: fixed; inset: 0; background: rgba(10,18,48,.45); opacity: 0; visibility: hidden; transition: .3s; z-index: 999; }
    .fac-nav__backdrop.is-open { opacity: 1; visibility: visible; }
}
.fac-nav__menu { display: flex; align-items: center; gap: 24px; }

/* ----- Hero -------------------------------------------------------------- */
.fac-hero {
    position: relative; overflow: hidden; color: #fff;
    background: var(--fac-grad-hero);
    padding: 168px 0 120px;
    border-radius: 0 0 var(--fac-r-xl) var(--fac-r-xl);
}
.fac-hero__grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 56px; align-items: center; }
.fac-hero__title { margin-top: 22px; }
.fac-hero__title span.fac-text-gold { display: inline-block; }
.fac-hero__lead { color: rgba(233,236,255,.82); max-width: 540px; }
.fac-hero__actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }

.fac-hero__stats { display: flex; gap: 36px; margin-top: 48px; flex-wrap: wrap; }
.fac-stat__num { font-size: 1.9rem; font-weight: 800; line-height: 1; background: var(--fac-grad-gold); -webkit-background-clip: text; background-clip: text; color: transparent; }
.fac-stat__label { font-size: .86rem; color: rgba(233,236,255,.7); margin-top: 6px; }

/* Visual flutuante (mock de aprovação) */
.fac-hero__visual { position: relative; display: grid; place-items: center; min-height: 360px; }
.fac-glasscard {
    position: relative; z-index: 2; width: min(360px, 100%);
    background: rgba(255,255,255,.10); border: 1px solid rgba(255,255,255,.20);
    border-radius: var(--fac-r-lg); padding: 26px; backdrop-filter: blur(16px);
    box-shadow: var(--fac-shadow-lg); animation: fac-float 6s ease-in-out infinite;
}
.fac-glasscard__row { display: flex; align-items: center; gap: 14px; }
.fac-glasscard__avatar { width: 46px; height: 46px; border-radius: 14px; background: var(--fac-grad-brand); display: grid; place-items: center; color: #fff; }
.fac-glasscard__name { font-weight: 700; }
.fac-glasscard__sub { font-size: .82rem; color: rgba(255,255,255,.7); }
.fac-glasscard__bar { height: 10px; border-radius: 999px; background: rgba(255,255,255,.16); margin-top: 18px; overflow: hidden; }
.fac-glasscard__bar > i { display: block; height: 100%; width: 86%; border-radius: 999px; background: linear-gradient(90deg, #4088fb, #8fc0ff); animation: fac-grow 2.4s ease forwards; }
.fac-glasscard__approved {
    margin-top: 20px; display: flex; align-items: center; gap: 10px;
    background: rgba(46,204,113,.16); border: 1px solid rgba(46,204,113,.35); color: #b8f5d0;
    padding: 12px 16px; border-radius: 14px; font-weight: 600; font-size: .92rem;
}
.fac-chip-float {
    position: absolute; z-index: 3; background: #fff; color: var(--fac-ink);
    border-radius: 16px; padding: 12px 16px; box-shadow: var(--fac-shadow-lg);
    display: flex; align-items: center; gap: 10px; font-weight: 600; font-size: .9rem;
}
.fac-chip-float--1 { top: 6%; left: -4%; animation: fac-float 5s ease-in-out infinite; }
.fac-chip-float--2 { bottom: 8%; right: -2%; animation: fac-float 7s ease-in-out infinite .6s; }
.fac-chip-float i { width: 30px; height: 30px; border-radius: 9px; display: grid; place-items: center; color: #fff; }

/* blobs decorativos */
.fac-blob { position: absolute; border-radius: 50%; filter: blur(10px); opacity: .5; pointer-events: none; }
.fac-blob--1 { width: 460px; height: 460px; top: -140px; right: -90px; background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.34), rgba(255,255,255,0) 70%); }
.fac-blob--2 { width: 380px; height: 380px; bottom: -150px; left: -100px; background: radial-gradient(circle at 30% 30%, rgba(135,180,255,.30), rgba(135,180,255,0) 70%); }

.fac-wave { position: absolute; left: 0; right: 0; bottom: -1px; width: 100%; display: block; }

/* ----- Sobre ------------------------------------------------------------- */
.fac-about__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.fac-about__media {
    position: relative; border-radius: var(--fac-r-lg); padding: 30px;
    background: var(--fac-grad-hero); color: #fff; box-shadow: var(--fac-shadow);
    overflow: hidden;
}
.fac-about__list { margin: 26px 0 0; padding: 0; list-style: none; display: grid; gap: 14px; }
.fac-about__list li { display: flex; gap: 12px; align-items: flex-start; color: var(--fac-ink); font-weight: 500; }
.fac-about__list .fac-check { flex: 0 0 auto; width: 26px; height: 26px; border-radius: 8px; background: rgba(46,204,113,.14); color: #1aa85a; display: grid; place-items: center; }
.fac-mini-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.fac-mini-stat { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.16); border-radius: var(--fac-r); padding: 20px; }
.fac-mini-stat b { font-size: 1.7rem; display: block; }
.fac-mini-stat span { font-size: .84rem; color: rgba(233,236,255,.75); }

/* ----- Como funciona (steps) -------------------------------------------- */
.fac-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; counter-reset: step; }
.fac-step {
    position: relative; background: var(--fac-surface); border: 1px solid var(--fac-line);
    border-radius: var(--fac-r-lg); padding: 32px 26px; transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.fac-step:hover { transform: translateY(-6px); box-shadow: var(--fac-shadow); border-color: transparent; }
.fac-step__icon {
    width: 58px; height: 58px; border-radius: 16px; display: grid; place-items: center; color: #2f6fe0;
    background: linear-gradient(160deg, #ffffff, rgba(64,136,251,.12)); border: 1px solid rgba(64,136,251,.16);
    box-shadow: 0 10px 24px -14px rgba(64,136,251,.35); margin-bottom: 18px;
}
.fac-step:nth-child(2) .fac-step__icon { color: #1b5dc0; }
.fac-step:nth-child(3) .fac-step__icon { color: #2f6fe0; }
.fac-step:nth-child(4) .fac-step__icon { color: #0c3a6e; }
.fac-step__num { position: absolute; top: 22px; right: 26px; font-size: 2.4rem; font-weight: 800; color: var(--fac-line); line-height: 1; }
.fac-step h3 { font-size: 1.12rem; margin-bottom: 8px; }
.fac-step p { color: var(--fac-muted); font-size: .94rem; line-height: 1.55; margin: 0; }

/* ----- Faixa CTA com vídeo ----------------------------------------------- */
.fac-videoband { position: relative; overflow: hidden; color: #fff; background: var(--fac-grad-hero); border-radius: var(--fac-r-xl); padding: 56px; box-shadow: var(--fac-shadow); }
.fac-videoband__grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 44px; align-items: center; }
.fac-video {
    position: relative; width: 100%; aspect-ratio: 16/9; border-radius: var(--fac-r); overflow: hidden;
    box-shadow: var(--fac-shadow-lg); border: 1px solid rgba(255,255,255,.18);
}
.fac-video iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }

/* ----- Cadastre-se (tabs + form) ----------------------------------------- */
.fac-formwrap { max-width: 760px; margin: 0 auto; }
.fac-tabs {
    display: inline-flex; padding: 6px; gap: 6px; margin: 0 auto 36px; border-radius: 999px;
    background: #eef0fa; border: 1px solid var(--fac-line);
}
.fac-tabs-center { text-align: center; }
.fac-tab {
    appearance: none; border: 0; background: transparent; cursor: pointer;
    font-family: var(--fac-font); font-weight: 600; font-size: .98rem; color: var(--fac-muted);
    padding: 12px 26px; border-radius: 999px; transition: .22s; display: inline-flex; align-items: center; gap: 8px;
}
.fac-tab.is-active { background: #fff; color: var(--fac-ink); box-shadow: var(--fac-shadow-sm); }

.fac-formcard {
    background: var(--fac-surface); border: 1px solid var(--fac-line);
    border-radius: var(--fac-r-lg); padding: 40px; box-shadow: var(--fac-shadow);
}
.fac-formcard__title { text-align: center; margin-bottom: 28px; }
.fac-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.fac-field { margin-bottom: 18px; }
.fac-field label, .fac-body .form-control-label { display: block; font-weight: 600; font-size: .9rem; color: var(--fac-ink); margin-bottom: 8px; }

/* inputs: estiliza .form-control (mantido para integração jQuery validate) */
.fac-body .fac-formcard .form-control,
.fac-body .fac-input,
.fac-body .fac-field .form-control {
    width: 100%; font-family: var(--fac-font); font-size: 1rem; color: var(--fac-ink);
    background: #f7f8fd; border: 1.5px solid var(--fac-line); border-radius: 14px;
    padding: 14px 16px; transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
.fac-body .fac-formcard .form-control:focus,
.fac-body .fac-input:focus,
.fac-body .fac-field .form-control:focus {
    outline: 0; background: #fff; border-color: var(--fac-violet);
    box-shadow: 0 0 0 4px rgba(64,136,251,.15);
}
.fac-body .fac-formcard .form-control.is-invalid,
.fac-body .fac-field .form-control.is-invalid { border-color: #e5484d; box-shadow: 0 0 0 4px rgba(229,72,77,.12); }
.fac-body .invalid-feedback { color: #e5484d; font-size: .82rem; margin-top: 6px; }

/* ----- Parceiros (carrossel de logos) ------------------------------------ */
.fac-partners { background: #fff; }
.fac-partner-logo { padding: 0 18px; }
.fac-partner-logo img { max-height: 70px; width: auto; margin: 0 auto; filter: grayscale(1); opacity: .65; transition: .25s; }
.fac-partner-logo img:hover { filter: grayscale(0); opacity: 1; transform: scale(1.04); }

/* cards de imobiliárias (página parceiras) */
.fac-imob-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; margin-top: 28px; }
.fac-imob-card {
    display: flex; gap: 20px; align-items: center;
    background: var(--fac-surface); border: 1px solid var(--fac-line); border-radius: var(--fac-r-lg);
    padding: 22px; transition: transform .22s ease, box-shadow .22s ease, border-color .22s;
}
.fac-imob-card:hover { transform: translateY(-4px); box-shadow: var(--fac-shadow); border-color: transparent; }
.fac-imob-card__logo { flex: 0 0 96px; width: 96px; height: 96px; border-radius: var(--fac-r); background: #f7f9fe; display: grid; place-items: center; overflow: hidden; }
.fac-imob-card__logo img { max-width: 80%; max-height: 80%; }
.fac-imob-card__body h3 { font-size: 1.1rem; margin-bottom: 6px; }
.fac-imob-card__body p { margin: 2px 0; color: var(--fac-muted); font-size: .92rem; }

.fac-filterbar { display: grid; grid-template-columns: 1fr 1fr auto; gap: 16px; align-items: end; background: #fff; border: 1px solid var(--fac-line); border-radius: var(--fac-r-lg); padding: 22px; box-shadow: var(--fac-shadow-sm); }

/* ----- Slider de imobiliárias (scroll-snap) ------------------------------ */
.fac-slider { position: relative; margin: 8px 0 8px; }
.fac-slider__track {
    display: flex; gap: 22px; overflow-x: auto; scroll-snap-type: x mandatory; scroll-behavior: smooth;
    padding: 10px 4px 26px; -ms-overflow-style: none; scrollbar-width: none;
}
.fac-slider__track::-webkit-scrollbar { display: none; }
.fac-slide { scroll-snap-align: start; flex: 0 0 320px; max-width: 86%; }
.fac-slider__nav {
    position: absolute; top: 42%; transform: translateY(-50%); width: 48px; height: 48px; border-radius: 50%;
    border: 1px solid var(--fac-line); background: #fff; box-shadow: var(--fac-shadow); display: grid; place-items: center;
    cursor: pointer; z-index: 4; color: var(--fac-navy-700); transition: background .2s, color .2s, border-color .2s, transform .2s;
}
.fac-slider__nav:hover { background: var(--fac-grad-brand); color: #fff; border-color: transparent; transform: translateY(-50%) scale(1.06); }
.fac-slider__nav--prev { left: -14px; }
.fac-slider__nav--next { right: -14px; }

.fac-pcard {
    display: block; background: #fff; border: 1px solid var(--fac-line); border-radius: var(--fac-r-lg);
    overflow: hidden; box-shadow: var(--fac-shadow-sm); transition: transform .25s ease, box-shadow .25s ease; height: 100%;
}
.fac-pcard:hover { transform: translateY(-6px); box-shadow: var(--fac-shadow); }
.fac-pcard__top { height: 96px; background: var(--fac-grad-hero); position: relative; }
.fac-pcard__logo {
    position: absolute; left: 50%; bottom: -38px; transform: translateX(-50%);
    width: 92px; height: 92px; border-radius: 22px; background: #fff; box-shadow: var(--fac-shadow-sm);
    display: grid; place-items: center; padding: 12px;
}
.fac-pcard__logo img { max-width: 100%; max-height: 100%; object-fit: contain; }
.fac-pcard__body { padding: 52px 24px 26px; text-align: center; }
.fac-pcard__body h3 { font-size: 1.14rem; margin: 0 0 12px; color: var(--fac-ink); }
.fac-pcard__meta { color: var(--fac-muted); font-size: .9rem; display: inline-flex; gap: 7px; align-items: center; justify-content: center; margin: 5px 0; }
.fac-pcard__meta svg { color: var(--fac-violet); flex: 0 0 auto; }
.fac-pcard__cta { display: inline-flex; align-items: center; gap: 6px; margin-top: 16px; color: var(--fac-violet); font-weight: 600; font-size: .92rem; }
.fac-pcard:hover .fac-pcard__cta { gap: 10px; }

@media (max-width: 640px) {
    .fac-slider__nav { display: none; }
    .fac-slide { flex-basis: 84%; }
}

/* ----- Página de sucesso (Obrigado) -------------------------------------- */
.fac-success { max-width: 640px; margin: 0 auto; text-align: center; }
.fac-success__badge {
    width: 96px; height: 96px; border-radius: 30px; margin: 0 auto 28px; display: grid; place-items: center; color: #fff;
    background: linear-gradient(135deg,#34d399,#10b981); box-shadow: 0 24px 50px -16px rgba(16,185,129,.6);
    animation: fac-pop .5s cubic-bezier(.2,.9,.3,1.4) both;
}
.fac-success__card { background: #fff; border: 1px solid var(--fac-line); border-radius: var(--fac-r-xl); padding: 56px 40px; box-shadow: var(--fac-shadow); }

/* ----- Footer ------------------------------------------------------------ */
.fac-footer { background: var(--fac-navy-900); color: rgba(233,236,255,.78); padding: 72px 0 28px; position: relative; overflow: hidden; }
.fac-footer .fac-blob { opacity: .35; }
.fac-footer__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 40px; position: relative; z-index: 1; }
.fac-footer__brand { display: inline-flex; align-items: center; gap: 12px; color: #fff; font-weight: 800; font-size: 1.3rem; margin-bottom: 18px; }
.fac-footer p { line-height: 1.6; font-size: .94rem; max-width: 320px; color: rgba(233,236,255,.78); }
.fac-footer h5 { color: #fff; font-size: .82rem; letter-spacing: .14em; text-transform: uppercase; margin: 0 0 20px; }
.fac-footer__contact { list-style: none; margin: 0; padding: 0; display: grid; gap: 14px; }
.fac-footer__contact li { display: flex; gap: 12px; align-items: flex-start; font-size: .94rem; }
.fac-footer__contact .fac-ic { flex: 0 0 auto; width: 34px; height: 34px; border-radius: 10px; background: rgba(255,255,255,.08); display: grid; place-items: center; color: #4088fb; }
.fac-footer__contact a:hover { color: #fff; }
.fac-socials { display: flex; gap: 12px; margin-top: 22px; }
.fac-socials a { width: 42px; height: 42px; border-radius: 12px; background: rgba(255,255,255,.08); display: grid; place-items: center; color: #fff; transition: .22s; }
.fac-socials a:hover { background: var(--fac-grad-brand); transform: translateY(-3px); box-shadow: var(--fac-shadow-brand); }
.fac-footer__bottom { position: relative; z-index: 1; margin-top: 52px; padding-top: 24px; border-top: 1px solid rgba(255,255,255,.10); display: flex; justify-content: space-between; align-items: center; gap: 16px; flex-wrap: wrap; font-size: .88rem; }
.fac-footer__bottom .fac-dev { display: inline-flex; align-items: center; gap: 8px; }
.fac-footer__bottom .fac-dev img { height: 16px; display: inline-block; filter: brightness(0) invert(1); opacity: .8; }

/* ----- Login ------------------------------------------------------------- */
.fac-login { min-height: 100vh; display: grid; grid-template-columns: 1.05fr 1fr; background: var(--fac-bg); }
.fac-login__aside { position: relative; overflow: hidden; color: #fff; background: var(--fac-grad-hero); padding: 64px; display: flex; flex-direction: column; justify-content: space-between; }
.fac-login__aside .fac-brand { display: inline-flex; align-items: center; gap: 12px; font-weight: 800; font-size: 1.25rem; }
.fac-login__pitch h2 { font-size: clamp(1.8rem, 3vw, 2.6rem); font-weight: 800; line-height: 1.1; color: inherit; }
.fac-login__card h1 { color: var(--fac-ink); }
.fac-login__pitch p { color: rgba(233,236,255,.8); margin-top: 14px; max-width: 420px; }
.fac-login__main { display: grid; place-items: center; padding: 40px 24px; }
.fac-login__card { width: min(440px, 100%); }
/* no desktop o painel lateral já mostra a marca; a logo do card aparece só no mobile (aside escondido) */
.fac-login__card .fac-login__logo { display: none; height: 50px; width: auto; margin-bottom: 26px; }
.fac-login__card h1 { font-size: 1.7rem; font-weight: 800; margin: 0 0 6px; }
.fac-login__card .fac-muted { color: var(--fac-muted); margin: 0 0 28px; }
.fac-login__card .form-control { width: 100%; font-family: var(--fac-font); font-size: 1rem; background: #f7f8fd; border: 1.5px solid var(--fac-line); border-radius: 14px; padding: 14px 16px; margin-bottom: 4px; }
.fac-login__card .form-control:focus { outline: 0; background: #fff; border-color: var(--fac-violet); box-shadow: 0 0 0 4px rgba(64,136,251,.15); }
.fac-login__foot { text-align: center; margin-top: 22px; }
.fac-login__foot a { color: var(--fac-violet); font-weight: 600; }

/* overrides do template argon do <formulario-login> dentro do card */
.fac-login__card .input-group {
    display: flex; align-items: stretch; width: 100%;
    background: #f7f8fd; border: 1.5px solid var(--fac-line); border-radius: 14px;
    overflow: hidden; transition: border-color .2s ease, box-shadow .2s ease, background .2s ease; margin-bottom: 16px;
}
.fac-login__card .input-group:focus-within { background: #fff; border-color: var(--fac-violet); box-shadow: 0 0 0 4px rgba(64,136,251,.15); }
.fac-login__card .input-group-text { display: grid; place-items: center; padding: 0 14px; background: transparent; border: 0; color: var(--fac-muted); }
.fac-login__card .input-group .form-control { border: 0 !important; background: transparent !important; box-shadow: none !important; margin: 0; padding: 14px 14px 14px 0; flex: 1; }
.fac-login__card .form-check { display: flex; align-items: center; gap: 8px; margin: 6px 0 4px; }
.fac-login__card .btn-primary {
    width: 100%; border: 0; cursor: pointer; color: #fff; font-family: var(--fac-font); font-weight: 600; font-size: 1rem;
    padding: 15px 24px; border-radius: 999px; background: linear-gradient(135deg, #4088fb 0%, #2a64d4 100%); box-shadow: 0 8px 20px -9px rgba(42,100,212,.5);
    transition: transform .18s ease, box-shadow .25s ease, background .25s ease;
}
.fac-login__card .btn-primary:hover { transform: translateY(-2px); background: linear-gradient(135deg, #5096ff 0%, #3573e6 100%); box-shadow: 0 14px 26px -11px rgba(42,100,212,.55); }
.fac-login__card .btn-primary.error { background: linear-gradient(135deg,#e5484d,#c2333a); box-shadow: none; }
.fac-login__card .my-4 { margin-top: 22px !important; margin-bottom: 0 !important; }

@media (max-width: 900px) {
    .fac-login { grid-template-columns: 1fr; }
    .fac-login__aside { display: none; }
    .fac-login__card .fac-login__logo { display: block; }
}

/* ----- Animações --------------------------------------------------------- */
@keyframes fac-float { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-14px); } }
@keyframes fac-grow { from { width: 0; } }
@keyframes fac-pop { from { transform: scale(.6); opacity: 0; } to { transform: scale(1); opacity: 1; } }

[data-fac-reveal] { opacity: 0; transform: translateY(28px); transition: opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
[data-fac-reveal].is-visible { opacity: 1; transform: none; }
[data-fac-reveal][data-delay="1"] { transition-delay: .08s; }
[data-fac-reveal][data-delay="2"] { transition-delay: .16s; }
[data-fac-reveal][data-delay="3"] { transition-delay: .24s; }
@media (prefers-reduced-motion: reduce) {
    [data-fac-reveal] { opacity: 1; transform: none; transition: none; }
    .fac-glasscard, .fac-chip-float { animation: none; }
    html { scroll-behavior: auto; }
}

/* ----- Responsivo -------------------------------------------------------- */
@media (max-width: 991px) {
    .fac-section { padding: 72px 0; }
    .fac-hero { padding: 130px 0 90px; }
    .fac-hero__grid { grid-template-columns: 1fr; gap: 40px; text-align: center; }
    .fac-hero__lead { margin-left: auto; margin-right: auto; }
    .fac-hero__actions, .fac-hero__stats { justify-content: center; }
    .fac-about__grid { grid-template-columns: 1fr; gap: 36px; }
    .fac-steps { grid-template-columns: repeat(2, 1fr); }
    .fac-videoband { padding: 40px 28px; }
    .fac-videoband__grid { grid-template-columns: 1fr; gap: 28px; }
    .fac-imob-grid { grid-template-columns: 1fr; }
    .fac-footer__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
    .fac-container { padding: 0 18px; }
    .fac-section { padding: 60px 0; }
    .fac-steps { grid-template-columns: 1fr; }
    .fac-grid-2 { grid-template-columns: 1fr; }
    .fac-formcard { padding: 26px 20px; }
    .fac-footer__grid { grid-template-columns: 1fr; }
    .fac-footer__bottom { flex-direction: column; text-align: center; }
    .fac-tabs { display: flex; width: 100%; }
    .fac-tab { flex: 1; justify-content: center; padding: 12px 10px; }
}
