/* ═══════════════════════════════════════════════════════
   France Démarche Ltd — Design System v2
   Bleu marine + accent rouge français — minimaliste pro
═══════════════════════════════════════════════════════ */

:root{
  --navy:#0A2540;
  --navy-dark:#061629;
  --navy-soft:#1E3A5F;
  --navy-line:#E5EAF1;
  --red:#D90012;
  --red-dark:#A8000E;
  --red-soft:#FFF1F2;
  --gold:#C9A86A;
  --bg:#FFFFFF;
  --bg-soft:#F6F8FB;
  --bg-card:#FFFFFF;
  --text:#0F1B2D;
  --text-soft:#4A5568;
  --muted:#8895A7;
  --border:#E6EAF0;
  --green:#25D366;
  --green-dark:#1DA851;
  --shadow-sm:0 1px 3px rgba(10,37,64,.06), 0 1px 2px rgba(10,37,64,.04);
  --shadow:0 4px 24px rgba(10,37,64,.08);
  --shadow-lg:0 12px 48px rgba(10,37,64,.12);
  --shadow-red:0 6px 24px rgba(217,0,18,.28);
  --radius:14px;
  --radius-sm:8px;
  --radius-lg:20px;
  --maxw:1200px;
  --transition:.2s cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:80px}
body{
  font-family:'Inter','Segoe UI',system-ui,-apple-system,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.65;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none;transition:color var(--transition)}
