/* =====================================================================
   FacileApp — Département SFAV
   Design system moderne · Rouge dominant · Mode clair/sombre
   Auteur : refonte 2026 — self-contained (n'écrase pas le template)
   ===================================================================== */

/* ---------- Design tokens ---------- */
:root{
  --brand:        #d40b12;
  --brand-600:    #b8080f;
  --brand-700:    #950208;
  --brand-400:    #ef2a35;
  --brand-300:    #ff6a72;
  --brand-glow:   rgba(212, 11, 18, .35);
  --brand-soft:   rgba(212, 11, 18, .08);

  --bg:           #ffffff;
  --bg-soft:      #f6f7fb;
  --bg-elev:      #ffffff;
  --surface:      #ffffff;
  --surface-2:    #f9fafc;
  --text:         #12141b;
  --heading:      #0b0d13;
  --muted:        #5a6273;
  --border:       #e7e9f1;
  --border-strong:#d6d9e4;
  --shadow:       0 10px 40px -12px rgba(18, 20, 27, .18);
  --shadow-sm:    0 4px 18px -8px rgba(18, 20, 27, .22);
  --ring:         rgba(212, 11, 18, .28);

  --radius:       18px;
  --radius-sm:    12px;
  --radius-pill:  999px;
  --container:    1200px;
  --nav-h:        72px;

  --font-head: "Poppins", "Segoe UI", system-ui, -apple-system, sans-serif;
  --font-body: "Open Sans", "Segoe UI", system-ui, -apple-system, sans-serif;

  --grad-brand: linear-gradient(135deg, var(--brand-400) 0%, var(--brand-700) 100%);
  --grad-dark:  linear-gradient(150deg, #1a0305 0%, #2a060a 45%, #12141b 100%);
}

html[data-theme="dark"]{
  --bg:           #0c0d12;
  --bg-soft:      #10121a;
  --bg-elev:      #14161f;
  --surface:      #161923;
  --surface-2:    #1b1f2b;
  --text:         #e9ebf2;
  --heading:      #ffffff;
  --muted:        #9aa2b4;
  --border:       #252a37;
  --border-strong:#323848;
  --shadow:       0 20px 50px -18px rgba(0,0,0,.65);
  --shadow-sm:    0 8px 26px -14px rgba(0,0,0,.7);
  --brand-soft:   rgba(212, 11, 18, .16);
}

/* ---------- Base ---------- */
html{scroll-behavior:smooth;}
body.fa-modern{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  transition:background .35s ease, color .35s ease;
}
.fa-modern *{box-sizing:border-box;}
.fa-modern h1,.fa-modern h2,.fa-modern h3,.fa-modern h4,.fa-modern h5{
  font-family:var(--font-head);
  color:var(--heading);
  line-height:1.15;
  margin:0 0 .5em;
  font-weight:700;
  letter-spacing:-.02em;
}
.fa-modern p{margin:0 0 1rem;color:var(--text);}
.fa-modern a{color:var(--brand);text-decoration:none;transition:color .2s;}
.fa-modern a:hover{color:var(--brand-600);}
.fa-modern img{max-width:100%;height:auto;display:block;}
.fa-modern ul{margin:0;padding:0;list-style:none;}
.fa-modern section{position:relative;}

.fa-container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:24px;}
.fa-section{padding:96px 0;}
.fa-section.alt{background:var(--bg-soft);}
@media(max-width:768px){.fa-section{padding:64px 0;}}

/* ---------- Section headings ---------- */
.fa-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-head);font-weight:600;font-size:.78rem;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--brand);background:var(--brand-soft);
  padding:7px 14px;border-radius:var(--radius-pill);margin-bottom:18px;
}
.fa-eyebrow i{font-size:1rem;}
.fa-head{max-width:720px;}
.fa-head.center{margin-inline:auto;text-align:center;}
.fa-head h2{font-size:clamp(1.8rem,4vw,2.7rem);margin-bottom:.4em;}
.fa-head p{color:var(--muted);font-size:1.05rem;}