img,svg{max-width:100%;display:block}
ul{list-style:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* ═══ TYPOGRAPHIE ═══ */
h1,h2,h3,h4{
  font-family:'Playfair Display','Georgia',serif;
  font-weight:700;
  letter-spacing:-.02em;
  line-height:1.15;
  color:var(--navy);
}
h1{font-size:clamp(2rem,5.2vw,3.5rem);font-weight:800}
h2{font-size:clamp(1.65rem,3.6vw,2.5rem)}
h3{font-size:clamp(1.15rem,2vw,1.4rem);line-height:1.3}
h4{font-size:1.05rem;line-height:1.4}
p{color:var(--text-soft)}
.lead{font-size:clamp(1.05rem,1.8vw,1.2rem);color:var(--text-soft);line-height:1.7}
strong{color:var(--text);font-weight:600}

/* ═══ LAYOUT ═══ */
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:80px 0;position:relative}
.section-alt{background:var(--bg-soft)}
.section-navy{background:var(--navy);color:#fff}
.section-navy h1,.section-navy h2,.section-navy h3{color:#fff}
.section-navy p{color:rgba(255,255,255,.78)}
.section-head{max-width:760px;margin:0 auto 56px;text-align:center}
.section-head.left{text-align:left;margin-left:0}
.section-label{
  display:inline-block;
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--red);
  background:var(--red-soft);
  padding:6px 14px;
  border-radius:100px;
  margin-bottom:18px;
}
.section-navy .section-label{background:rgba(217,0,18,.18);color:#FFB1B7}
.section-title{margin-bottom:14px}
.section-sub{font-size:1.08rem;color:var(--text-soft);max-width:620px;margin:0 auto}
.section-head.left .section-sub{margin:0}

/* ═══ BOUTONS ═══ */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:52px;
  padding:0 28px;
  border-radius:10px;
  font-weight:600;
  font-size:.97rem;
  font-family:inherit;
  white-space:nowrap;
  transition:all var(--transition);
  cursor:pointer;
  text-align:center;
}
.btn svg{width:18px;height:18px;flex-shrink:0}
.btn-primary{background:var(--red);color:#fff;box-shadow:var(--shadow-red)}
.btn-primary:hover{background:var(--red-dark);transform:translateY(-2px);box-shadow:0 10px 32px rgba(217,0,18,.36)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-wa{background:var(--green);color:#fff;box-shadow:0 6px 20px rgba(37,211,102,.32)}
.btn-wa:hover{background:var(--green-dark);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--navy);border:1.5px solid var(--border)}
.btn-outline:hover{border-color:var(--navy);background:var(--navy);color:#fff}
.btn-ghost{background:transparent;color:var(--navy)}
.btn-ghost:hover{background:var(--bg-soft)}
.btn-w{width:100%}

/* ═══ HEADER ═══ */
.site-header{
  position:sticky;
  top:0;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--border);
  z-index:100;
  transition:box-shadow var(--transition);
}
.site-header.scrolled{box-shadow:var(--shadow-sm)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px;gap:24px}
.brand{display:flex;align-items:center;gap:12px}
.brand-logo{width:40px;height:40px;flex-shrink:0}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-name{font-family:'Playfair Display',serif;font-weight:700;font-size:1.15rem;color:var(--navy);letter-spacing:-.01em}
.brand-tag{font-size:.7rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;font-weight:500}
.nav-main{display:flex;align-items:center;gap:4px}
.nav-main a{
  padding:10px 14px;
  font-size:.93rem;
  font-weight:500;
  color:var(--text);
  border-radius:8px;
  transition:all var(--transition);
}
.nav-main a:hover{background:var(--bg-soft);color:var(--navy)}
.nav-main a.active{color:var(--red)}
.nav-cta{display:flex;align-items:center;gap:10px}
.header-call{
  display:flex;
  align-items:center;
  gap:10px;
  padding:0 18px;
  height:42px;
  border-radius:8px;
  background:var(--red);
  color:#fff;
  font-weight:600;
  font-size:.92rem;
  box-shadow:0 4px 14px rgba(217,0,18,.25);
  transition:all var(--transition);
}
.header-call:hover{background:var(--red-dark);transform:translateY(-1px)}
.header-call svg{width:16px;height:16px}

/* Burger */
.burger{
  display:none;
  width:42px;
  height:42px;
  align-items:center;
  justify-content:center;
  border-radius:8px;
  border:1px solid var(--border);
}
.burger span{display:block;width:20px;height:2px;background:var(--navy);position:relative}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--navy);transition:transform var(--transition)}
.burger span::before{top:-6px}
.burger span::after{top:6px}
.burger.open span{background:transparent}
.burger.open span::before{transform:rotate(45deg) translate(4px,4px)}
.burger.open span::after{transform:rotate(-45deg) translate(4px,-4px)}

.mobile-nav{
  display:none;
  position:fixed;
  top:72px;
  left:0;
  right:0;
  background:#fff;
  border-bottom:1px solid var(--border);
  box-shadow:var(--shadow);
  padding:16px 24px 24px;
  z-index:99;
  max-height:calc(100vh - 72px);
  overflow-y:auto;
}
.mobile-nav.open{display:block}
.mobile-nav a{display:block;padding:14px 12px;font-weight:500;color:var(--text);border-bottom:1px solid var(--border)}
.mobile-nav a:last-of-type{border:none}
.mobile-nav .btn{margin-top:16px}

/* ═══ HERO ═══ */
.hero{position:relative;padding:80px 0 90px;background:linear-gradient(180deg,#fff 0%,var(--bg-soft) 100%);overflow:hidden}
.hero::before{
  content:"";
  position:absolute;
  top:-100px;
  right:-200px;
  width:600px;
  height:600px;
  background:radial-gradient(circle,rgba(217,0,18,.06) 0%,transparent 70%);
  pointer-events:none;
}
.hero::after{
  content:"";
  position:absolute;
  bottom:-150px;
  left:-150px;
  width:500px;
  height:500px;
  background:radial-gradient(circle,rgba(10,37,64,.05) 0%,transparent 70%);
  pointer-events:none;
}
.hero-inner{position:relative;display:grid;grid-template-columns:1fr;gap:60px;align-items:center;z-index:1}
.hero-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 14px;
  border-radius:100px;
  background:#fff;
  border:1px solid var(--border);
  font-size:.82rem;
  font-weight:500;
  color:var(--navy);
  margin-bottom:24px;
  box-shadow:var(--shadow-sm);
}
.hero-eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px rgba(37,211,102,.18)}
.hero h1{margin-bottom:20px}
.hero h1 .accent{color:var(--red);position:relative;display:inline-block}
.hero h1 .accent::after{
  content:"";
  position:absolute;
  bottom:.05em;
  left:0;
  right:0;
  height:.12em;
  background:rgba(217,0,18,.15);
  z-index:-1;
}
.hero-sub{font-size:1.1rem;color:var(--text-soft);margin-bottom:32px;max-width:560px;line-height:1.7}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:36px}
.hero-trust{display:flex;flex-wrap:wrap;gap:24px;align-items:center}
.trust-item{display:flex;align-items:center;gap:8px;font-size:.88rem;color:var(--text-soft);font-weight:500}
.trust-item svg{width:18px;height:18px;color:var(--green);flex-shrink:0}