/* ---------- Buttons ---------- */
.fa-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--font-head);font-weight:600;font-size:.98rem;
  padding:13px 26px;border-radius:var(--radius-pill);
  border:1.5px solid transparent;cursor:pointer;
  transition:transform .2s, box-shadow .25s, background .2s, color .2s, border-color .2s;
  white-space:nowrap;text-align:center;
}
.fa-btn i{font-size:1.15em;}
/* NB : sélecteurs préfixés .fa-modern pour battre `.fa-modern a` (sinon texte rouge invisible sur bouton rouge) */
.fa-modern .fa-btn-primary{background:var(--grad-brand);color:#fff;box-shadow:0 12px 30px -10px var(--brand-glow);}
.fa-modern .fa-btn-primary:hover{color:#fff;transform:translateY(-2px);box-shadow:0 18px 36px -10px var(--brand-glow);}
.fa-modern .fa-btn-ghost{background:transparent;color:var(--text);border-color:var(--border-strong);}
.fa-modern .fa-btn-ghost:hover{color:var(--brand);border-color:var(--brand);background:var(--brand-soft);}
.fa-modern .fa-btn-dark{background:var(--heading);color:var(--bg);}
html[data-theme="dark"] .fa-modern .fa-btn-dark{background:#fff;color:#111;}
.fa-modern .fa-btn-dark:hover{transform:translateY(-2px);}
.fa-btn-sm{padding:9px 18px;font-size:.9rem;}
.fa-modern .fa-btn-white{background:#fff;color:var(--brand-700);}
.fa-modern .fa-btn-white:hover{color:var(--brand-700);transform:translateY(-2px);}
.fa-modern .fa-btn-outline-white{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.5);}
.fa-modern .fa-btn-outline-white:hover{background:#fff;color:var(--brand-700);}

/* ---------- Header / Navbar (style SFAV) ---------- */
.fa-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);
  display:flex;align-items:center;
  background:var(--bg);
  background:color-mix(in srgb, var(--bg) 78%, transparent);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid transparent;
  transition:background .3s, border-color .3s, box-shadow .3s;
}
.fa-header.scrolled{
  background:var(--bg);
  background:color-mix(in srgb, var(--bg) 92%, transparent);
  border-bottom-color:var(--border);
  box-shadow:var(--shadow-sm);
}
.fa-nav{display:flex;align-items:center;justify-content:space-between;gap:20px;width:100%;}
.fa-modern .fa-brand{display:flex;align-items:center;gap:11px;font-family:var(--font-head);font-weight:800;font-size:1.28rem;color:var(--heading);letter-spacing:-.02em;}
.fa-modern .fa-brand:hover{color:var(--heading);}
.fa-brand img{width:40px;height:40px;object-fit:contain;filter:drop-shadow(0 4px 10px var(--brand-glow));}
.fa-brand span b{color:var(--brand);}
.fa-brand small{display:block;font-size:.6rem;font-weight:600;letter-spacing:.22em;color:var(--muted);text-transform:uppercase;margin-top:-2px;}

.fa-menu{display:flex;align-items:center;gap:4px;}
.fa-menu a{
  font-family:var(--font-head);font-weight:500;font-size:.95rem;color:var(--text);
  padding:9px 14px;border-radius:10px;position:relative;transition:color .2s,background .2s;
}
.fa-menu a:hover,.fa-menu a.active{color:var(--brand);background:var(--brand-soft);}

.fa-nav-actions{display:flex;align-items:center;gap:10px;}

/* Theme toggle */
.fa-theme-toggle{
  width:42px;height:42px;flex:0 0 42px;border-radius:50%;
  display:grid;place-items:center;cursor:pointer;
  background:var(--surface-2);border:1px solid var(--border);color:var(--text);
  transition:background .2s,color .2s,transform .3s,border-color .2s;
}
.fa-theme-toggle:hover{color:var(--brand);border-color:var(--brand);transform:rotate(18deg);}
.fa-theme-toggle i{font-size:1.3rem;}
.fa-theme-toggle .icon-sun{display:none;}
html[data-theme="dark"] .fa-theme-toggle .icon-sun{display:block;}
html[data-theme="dark"] .fa-theme-toggle .icon-moon{display:none;}

/* Mobile burger */
.fa-burger{display:none;width:44px;height:44px;border-radius:12px;background:var(--surface-2);border:1px solid var(--border);color:var(--text);cursor:pointer;place-items:center;}
.fa-burger i{font-size:1.6rem;}

/* Mobile drawer */
.fa-drawer-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);opacity:0;visibility:hidden;transition:.3s;z-index:1099;backdrop-filter:blur(2px);}
.fa-drawer{
  position:fixed;top:0;right:0;height:100%;width:min(340px,86vw);z-index:1100;
  background:var(--bg-elev);border-left:1px solid var(--border);
  transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;padding:22px;box-shadow:var(--shadow);overflow-y:auto;
}
body.fa-drawer-open .fa-drawer{transform:translateX(0);}
body.fa-drawer-open .fa-drawer-backdrop{opacity:1;visibility:visible;}
.fa-drawer-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.fa-drawer-close{width:42px;height:42px;border-radius:12px;background:var(--surface-2);border:1px solid var(--border);color:var(--text);cursor:pointer;display:grid;place-items:center;}
.fa-drawer-close i{font-size:1.5rem;}
.fa-drawer-label{font-family:var(--font-head);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin:18px 0 6px;}
.fa-drawer nav{display:flex;flex-direction:column;}
.fa-drawer nav a{font-family:var(--font-head);font-weight:500;font-size:1.05rem;color:var(--text);padding:14px 12px;border-radius:12px;border-bottom:1px solid var(--border);}
.fa-drawer nav a:hover{background:var(--brand-soft);color:var(--brand);}
.fa-drawer-cta{display:flex;flex-direction:column;gap:10px;margin-top:22px;}
.fa-drawer-cta .fa-btn{width:100%;}

@media(max-width:992px){
  .fa-menu,.fa-nav-actions .fa-desktop-only{display:none;}
  .fa-burger{display:grid;}
}

/* ---------- Hero ---------- */
.fa-hero{
  position:relative;padding:calc(var(--nav-h) + 70px) 0 90px;overflow:hidden;
  background:
    radial-gradient(1100px 520px at 78% -10%, var(--brand-soft), transparent 60%),
    radial-gradient(760px 420px at 8% 8%, var(--brand-soft), transparent 55%),
    var(--bg);
}
html[data-theme="dark"] .fa-hero{
  background:
    radial-gradient(1100px 560px at 80% -12%, rgba(212,11,18,.22), transparent 60%),
    radial-gradient(760px 440px at 5% 10%, rgba(212,11,18,.14), transparent 55%),
    var(--bg);
}
.fa-hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;}
.fa-hero h1{font-size:clamp(2.1rem,5.2vw,3.7rem);line-height:1.06;margin-bottom:.35em;}
.fa-hero h1 .hl{background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.fa-hero .lead{font-size:1.15rem;color:var(--muted);max-width:560px;margin-bottom:26px;}
.fa-hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:26px;}
.fa-hero-trust{display:flex;align-items:center;gap:22px;flex-wrap:wrap;color:var(--muted);font-size:.9rem;}
.fa-hero-trust .item{display:flex;align-items:center;gap:8px;}
.fa-hero-trust i{color:var(--brand);font-size:1.15rem;}

.fa-hero-visual{position:relative;}
.fa-hero-visual .glow{position:absolute;inset:-10% -6%;background:radial-gradient(circle at 60% 40%,var(--brand-glow),transparent 65%);filter:blur(10px);z-index:0;}
.fa-hero-card{
  position:relative;z-index:1;background:var(--surface);border:1px solid var(--border);
  border-radius:24px;box-shadow:var(--shadow);padding:22px;
}
.fa-hero-card img{border-radius:14px;width:100%;}
@media(max-width:992px){
  .fa-hero-grid{grid-template-columns:1fr;gap:40px;text-align:center;}
  .fa-hero .lead{margin-inline:auto;}
  .fa-hero-cta,.fa-hero-trust{justify-content:center;}
}