.hero-visual{
  position:relative;
  background:#fff;
  border-radius:var(--radius-lg);
  padding:32px;
  box-shadow:var(--shadow-lg);
  border:1px solid var(--border);
}
.hero-card-stat{
  display:flex;
  align-items:center;
  gap:16px;
  padding:16px;
  background:var(--bg-soft);
  border-radius:var(--radius-sm);
  margin-bottom:14px;
}
.hero-card-stat:last-child{margin-bottom:0}
.stat-icon{
  width:48px;
  height:48px;
  border-radius:12px;
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--red);
  flex-shrink:0;
  box-shadow:var(--shadow-sm);
}
.stat-icon svg{width:22px;height:22px}
.stat-body strong{display:block;font-size:1.5rem;font-weight:700;color:var(--navy);font-family:'Playfair Display',serif;line-height:1}
.stat-body span{display:block;font-size:.82rem;color:var(--text-soft);margin-top:4px}

/* ═══ SERVICES GRID ═══ */
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
.service-card{
  background:#fff;
  padding:32px 28px;
  border-radius:var(--radius);
  border:1px solid var(--border);
  transition:all var(--transition);
  position:relative;
  display:flex;
  flex-direction:column;
}
.service-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-lg);
  border-color:transparent;
}
.svc-icon{
  width:52px;
  height:52px;
  border-radius:12px;
  background:var(--red-soft);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--red);
  margin-bottom:20px;
}
.svc-icon svg{width:24px;height:24px}
.service-card h3{margin-bottom:10px;color:var(--navy)}
.service-card p{font-size:.95rem;line-height:1.65;margin-bottom:18px;flex-grow:1}
.svc-link{
  display:inline-flex;
  align-items:center;
  gap:6px;
  color:var(--red);
  font-weight:600;
  font-size:.9rem;
  margin-top:auto;
}
.svc-link svg{width:14px;height:14px;transition:transform var(--transition)}
.service-card:hover .svc-link svg{transform:translateX(4px)}

/* ═══ WHY US ═══ */
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}
.why-card{
  background:#fff;
  padding:28px;
  border-radius:var(--radius);
  border:1px solid var(--border);
  transition:all var(--transition);
}
.why-card:hover{box-shadow:var(--shadow);border-color:transparent}
.why-icon{
  width:44px;
  height:44px;
  border-radius:10px;
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-soft) 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  margin-bottom:18px;
}
.why-icon svg{width:20px;height:20px}
.why-card h3{margin-bottom:8px;font-size:1.1rem}
.why-card p{font-size:.93rem;line-height:1.6}

/* ═══ PROCESS / STEPS ═══ */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;position:relative}
.step{
  background:#fff;
  padding:32px 28px;
  border-radius:var(--radius);
  border:1px solid var(--border);
  position:relative;
}
.step-num{
  position:absolute;
  top:-16px;
  left:28px;
  width:40px;
  height:40px;
  border-radius:10px;
  background:var(--red);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  font-family:'Playfair Display',serif;
  font-size:1.15rem;
  box-shadow:var(--shadow-red);
}
.step h3{margin:14px 0 10px;font-size:1.15rem}
.step p{font-size:.94rem;line-height:1.65}