/* ---------- Store badges ---------- */
.fa-stores{display:flex;flex-wrap:wrap;gap:12px;}
.fa-modern .fa-store-badge{
  display:inline-flex;align-items:center;gap:12px;
  background:var(--heading);color:var(--bg);
  padding:10px 20px 10px 16px;border-radius:14px;min-width:180px;
  transition:transform .2s,box-shadow .25s;box-shadow:var(--shadow-sm);
}
html[data-theme="dark"] .fa-modern .fa-store-badge{background:#fff;color:#0b0d13;border:1px solid #fff;}
.fa-modern .fa-store-badge:hover{transform:translateY(-3px);color:var(--bg);}
html[data-theme="dark"] .fa-modern .fa-store-badge:hover{color:#0b0d13;}
.fa-store-badge i{font-size:2rem;line-height:1;}
.fa-store-badge .txt{display:flex;flex-direction:column;line-height:1.15;font-family:var(--font-head);}
.fa-store-badge .txt small{font-size:.62rem;letter-spacing:.06em;opacity:.75;text-transform:uppercase;}
.fa-store-badge .txt b{font-size:1.05rem;font-weight:700;}

/* ---------- Stats ---------- */
.fa-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.fa-stat{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:28px 24px;text-align:center;box-shadow:var(--shadow-sm);
}
.fa-stat .num{font-family:var(--font-head);font-weight:800;font-size:2.3rem;background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1;}
.fa-stat .lbl{color:var(--muted);font-size:.92rem;margin-top:6px;}
@media(max-width:768px){.fa-stats{grid-template-columns:repeat(2,1fr);}}

/* ---------- App showcase (CNDCI / SYGBank) ---------- */
.fa-showcase{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.fa-showcase.reverse .media{order:-1;}
.fa-showcase + .fa-showcase{margin-top:88px;}
.fa-app-tag{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-head);font-weight:700;color:var(--brand);margin-bottom:14px;font-size:.95rem;letter-spacing:.04em;}
.fa-app-tag img{width:34px;height:34px;border-radius:9px;object-fit:cover;}
.fa-showcase h3{font-size:clamp(1.5rem,3vw,2.1rem);}
.fa-showcase .desc{color:var(--muted);font-size:1.05rem;margin-bottom:20px;}
.fa-feature-list{display:grid;gap:12px;margin-bottom:26px;}
.fa-feature-list li{display:flex;gap:12px;align-items:flex-start;color:var(--text);}
.fa-feature-list i{color:var(--brand);font-size:1.3rem;flex:0 0 auto;margin-top:1px;}
.fa-showcase .media{position:relative;}
.fa-showcase .media .frame{background:var(--surface);border:1px solid var(--border);border-radius:22px;padding:16px;box-shadow:var(--shadow);}
.fa-showcase .media .frame img{border-radius:12px;width:100%;}
.fa-showcase .media .halo{position:absolute;inset:-8%;background:radial-gradient(circle,var(--brand-glow),transparent 68%);z-index:-1;filter:blur(8px);}
@media(max-width:900px){
  .fa-showcase{grid-template-columns:1fr;gap:34px;}
  .fa-showcase.reverse .media{order:0;}
}

/* ---------- Feature cards ---------- */
.fa-grid{display:grid;gap:22px;}
.fa-grid.cols-3{grid-template-columns:repeat(3,1fr);}
.fa-grid.cols-4{grid-template-columns:repeat(4,1fr);}
@media(max-width:900px){.fa-grid.cols-3,.fa-grid.cols-4{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.fa-grid.cols-3,.fa-grid.cols-4{grid-template-columns:1fr;}}

.fa-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:30px 26px;box-shadow:var(--shadow-sm);
  transition:transform .25s, box-shadow .3s, border-color .25s;
  position:relative;overflow:hidden;
}
.fa-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:color-mix(in srgb,var(--brand) 40%, var(--border));}
.fa-card .ic{
  width:56px;height:56px;border-radius:15px;display:grid;place-items:center;
  background:var(--brand-soft);color:var(--brand);font-size:1.7rem;margin-bottom:18px;
}
.fa-card h4{font-size:1.2rem;margin-bottom:8px;}
.fa-card p{color:var(--muted);font-size:.96rem;margin-bottom:0;}
.fa-card .more{display:inline-flex;align-items:center;gap:6px;margin-top:14px;font-family:var(--font-head);font-weight:600;font-size:.9rem;}
.fa-card .more i{transition:transform .2s;}
.fa-card:hover .more i{transform:translateX(4px);}
.fa-card img.logo{width:64px;height:64px;object-fit:contain;border-radius:14px;margin-bottom:16px;}

/* ---------- Sector pills ---------- */
.fa-pills{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;}
.fa-pill{
  display:inline-flex;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--border);
  padding:11px 20px;border-radius:var(--radius-pill);font-family:var(--font-head);font-weight:500;font-size:.95rem;
  color:var(--text);transition:.2s;box-shadow:var(--shadow-sm);
}
.fa-pill i{color:var(--brand);font-size:1.2rem;}
.fa-pill:hover{border-color:var(--brand);color:var(--brand);transform:translateY(-2px);}

/* ---------- Steps ---------- */
.fa-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:step;}
@media(max-width:900px){.fa-steps{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.fa-steps{grid-template-columns:1fr;}}
.fa-step{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px 24px;box-shadow:var(--shadow-sm);position:relative;}
.fa-step .n{width:44px;height:44px;border-radius:12px;background:var(--grad-brand);color:#fff;display:grid;place-items:center;font-family:var(--font-head);font-weight:700;font-size:1.2rem;margin-bottom:16px;}
.fa-step h4{font-size:1.1rem;margin-bottom:6px;}
.fa-step p{color:var(--muted);font-size:.94rem;margin-bottom:0;}

/* ---------- Testimonials / clients (swiper reuse) ---------- */
.fa-modern .testimonials .testimonial-item{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:30px 24px;text-align:center;box-shadow:var(--shadow-sm);margin:10px;
}
.fa-modern .testimonials .testimonial-img{width:96px;height:96px;object-fit:contain;border-radius:16px;margin:0 auto 14px;background:var(--surface-2);padding:8px;border:1px solid var(--border);}
.fa-modern .testimonials h3{font-size:1.15rem;margin-bottom:4px;}
.fa-modern .testimonials h4{font-size:.86rem;color:var(--muted);font-weight:500;font-family:var(--font-body);}
.fa-modern .swiper-pagination-bullet{background:var(--muted);}
.fa-modern .swiper-pagination-bullet-active{background:var(--brand);}

/* ---------- CTA band ---------- */
.fa-cta{position:relative;overflow:hidden;border-radius:28px;padding:64px 40px;text-align:center;color:#fff;background:var(--grad-dark);border:1px solid rgba(255,255,255,.08);}
.fa-cta::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 300px at 50% -20%,var(--brand-glow),transparent 60%);}
.fa-cta > *{position:relative;z-index:1;}
.fa-cta h2{color:#fff;font-size:clamp(1.7rem,4vw,2.6rem);}
.fa-cta p{color:rgba(255,255,255,.82);max-width:640px;margin:0 auto 26px;}
.fa-cta .fa-hero-cta{justify-content:center;}

/* ---------- Contact ---------- */
.fa-contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:34px;}
@media(max-width:900px){.fa-contact-grid{grid-template-columns:1fr;}}
.fa-info-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 22px;display:flex;gap:16px;align-items:flex-start;box-shadow:var(--shadow-sm);margin-bottom:16px;}
.fa-info-card .ic{width:48px;height:48px;flex:0 0 48px;border-radius:12px;background:var(--brand-soft);color:var(--brand);display:grid;place-items:center;font-size:1.4rem;}
.fa-info-card h4{font-size:1rem;margin-bottom:2px;}
.fa-info-card p{margin:0;color:var(--muted);font-size:.95rem;}
.fa-map{border:0;width:100%;height:100%;min-height:340px;border-radius:var(--radius);filter:grayscale(.15);}

/* ---------- Prose (à propos, cours, légal) ---------- */
.fa-prose{max-width:860px;margin-inline:auto;}
.fa-prose h3{font-size:1.4rem;margin:1.6em 0 .5em;}
.fa-prose h4{font-size:1.1rem;margin:1.4em 0 .4em;color:var(--brand);}
.fa-prose p,.fa-prose li{color:var(--text);}
.fa-prose ul,.fa-prose ol{padding-left:1.3em;margin:0 0 1.2em;}
.fa-prose ul li,.fa-prose ol li{list-style:inherit;margin-bottom:.5em;}
.fa-prose ul{list-style:disc;}
.fa-prose ol{list-style:decimal;}
.fa-values{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin:1em 0;}
@media(max-width:640px){.fa-values{grid-template-columns:1fr;}}
.fa-value{display:flex;gap:13px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:18px;box-shadow:var(--shadow-sm);}
.fa-value i{color:var(--brand);font-size:1.5rem;flex:0 0 auto;}
.fa-value b{display:block;color:var(--heading);font-family:var(--font-head);margin-bottom:2px;}
.fa-value span{color:var(--muted);font-size:.93rem;}