/* ═══ TESTIMONIALS ═══ */
.testi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:24px}
.testi-card{
  background:#fff;
  padding:32px 28px;
  border-radius:var(--radius);
  border:1px solid var(--border);
  position:relative;
}
.testi-card::before{
  content:"\201C";
  position:absolute;
  top:14px;
  right:20px;
  font-family:'Playfair Display',serif;
  font-size:4.5rem;
  color:var(--red-soft);
  line-height:1;
}
.stars{color:var(--gold);font-size:1rem;letter-spacing:2px;margin-bottom:14px}
.testi-card blockquote{font-size:.97rem;line-height:1.7;color:var(--text);margin-bottom:24px;font-style:italic}
.testi-author{display:flex;align-items:center;gap:14px}
.testi-avatar{
  width:46px;
  height:46px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  font-weight:700;
  font-family:'Playfair Display',serif;
  font-size:1.1rem;
  flex-shrink:0;
}
.testi-avatar.av1{background:linear-gradient(135deg,#D90012,#A8000E)}
.testi-avatar.av2{background:linear-gradient(135deg,#0A2540,#1E3A5F)}
.testi-avatar.av3{background:linear-gradient(135deg,#C9A86A,#A88848)}
.testi-author strong{display:block;color:var(--navy);font-size:.95rem;font-weight:600}
.testi-author span{display:block;font-size:.8rem;color:var(--muted);margin-top:2px}

/* ═══ FAQ ═══ */
.faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  transition:all var(--transition);
}
.faq-item:hover{border-color:#D5DCE6}
.faq-q{
  width:100%;
  padding:22px 26px;
  text-align:left;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  font-weight:600;
  font-size:1.02rem;
  color:var(--navy);
}
.faq-icon{
  width:28px;
  height:28px;
  border-radius:50%;
  background:var(--bg-soft);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  font-style:normal;
  color:var(--red);
  font-weight:700;
  font-size:1.1rem;
  transition:transform var(--transition);
}
.faq-q.open .faq-icon{transform:rotate(45deg);background:var(--red);color:#fff}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-a.open{max-height:400px}
.faq-a p{padding:0 26px 22px;font-size:.95rem;line-height:1.7;color:var(--text-soft)}

/* ═══ CONTACT ═══ */
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-bottom:36px}
.contact-card{
  background:#fff;
  padding:30px 26px;
  border-radius:var(--radius);
  border:1px solid var(--border);
  text-align:center;
  transition:all var(--transition);
}
.contact-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.contact-icon{
  width:56px;
  height:56px;
  margin:0 auto 18px;
  border-radius:14px;
  background:var(--red-soft);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--red);
}
.contact-icon svg{width:26px;height:26px}
.contact-card h3{margin-bottom:10px;font-size:1.1rem}
.contact-card a{color:var(--navy);font-weight:600;font-size:1.02rem;display:block;margin-bottom:6px;transition:color var(--transition)}
.contact-card a:hover{color:var(--red)}
.contact-card .hours{font-size:.85rem;color:var(--muted)}
.contact-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;max-width:560px;margin:0 auto}

/* ═══ PAGE HEADER (sub-pages) ═══ */
.page-header{
  padding:60px 0 40px;
  background:linear-gradient(180deg,var(--bg-soft) 0%,#fff 100%);
  border-bottom:1px solid var(--border);
}
.breadcrumb{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  font-size:.85rem;
  color:var(--muted);
  margin-bottom:18px;
}
.breadcrumb a{color:var(--muted);transition:color var(--transition)}
.breadcrumb a:hover{color:var(--red)}
.breadcrumb svg{width:12px;height:12px;color:var(--muted)}
.breadcrumb [aria-current]{color:var(--navy);font-weight:500}
.page-header h1{margin-bottom:14px}
.page-header .lead{max-width:720px}

/* ═══ ARTICLE / SERVICE PAGE ═══ */
.article{padding:60px 0 90px}
.article-grid{display:grid;grid-template-columns:1fr;gap:40px;max-width:1100px;margin:0 auto}
.article-main h2{margin:42px 0 16px;font-size:1.7rem}
.article-main h2:first-child{margin-top:0}
.article-main h3{margin:28px 0 12px;font-size:1.25rem;color:var(--navy)}
.article-main p{margin-bottom:18px;font-size:1.02rem;line-height:1.75}
.article-main ul,.article-main ol{margin:0 0 22px 22px}
.article-main li{margin-bottom:10px;font-size:1rem;color:var(--text-soft);line-height:1.7}
.article-main li::marker{color:var(--red)}
.article-main strong{color:var(--navy)}

.checklist{list-style:none;margin-left:0!important}
.checklist li{
  position:relative;
  padding-left:34px;
  margin-bottom:14px!important;
}
.checklist li::before{
  content:"";
  position:absolute;
  left:0;
  top:6px;
  width:22px;
  height:22px;
  border-radius:50%;
  background:var(--red-soft) url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg' stroke='%23D90012' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") no-repeat center/13px;
}

.info-box{
  background:linear-gradient(135deg,var(--bg-soft) 0%,#fff 100%);
  border:1px solid var(--border);
  border-left:4px solid var(--red);
  padding:24px 28px;
  border-radius:var(--radius-sm);
  margin:28px 0;
}
.info-box h4{margin-bottom:8px;color:var(--navy)}
.info-box p{margin:0;font-size:.95rem}

.cta-block{
  background:var(--navy);
  color:#fff;
  padding:44px 32px;
  border-radius:var(--radius);
  text-align:center;
  margin:48px 0;
}
.cta-block h3{color:#fff;font-size:1.5rem;margin-bottom:10px}
.cta-block p{color:rgba(255,255,255,.78);margin-bottom:24px;font-size:1rem}
.cta-block .btn-group{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}

/* Sidebar (services list, contact) */
.sidebar{display:flex;flex-direction:column;gap:24px;position:sticky;top:96px}
.sidebar-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:24px;
}
.sidebar-card h4{margin-bottom:14px;font-size:1.05rem;padding-bottom:12px;border-bottom:1px solid var(--border)}
.sidebar-card ul{display:flex;flex-direction:column;gap:2px}
.sidebar-card a{
  display:flex;
  align-items:center;
  gap:8px;
  padding:10px 12px;
  border-radius:8px;
  font-size:.92rem;
  color:var(--text);
  transition:all var(--transition);
}
.sidebar-card a:hover{background:var(--bg-soft);color:var(--red)}
.sidebar-card a.active{background:var(--red-soft);color:var(--red);font-weight:600}
.sidebar-card a svg{width:14px;height:14px;flex-shrink:0;color:var(--muted)}
.sidebar-card a.active svg{color:var(--red)}
.sidebar-cta{
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-soft) 100%);
  color:#fff;
  padding:24px;
  border-radius:var(--radius);
  text-align:center;
}
.sidebar-cta h4{color:#fff;margin-bottom:8px}
.sidebar-cta p{color:rgba(255,255,255,.78);font-size:.88rem;margin-bottom:16px}
.sidebar-cta .btn{width:100%;font-size:.9rem}

/* ═══ FOOTER ═══ */
.site-footer{
  background:var(--navy-dark);
  color:rgba(255,255,255,.7);
  padding:64px 0 0;
  font-size:.92rem;
}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-brand .brand{margin-bottom:18px}
.footer-brand .brand-name{color:#fff}
.footer-brand .brand-tag{color:rgba(255,255,255,.55)}
.footer-brand p{color:rgba(255,255,255,.62);font-size:.88rem;line-height:1.7;margin-bottom:18px}
.footer-col h5{
  color:#fff;
  font-family:'Inter',sans-serif;
  font-size:.82rem;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  margin-bottom:18px;
}
.footer-col ul{display:flex;flex-direction:column;gap:10px}
.footer-col a{color:rgba(255,255,255,.7);font-size:.92rem;transition:color var(--transition)}
.footer-col a:hover{color:#fff}
.footer-contact li{display:flex;gap:10px;align-items:flex-start;line-height:1.55}
.footer-contact svg{width:16px;height:16px;color:var(--red);flex-shrink:0;margin-top:3px}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);
  padding:24px 0;
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:16px;
  font-size:.82rem;
  color:rgba(255,255,255,.5);
}
.footer-bottom .legal-links{display:flex;flex-wrap:wrap;gap:20px}
.footer-bottom a{color:rgba(255,255,255,.6)}
.footer-bottom a:hover{color:#fff}

/* ═══ MOBILE BAR (FIXED BOTTOM) ═══ */
.mobile-bar{
  display:none;
  position:fixed;
  bottom:0;left:0;right:0;
  background:#fff;
  border-top:1px solid var(--border);
  padding:10px 12px calc(10px + env(safe-area-inset-bottom));
  z-index:90;
  box-shadow:0 -4px 24px rgba(10,37,64,.08);
  gap:10px;
}
.mobile-bar a{
  flex:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:10px 6px;
  border-radius:10px;
  color:#fff;
  font-size:.78rem;
  font-weight:600;
  line-height:1.2;
}
.mobile-bar a svg{width:18px;height:18px;margin-bottom:4px}
.mb-call{background:var(--red)}
.mb-wa{background:var(--green)}
.mb-num{font-size:.7rem;opacity:.9;font-weight:500;margin-top:2px}

/* ═══ COOKIE BAR ═══ */
.cookie-bar{
  position:fixed;
  bottom:24px;
  left:24px;
  right:24px;
  max-width:480px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:22px 24px;
  box-shadow:var(--shadow-lg);
  z-index:200;
  transform:translateY(160%);
  transition:transform .4s cubic-bezier(.4,0,.2,1);
}
.cookie-bar.show{transform:translateY(0)}
.cookie-bar h4{margin-bottom:8px;font-size:1rem;color:var(--navy)}
.cookie-bar p{font-size:.85rem;line-height:1.55;margin-bottom:14px}
.cookie-bar a{color:var(--red);text-decoration:underline}
.cookie-btns{display:flex;gap:10px}
.cookie-btns button{
  flex:1;
  padding:10px 16px;
  border-radius:8px;
  font-weight:600;
  font-size:.88rem;
  transition:all var(--transition);
}
.cookie-accept{background:var(--red);color:#fff}
.cookie-accept:hover{background:var(--red-dark)}
.cookie-refuse{background:var(--bg-soft);color:var(--text)}
.cookie-refuse:hover{background:var(--border)}

/* ═══ LANDING (ADS) ═══ */
.landing-body{background:linear-gradient(180deg,#fff 0%,var(--bg-soft) 100%);min-height:100vh}
.landing-header{padding:24px 0;border-bottom:1px solid var(--border);background:#fff}
.landing-header .header-inner{height:auto}
.landing-trust-row{
  background:var(--navy);
  color:#fff;
  padding:10px 0;
  font-size:.85rem;
  text-align:center;
}
.landing-trust-row strong{color:#fff;font-weight:600}
.landing-hero{padding:50px 0 30px}
.landing-hero-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:center}
.landing-form-card{
  background:#fff;
  padding:32px;
  border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  border-top:5px solid var(--red);
}
.landing-form-card h3{margin-bottom:8px;font-size:1.4rem}
.landing-form-card p{margin-bottom:24px;font-size:.95rem}
.landing-cta-stack{display:flex;flex-direction:column;gap:12px}
.landing-cta-stack .btn{min-height:60px;font-size:1.05rem}
.landing-cta-stack .or{text-align:center;color:var(--muted);font-size:.85rem;font-weight:500;position:relative;margin:4px 0}
.landing-cta-stack .or::before,.landing-cta-stack .or::after{content:"";position:absolute;top:50%;width:38%;height:1px;background:var(--border)}
.landing-cta-stack .or::before{left:0}
.landing-cta-stack .or::after{right:0}
.landing-bullets{display:flex;flex-direction:column;gap:14px;margin-top:24px}
.landing-bullets li{
  display:flex;
  align-items:flex-start;
  gap:12px;
  font-size:.95rem;
  line-height:1.55;
  color:var(--text);
}
.landing-bullets svg{width:22px;height:22px;color:var(--green);flex-shrink:0;margin-top:1px}

/* ═══ UTILS ═══ */
.text-center{text-align:center}
.mt-0{margin-top:0!important}
.mb-0{margin-bottom:0!important}
.divider{height:1px;background:var(--border);margin:48px 0}

/* ═══ RESPONSIVE — desktop up ═══ */
@media (min-width:760px){
  .hero-inner{grid-template-columns:1.05fr .95fr}
}
@media (min-width:980px){
  .article-grid{grid-template-columns:1fr 320px}
}

/* ═══ TABLET ≤ 880px ═══ */
@media (max-width:880px){
  .nav-main,.header-call{display:none}
  .burger{display:flex}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  .footer-brand{grid-column:1/-1}
  .landing-hero-grid{grid-template-columns:1fr;gap:32px}
  body{padding-bottom:88px}
  .mobile-bar{display:flex}
  .site-footer{padding-bottom:96px}
  .hero-visual{padding:22px;margin-top:24px}
  .stat-body strong{font-size:1.25rem}
  .section-head{margin-bottom:40px}
  .why-grid,.services-grid,.testi-grid{gap:14px}
  .sidebar{position:static;top:auto}
  html{scroll-padding-top:64px}
}

/* ═══ MOBILE ≤ 640px ═══ */
@media (max-width:640px){
  body{font-size:15.5px;line-height:1.6}
  .container{padding:0 16px}
  .section{padding:48px 0}
  .section-alt{padding:48px 0}
  .section-head{margin-bottom:32px}
  .section-label{font-size:.72rem;padding:5px 11px;margin-bottom:14px}
  .lead{font-size:1rem;line-height:1.6}

  /* Header compact */
  .site-header{border-bottom-width:1px}
  .header-inner{height:60px;gap:12px}
  .brand-logo{width:34px;height:34px}
  .brand-name{font-size:1rem}
  .brand-tag{font-size:.62rem;letter-spacing:.08em}
  .burger{width:38px;height:38px}
  .mobile-nav{top:60px}
  html{scroll-padding-top:70px}

  /* Hero */
  .hero{padding:30px 0 50px}
  .hero h1{font-size:1.85rem;line-height:1.18;margin-bottom:14px}
  .hero-eyebrow{font-size:.74rem;padding:6px 11px;margin-bottom:16px;gap:6px}
  .hero-eyebrow .dot{width:6px;height:6px;box-shadow:0 0 0 3px rgba(37,211,102,.2)}
  .hero-sub{font-size:.97rem;margin-bottom:22px;line-height:1.6}
  .hero-actions{flex-direction:column;gap:10px;margin-bottom:24px}
  .hero-actions .btn{width:100%;min-height:54px;font-size:1rem}
  .hero-trust{gap:14px}
  .trust-item{font-size:.78rem}
  .trust-item svg{width:15px;height:15px}
  .hero-visual{padding:18px;border-radius:14px}
  .hero-card-stat{padding:12px;gap:12px;margin-bottom:10px}
  .stat-icon{width:40px;height:40px}
  .stat-icon svg{width:18px;height:18px}
  .stat-body strong{font-size:1.15rem}
  .stat-body span{font-size:.74rem;margin-top:2px}

  /* Headings */
  h1{font-size:1.85rem}
  h2{font-size:1.5rem;line-height:1.2}
  h3{font-size:1.05rem}

  /* Page header (sub-pages) */
  .page-header{padding:36px 0 28px}
  .breadcrumb{font-size:.78rem;margin-bottom:14px}

  /* Cards & grids — single column with tighter padding */
  .services-grid,.why-grid,.testi-grid,.steps,.contact-grid{grid-template-columns:1fr;gap:12px}
  .service-card,.why-card,.step,.testi-card,.contact-card{padding:22px 20px}
  .service-card{border-radius:12px}
  .service-card h3{font-size:1.08rem;margin-bottom:8px}
  .service-card p{font-size:.9rem;line-height:1.55;margin-bottom:14px}
  .svc-icon{width:44px;height:44px;margin-bottom:14px}
  .svc-icon svg{width:20px;height:20px}
  .why-icon{width:38px;height:38px;margin-bottom:14px}
  .why-card h3{font-size:1rem}
  .why-card p{font-size:.88rem}

  /* Step process */
  .step{padding:24px 20px 20px}
  .step-num{top:-14px;left:20px;width:34px;height:34px;font-size:1rem}
  .step h3{margin:10px 0 8px}
  .step p{font-size:.88rem}

  /* Testimonials */
  .testi-card{padding:24px 20px}
  .testi-card::before{font-size:3.2rem;top:8px;right:14px}
  .testi-card blockquote{font-size:.92rem;margin-bottom:18px}
  .testi-avatar{width:40px;height:40px;font-size:.95rem}

  /* FAQ */
  .faq-q{padding:18px 20px;font-size:.95rem;gap:12px;min-height:60px}
  .faq-icon{width:26px;height:26px;font-size:1rem}
  .faq-a p{padding:0 20px 18px;font-size:.9rem}

  /* Buttons — touch target ≥ 48px */
  .btn{min-height:50px;padding:0 22px;font-size:.95rem;border-radius:10px}

  /* Article content */
  .article{padding:36px 0 56px}
  .article-grid{gap:28px}
  .article-main h2{font-size:1.4rem;margin:32px 0 12px}
  .article-main h3{font-size:1.1rem;margin:22px 0 10px}
  .article-main p{font-size:.96rem;margin-bottom:14px;line-height:1.65}
  .article-main ul,.article-main ol{margin-left:18px}
  .article-main li{font-size:.94rem;margin-bottom:8px}
  .checklist li{padding-left:30px;margin-bottom:10px!important}
  .checklist li::before{width:20px;height:20px;background-size:11px}
  .info-box{padding:18px 20px;margin:22px 0}
  .cta-block{padding:32px 22px;margin:32px 0}
  .cta-block h3{font-size:1.2rem}
  .cta-block p{font-size:.95rem;margin-bottom:18px}
  .cta-block .btn-group .btn{width:100%}

  /* Contact */
  .contact-card{padding:24px 20px}
  .contact-icon{width:48px;height:48px;margin-bottom:14px}
  .contact-actions .btn{width:100%}

  /* Sidebar (becomes inline on mobile) */
  .sidebar-card{padding:20px}
  .sidebar-card a{padding:12px 10px;font-size:.9rem;min-height:44px}
  .sidebar-cta{padding:20px}

  /* Landing pages */
  .landing-trust-row{font-size:.78rem;padding:9px 0;line-height:1.4}
  .landing-trust-row .container{padding:0 14px}
  .landing-header{padding:14px 0}
  .landing-hero{padding:24px 0 14px}
  .landing-hero-grid{gap:24px}
  .landing-form-card{padding:24px 20px;border-top-width:4px;border-radius:12px}
  .landing-form-card h3{font-size:1.15rem;margin-bottom:6px}
  .landing-form-card p{font-size:.9rem;margin-bottom:18px}
  .landing-cta-stack .btn{min-height:54px;font-size:1rem}
  .landing-bullets li{font-size:.9rem;gap:10px}
  .landing-bullets svg{width:18px;height:18px}

  /* Section navy */
  .section-navy{padding:48px 0}

  /* Footer */
  .site-footer{padding:44px 0 0;font-size:.88rem}
  .footer-grid{grid-template-columns:1fr;gap:28px;margin-bottom:28px}
  .footer-brand p{font-size:.85rem}
  .footer-col h5{font-size:.78rem;margin-bottom:12px}
  .footer-col ul{gap:8px}
  .footer-col a{font-size:.88rem}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:10px;padding:18px 0;font-size:.76rem;text-align:left}
  .footer-bottom .legal-links{gap:14px}

  /* Mobile bar — larger touch targets */
  .mobile-bar{padding:8px 8px calc(8px + env(safe-area-inset-bottom));gap:8px}
  .mobile-bar a{padding:8px 4px;min-height:62px;border-radius:10px}
  .mobile-bar a svg{width:20px;height:20px;margin-bottom:2px}
  .mb-num{font-size:.66rem}
  .mobile-bar a span{font-size:.78rem;font-weight:700}

  /* Cookie bar */
  .cookie-bar{bottom:90px;left:12px;right:12px;padding:18px 18px;border-radius:12px}
  .cookie-bar h4{font-size:.95rem}
  .cookie-bar p{font-size:.82rem;margin-bottom:12px}
  .cookie-btns button{padding:11px 14px;font-size:.85rem;min-height:42px}
}

/* ═══ SMALL MOBILE ≤ 380px ═══ */
@media (max-width:380px){
  .container{padding:0 14px}
  .hero h1{font-size:1.65rem}
  h2{font-size:1.35rem}
  .brand-text{display:none}
  .brand-logo{width:36px;height:36px}
  .mobile-bar a{font-size:.74rem}
  .mb-num{font-size:.62rem}
}

/* ═══ ACCESSIBILITY ═══ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}
@media (hover:none){
  .service-card:hover,.why-card:hover,.contact-card:hover{transform:none}
  .btn-primary:hover,.btn-wa:hover,.btn-navy:hover{transform:none}
}

/* ═══ PRINT ═══ */
@media print{
  .site-header,.mobile-bar,.cookie-bar,.site-footer{display:none}
  body{background:#fff;color:#000;font-size:11pt}
  a{color:#000;text-decoration:underline}
}