/* Page hero (inner pages) */
.fa-page-hero{padding:calc(var(--nav-h) + 56px) 0 44px;text-align:center;background:radial-gradient(900px 320px at 50% -20%,var(--brand-soft),transparent 60%),var(--bg);}
.fa-page-hero h1{font-size:clamp(1.9rem,4.5vw,3rem);}
.fa-page-hero p{color:var(--muted);max-width:640px;margin:0 auto;font-size:1.05rem;}
.fa-crumbs{display:flex;gap:8px;justify-content:center;align-items:center;font-size:.85rem;color:var(--muted);margin-bottom:14px;}
.fa-crumbs a{color:var(--muted);}
.fa-crumbs a:hover{color:var(--brand);}

/* ---------- Footer ---------- */
.fa-footer{background:var(--bg-soft);border-top:1px solid var(--border);color:var(--text);padding:64px 0 0;}
.fa-footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.3fr;gap:34px;padding-bottom:44px;}
@media(max-width:900px){.fa-footer-grid{grid-template-columns:1fr 1fr;gap:28px;}}
@media(max-width:560px){.fa-footer-grid{grid-template-columns:1fr;}}
.fa-footer h4{font-size:1rem;margin-bottom:16px;font-family:var(--font-head);}
.fa-footer .brand-blk .fa-brand{margin-bottom:14px;}
.fa-footer p{color:var(--muted);font-size:.94rem;}
.fa-footer ul li{margin-bottom:10px;}
.fa-footer ul a{color:var(--muted);font-size:.94rem;display:inline-flex;align-items:center;gap:7px;}
.fa-footer ul a:hover{color:var(--brand);}
.fa-footer ul a i{color:var(--brand);}
.fa-newsletter form{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap;}
.fa-newsletter input[type=tel]{flex:1;min-width:0;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px 14px;color:var(--text);font-family:var(--font-body);}
.fa-newsletter input[type=tel]:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--ring);}
.fa-newsletter input[type=submit]{background:var(--grad-brand);color:#fff;border:0;border-radius:12px;padding:12px 20px;font-family:var(--font-head);font-weight:600;cursor:pointer;}
.fa-socials{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap;}
.fa-socials a{width:40px;height:40px;border-radius:11px;background:var(--surface);border:1px solid var(--border);display:grid;place-items:center;color:var(--text);font-size:1.25rem;transition:.2s;}
.fa-socials a:hover{background:var(--brand);color:#fff;border-color:var(--brand);transform:translateY(-2px);}
.fa-footer-bottom{border-top:1px solid var(--border);padding:22px 0;display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;}
.fa-footer-bottom p{margin:0;font-size:.88rem;color:var(--muted);}
.fa-footer-bottom .legal{display:flex;gap:18px;flex-wrap:wrap;}

/* ---------- Floating WhatsApp ---------- */
.fa-modern .fa-wa{position:fixed;right:22px;bottom:22px;z-index:900;width:58px;height:58px;border-radius:50%;background:var(--grad-brand);color:#fff;display:grid;place-items:center;font-size:1.9rem;box-shadow:0 12px 30px -8px var(--brand-glow);transition:transform .2s;animation:fa-pulse 2.4s infinite;}
.fa-modern .fa-wa:hover{transform:scale(1.08);color:#fff;}
@keyframes fa-pulse{0%{box-shadow:0 0 0 0 rgba(212,11,18,.5);}70%{box-shadow:0 0 0 16px rgba(212,11,18,0);}100%{box-shadow:0 0 0 0 rgba(212,11,18,0);}}

/* ---------- Reveal on scroll ---------- */
.fa-reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1);}
.fa-reveal.in{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){.fa-reveal{opacity:1;transform:none;transition:none;}html{scroll-behavior:auto;}}
