/*
  billiondollarcopywriting.com (Build 37) | Copywriting Agency | France
  Theme: Cream #FAFAF8 + Deep Navy #0D1B2A + Crimson #C41E3A (FIRST navy+red in series!)
  Nav: LEFT SIDEBAR (fixed 220px vertical - FIRST in 37 builds!)
  Hero: EDITORIAL SPLIT (cream text + navy image)
  Pricing: CREDIT-BASED GRID (FIRST credit system in series)
  Cases: MAGAZINE ALTERNATING rows (full-width flip layout)
  Testimonials: AUTO-SCROLL TICKER (CSS marquee - FIRST in series!)
  FAQ: NUMBERED STACKED rows (large index numbers)
  Mobile: LEFT-SLIDE sidebar with dark overlay
  Country: France | EN+FR multilingual
  Fonts: Playfair Display + Work Sans (first use of both in series)
  CSS prefix: bd-
*/
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;0,800;1,400;1,700&family=Work+Sans:wght@300;400;500;600;700&display=swap');

:root {
  --bd-pale:   #FAFAF8;
  --bd-warm:   #F2EFE8;
  --bd-navy:   #0D1B2A;
  --bd-navy2:  #152234;
  --bd-navy3:  #1D2F46;
  --bd-crim:   #C41E3A;
  --bd-crim2:  #A01830;
  --bd-crimlt: rgba(196,30,58,.08);
  --bd-crimbd: rgba(196,30,58,.3);
  --bd-gold:   #B8973A;
  --bd-muted:  #6B6560;
  --bd-dim:    #9E9891;
  --bd-edge:   #E0DBD4;
  --bd-edge2:  #EDE9E2;
  --bd-ink:    #1A1614;
  --bd-white:  #FFFFFF;
  --bd-sb-w:   220px;
  --bd-max:    1060px;
  --bd-r:      4px;
  --bd-r2:     8px;
  --bd-r3:     14px;
  --bd-r4:     22px;
  --bd-fh:     'Playfair Display', Georgia, serif;
  --bd-fb:     'Work Sans', system-ui, sans-serif;
  --bd-ease:   all 0.22s cubic-bezier(.4,0,.2,1);
  --bd-sh:     0 4px 24px rgba(13,27,42,.07);
  --bd-sh2:    0 12px 48px rgba(13,27,42,.12);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body { background:var(--bd-pale); color:var(--bd-ink); font-family:var(--bd-fb); font-size:1rem; line-height:1.72; overflow-x:hidden; display:flex; }
img,svg { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
ul { list-style:none; }
button { font-family:inherit; cursor:pointer; border:none; background:none; }
input,textarea,select { font-family:inherit; font-size:1rem; }
address { font-style:normal; }
h1 { font-family:var(--bd-fh); font-size:clamp(3rem,5.5vw,7rem); font-weight:800; line-height:.88; letter-spacing:-.02em; }
h2 { font-family:var(--bd-fh); font-size:clamp(2rem,3.5vw,4.5rem); font-weight:800; line-height:.88; letter-spacing:-.02em; }
h3 { font-family:var(--bd-fh); font-size:1.1rem; font-weight:700; }
p  { font-size:.9rem; line-height:1.84; color:var(--bd-muted); }

/* =============================================
   LEFT SIDEBAR NAV (FIRST in 37 builds!)
   ============================================= */
.bd-sidebar {
    width:var(--bd-sb-w); min-height:100vh; position:fixed; top:0; left:0; z-index:900;
    background:var(--bd-navy); display:flex; flex-direction:column; overflow-y:auto;
    border-right:1px solid rgba(255,255,255,.06);
}
.bd-sb-logo { padding:1.8rem 1.5rem 1.5rem; border-bottom:1px solid rgba(255,255,255,.06); flex-shrink:0; }
.bd-sb-brand { font-family:var(--bd-fh); font-size:.74rem; font-weight:700; font-style:italic; color:var(--bd-white); letter-spacing:-.01em; line-height:1.2; }
.bd-sb-brand em { color:var(--bd-crim); font-style:normal; }
.bd-sb-tagline { font-size:.52rem; font-weight:500; text-transform:uppercase; letter-spacing:.12em; color:rgba(255,255,255,.22); margin-top:.28rem; }
.bd-sb-nav { padding:.8rem 0; flex:1; }
.bd-sb-lk { display:flex; align-items:center; gap:.5rem; font-family:var(--bd-fb); font-size:.86rem; font-weight:500; color:rgba(255,255,255,.36); padding:.52rem 1.5rem; transition:var(--bd-ease); white-space:nowrap; }
.bd-sb-lk:hover,.bd-sb-lk.bd-on { color:var(--bd-white); }
.bd-sb-lk.bd-on { background:rgba(255,255,255,.05); border-right:2px solid var(--bd-crim); }
.bd-sb-lk svg { flex-shrink:0; opacity:.5; }
.bd-sb-lk:hover svg,.bd-sb-lk.bd-on svg { opacity:.9; }
.bd-sb-sect { font-size:.42rem; font-weight:700; text-transform:uppercase; letter-spacing:.24em; color:rgba(255,255,255,.15); padding:.6rem 1.5rem .18rem; margin-top:.4rem; }
.bd-sb-foot { padding:1rem 1.5rem 1.5rem; border-top:1px solid rgba(255,255,255,.06); }
.bd-sb-lang { display:flex; gap:.28rem; margin-bottom:.9rem; }
.bd-sb-lang-btn { font-family:var(--bd-fb); font-size:.52rem; font-weight:700; text-transform:uppercase; letter-spacing:.12em; color:rgba(255,255,255,.3); border:1px solid rgba(255,255,255,.14); padding:.18rem .56rem; border-radius:100px; transition:var(--bd-ease); }
.bd-sb-lang-btn:hover,.bd-sb-lang-btn.bd-lang-active { color:var(--bd-crim); border-color:var(--bd-crim); }
.bd-sb-soc { display:flex; gap:.32rem; }
.bd-sb-soc a { width:28px; height:28px; border:1px solid rgba(255,255,255,.1); border-radius:var(--bd-r); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.2); transition:var(--bd-ease); }
.bd-sb-soc a:hover { border-color:var(--bd-crim); color:var(--bd-crim); }
.bd-sb-cta { display:block; width:100%; background:var(--bd-crim); color:white; font-family:var(--bd-fb); font-size:.76rem; font-weight:700; text-align:center; padding:.58rem; border-radius:var(--bd-r2); border:none; cursor:pointer; transition:background .14s; margin-bottom:.7rem; }
.bd-sb-cta:hover { background:var(--bd-crim2); }

/* MAIN content area (offset by sidebar width) */
.bd-main { flex:1; margin-left:var(--bd-sb-w); min-width:0; }

/* Mobile top bar (hidden on desktop) */
.bd-topbar { display:none; position:fixed; top:0; left:0; right:0; height:56px; background:var(--bd-navy); z-index:850; align-items:center; justify-content:space-between; padding:0 1.2rem; border-bottom:1px solid rgba(255,255,255,.07); }
.bd-topbar-brand { font-family:var(--bd-fh); font-size:.72rem; font-weight:700; font-style:italic; color:white; }
.bd-topbar-brand em { color:var(--bd-crim); font-style:normal; }
.bd-burger { flex-direction:column; gap:5px; cursor:pointer; padding:4px; }
.bd-burger span { width:20px; height:1.5px; background:white; display:block; border-radius:2px; transition:var(--bd-ease); }
/* Sidebar overlay on mobile */
.bd-sb-overlay { position:fixed; inset:0; background:rgba(13,27,42,.55); z-index:890; opacity:0; pointer-events:none; transition:opacity .3s; }
.bd-sb-overlay.bd-ov-on { opacity:1; pointer-events:auto; }

/* Layout shell */
.bd-shell { max-width:var(--bd-max); margin:0 auto; padding:0 3rem; }
.bd-slab { padding:8rem 0; }
.bd-kicker { display:inline-flex; align-items:center; gap:.4rem; font-family:var(--bd-fb); font-size:.52rem; font-weight:700; text-transform:uppercase; letter-spacing:.26em; color:var(--bd-crim); margin-bottom:.55rem; }
.bd-kicker::before { content:''; width:12px; height:1.5px; background:var(--bd-crim); }

/* =============================================
   EDITORIAL SPLIT HERO
   ============================================= */
.bd-hero { min-height:100vh; display:grid; grid-template-columns:1.1fr 1fr; }
.bd-hero-left { background:var(--bd-pale); padding:calc(8rem) 4rem 5rem 3rem; display:flex; flex-direction:column; justify-content:center; position:relative; }
.bd-hero-left::before { content:''; position:absolute; top:0; left:0; width:3px; height:100%; background:var(--bd-crim); }
.bd-hero-kicker { font-family:var(--bd-fb); font-size:.52rem; font-weight:700; text-transform:uppercase; letter-spacing:.24em; color:var(--bd-crim); margin-bottom:.6rem; }
.bd-hero-h1 { color:var(--bd-navy); white-space:pre-line; margin-bottom:1.4rem; }
.bd-hero-sub { color:var(--bd-muted); max-width:44ch; margin-bottom:2.5rem; font-size:.94rem; line-height:1.86; }
.bd-hero-acts { display:flex; gap:.7rem; flex-wrap:wrap; }
.bd-hero-right { position:relative; overflow:hidden; }
.bd-hero-right img { width:100%; height:100%; object-fit:cover; filter:brightness(.18) saturate(.4) hue-rotate(200deg); }
.bd-hero-right-overlay { position:absolute; inset:0; background:linear-gradient(to bottom right,var(--bd-navy),var(--bd-navy2)); opacity:.85; }
.bd-hero-right-stat { position:absolute; bottom:3rem; left:2.5rem; }
.bd-hero-right-stat-n { font-family:var(--bd-fh); font-size:4.5rem; font-weight:800; font-style:italic; color:var(--bd-crim); line-height:1; letter-spacing:-.06em; }
.bd-hero-right-stat-l { font-size:.62rem; font-weight:600; text-transform:uppercase; letter-spacing:.14em; color:rgba(255,255,255,.35); margin-top:.2rem; }

/* =============================================
   SERVICE CARDS (6-col grid)
   ============================================= */
.bd-svc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--bd-edge); border:1px solid var(--bd-edge); border-radius:var(--bd-r3); overflow:hidden; margin-top:2.5rem; }
.bd-svc-cell { background:var(--bd-pale); padding:1.8rem; transition:background .18s; }
.bd-svc-cell:hover { background:var(--bd-warm); }
.bd-svc-cell-num { font-family:var(--bd-fh); font-size:.48rem; font-weight:700; color:var(--bd-dim); letter-spacing:.16em; text-transform:uppercase; margin-bottom:.5rem; }
.bd-svc-cell-icon { width:30px; height:30px; background:var(--bd-crimlt); border-radius:var(--bd-r); display:flex; align-items:center; justify-content:center; color:var(--bd-crim); margin-bottom:.6rem; }
.bd-svc-cell-nm { font-family:var(--bd-fh); font-size:.98rem; font-weight:700; color:var(--bd-navy); margin-bottom:.3rem; }
.bd-svc-cell-nm-fr { font-size:.66rem; font-style:italic; color:var(--bd-crim); margin-bottom:.4rem; }
.bd-svc-cell-p { font-size:.8rem; color:var(--bd-muted); line-height:1.7; }
.bd-svc-cell-cr { font-size:.56rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--bd-dim); margin-top:.6rem; display:flex; align-items:center; gap:.28rem; }
.bd-svc-cell-cr span { background:var(--bd-crimlt); color:var(--bd-crim); padding:.08rem .4rem; border-radius:100px; }
.bd-svc-cell-lk { display:inline-flex; align-items:center; gap:.22rem; font-size:.76rem; font-weight:600; color:var(--bd-navy); margin-top:.5rem; transition:gap .18s; }
.bd-svc-cell:hover .bd-svc-cell-lk { gap:.42rem; color:var(--bd-crim); }

/* =============================================
   CREDIT EXPLAINER + PRICING
   ============================================= */
.bd-credit-explain { background:var(--bd-navy); padding:5rem 0; }
.bd-credit-explain-in { max-width:var(--bd-max); margin:0 auto; padding:0 3rem; display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }
.bd-credit-kicker { color:var(--bd-crim); margin-bottom:.8rem; }
.bd-credit-h2 { color:white; margin-bottom:1.2rem; }
.bd-credit-p { color:rgba(255,255,255,.4); max-width:38ch; }
.bd-credit-table { }
.bd-credit-row { display:grid; grid-template-columns:50px 1fr 1fr; gap:1rem; align-items:center; padding:.9rem 0; border-bottom:1px solid rgba(255,255,255,.07); }
.bd-credit-row:last-child { border-bottom:none; }
.bd-credit-row-n { font-family:var(--bd-fh); font-size:2.2rem; font-weight:800; color:var(--bd-crim); line-height:1; letter-spacing:-.04em; }
.bd-credit-row-lbl { font-size:.54rem; font-weight:700; text-transform:uppercase; letter-spacing:.12em; color:rgba(255,255,255,.25); }
.bd-credit-row-ex { font-size:.78rem; color:rgba(255,255,255,.35); line-height:1.56; }

/* Credit package cards */
.bd-pkg-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; margin-top:2.5rem; }
.bd-pkg-card { background:var(--bd-white); border:1.5px solid var(--bd-edge); border-radius:var(--bd-r4); padding:1.8rem; display:flex; flex-direction:column; transition:var(--bd-ease); }
.bd-pkg-card:hover { border-color:var(--bd-crim); box-shadow:var(--bd-sh); }
.bd-pkg-card.bd-pkg-feat { border-color:var(--bd-navy); background:var(--bd-navy); }
.bd-pkg-badge { display:inline-block; font-size:.44rem; font-weight:700; text-transform:uppercase; letter-spacing:.14em; background:var(--bd-crim); color:white; padding:.16rem .56rem; border-radius:100px; margin-bottom:.5rem; }
.bd-pkg-nm { font-family:var(--bd-fh); font-size:1.1rem; font-weight:700; color:var(--bd-navy); margin-bottom:.15rem; }
.bd-pkg-card.bd-pkg-feat .bd-pkg-nm { color:white; }
.bd-pkg-credits { font-family:var(--bd-fh); font-size:3.5rem; font-weight:800; color:var(--bd-crim); line-height:1; letter-spacing:-.06em; margin:.3rem 0 .1rem; }
.bd-pkg-cr-lbl { font-size:.52rem; font-weight:700; text-transform:uppercase; letter-spacing:.12em; color:var(--bd-dim); margin-bottom:.8rem; }
.bd-pkg-card.bd-pkg-feat .bd-pkg-cr-lbl { color:rgba(255,255,255,.3); }
.bd-pkg-best { font-size:.72rem; color:var(--bd-muted); font-style:italic; margin-bottom:.8rem; }
.bd-pkg-card.bd-pkg-feat .bd-pkg-best { color:rgba(255,255,255,.35); }
.bd-pkg-price { font-family:var(--bd-fh); font-size:1.8rem; font-weight:800; color:var(--bd-navy); letter-spacing:-.04em; margin-bottom:.1rem; }
.bd-pkg-card.bd-pkg-feat .bd-pkg-price { color:var(--bd-crim); }
.bd-pkg-per { font-size:.52rem; font-weight:600; text-transform:uppercase; letter-spacing:.08em; color:var(--bd-dim); margin-bottom:1rem; }
.bd-pkg-card.bd-pkg-feat .bd-pkg-per { color:rgba(255,255,255,.25); }
.bd-pkg-feats { display:flex; flex-direction:column; gap:.3rem; flex:1; margin-bottom:1.2rem; }
.bd-pkg-feat-item { display:flex; align-items:flex-start; gap:.35rem; font-size:.78rem; color:var(--bd-muted); }
.bd-pkg-card.bd-pkg-feat .bd-pkg-feat-item { color:rgba(255,255,255,.5); }
.bd-pkg-feat-item svg { color:var(--bd-crim); flex-shrink:0; margin-top:.1rem; }

/* =============================================
   MAGAZINE ALTERNATING CASES (full-width rows)
   ============================================= */
.bd-case-mag { }
.bd-case-row { display:grid; grid-template-columns:1fr 1fr; min-height:520px; }
.bd-case-row:nth-child(even) .bd-case-img-side { order:2; }
.bd-case-row:nth-child(even) .bd-case-text-side { order:1; }
.bd-case-img-side { overflow:hidden; position:relative; }
.bd-case-img-side img { width:100%; height:100%; object-fit:cover; filter:brightness(.22) saturate(.4) hue-rotate(200deg); }
.bd-case-tag-strip { position:absolute; top:1.5rem; left:1.5rem; display:flex; gap:.3rem; flex-wrap:wrap; }
.bd-case-tag-item { font-size:.48rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:white; background:rgba(13,27,42,.7); padding:.12rem .44rem; border-radius:100px; }
.bd-case-text-side { background:var(--bd-warm); padding:5rem; display:flex; flex-direction:column; justify-content:center; }
.bd-case-row:nth-child(even) .bd-case-text-side { background:var(--bd-pale); }
.bd-case-client { font-family:var(--bd-fh); font-size:clamp(1.6rem,2.5vw,2.8rem); font-weight:800; color:var(--bd-navy); margin-bottom:.2rem; line-height:1; }
.bd-case-type { font-size:.62rem; color:var(--bd-dim); margin-bottom:1.2rem; }
.bd-case-stat-n { font-family:var(--bd-fh); font-size:5rem; font-weight:800; color:var(--bd-crim); line-height:1; letter-spacing:-.08em; }
.bd-case-stat-l { font-size:.66rem; color:var(--bd-muted); max-width:24ch; margin-top:.1rem; line-height:1.5; margin-bottom:1.2rem; }
.bd-case-intro { font-size:.86rem; line-height:1.82; margin-bottom:1.2rem; }
.bd-case-quote { font-family:var(--bd-fh); font-size:.88rem; font-style:italic; color:var(--bd-navy); padding-top:1rem; border-top:1px solid var(--bd-edge); line-height:1.56; }
.bd-case-who { font-size:.6rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--bd-crim); margin-top:.3rem; }

/* =============================================
   AUTO-SCROLL TICKER TESTIMONIALS (CSS marquee - FIRST in series!)
   ============================================= */
.bd-ticker-zone { background:var(--bd-navy); padding:5rem 0; overflow:hidden; }
.bd-ticker-hd { max-width:var(--bd-max); margin:0 auto; padding:0 3rem 2.5rem; }
.bd-ticker-hd-kicker { color:var(--bd-crim); margin-bottom:.5rem; }
.bd-ticker-h2 { color:white; }
.bd-ticker-wrap { overflow:hidden; mask-image:linear-gradient(to right,transparent,black 10%,black 90%,transparent); }
.bd-ticker-track { display:flex; gap:1.5rem; width:max-content; animation:bdTickScroll 36s linear infinite; }
.bd-ticker-track:hover { animation-play-state:paused; }
@keyframes bdTickScroll { from { transform:translateX(0); } to { transform:translateX(-50%); } }
.bd-testi-item { background:var(--bd-navy3); border:1px solid rgba(255,255,255,.07); border-radius:var(--bd-r3); padding:1.5rem; min-width:340px; flex-shrink:0; }
.bd-testi-q { font-family:var(--bd-fh); font-size:.88rem; font-style:italic; color:rgba(255,255,255,.75); line-height:1.54; margin-bottom:.8rem; }
.bd-testi-who { font-family:var(--bd-fb); font-size:.78rem; font-weight:700; color:var(--bd-crim); }
.bd-testi-co { font-size:.62rem; color:rgba(255,255,255,.25); margin-top:.05rem; }

/* =============================================
   PROCESS SECTION (vertical numbered list, alternating sides)
   ============================================= */
.bd-proc-list { display:flex; flex-direction:column; gap:0; margin-top:2.5rem; }
.bd-proc-item { display:grid; grid-template-columns:80px 1fr; gap:2.5rem; align-items:start; padding:2.5rem 0; border-bottom:1px solid var(--bd-edge); }
.bd-proc-item:last-child { border-bottom:none; }
.bd-proc-n { font-family:var(--bd-fh); font-size:4rem; font-weight:800; font-style:italic; color:var(--bd-edge); line-height:1; letter-spacing:-.06em; }
.bd-proc-h { font-family:var(--bd-fh); font-size:1rem; font-weight:700; color:var(--bd-navy); margin-bottom:.4rem; }
.bd-proc-p { font-size:.86rem; }

/* =============================================
   VALUES SECTION (oversized numbers)
   ============================================= */
.bd-vals-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--bd-edge); border:1px solid var(--bd-edge); margin-top:2.5rem; }
.bd-val-blk { background:var(--bd-pale); padding:2rem; }
.bd-val-n { font-family:var(--bd-fh); font-size:clamp(2.2rem,4vw,4.5rem); font-weight:800; color:var(--bd-crim); line-height:1; letter-spacing:-.05em; margin-bottom:.4rem; }
.bd-val-h { font-family:var(--bd-fh); font-size:.88rem; font-weight:700; color:var(--bd-navy); margin-bottom:.3rem; }
.bd-val-p { font-size:.76rem; }

/* =============================================
   NUMBERED STACKED FAQ (FIRST in 37 builds - different from all previous)
   ============================================= */
.bd-faq-list { margin-top:2.5rem; }
.bd-faq-item { display:grid; grid-template-columns:64px 1fr; gap:2rem; padding:2.2rem 0; border-bottom:1px solid var(--bd-edge); }
.bd-faq-item:last-child { border-bottom:none; }
.bd-faq-idx { font-family:var(--bd-fh); font-size:2.4rem; font-weight:800; color:var(--bd-edge2); line-height:1; letter-spacing:-.04em; }
.bd-faq-q { font-family:var(--bd-fh); font-size:1rem; font-weight:700; color:var(--bd-navy); margin-bottom:.4rem; }
.bd-faq-a { font-size:.86rem; }

/* =============================================
   INNER PAGE HEADER
   ============================================= */
.bd-pagecap { background:var(--bd-navy); text-align:center; padding:6rem 3rem 5rem; position:relative; overflow:hidden; }
.bd-pagecap::before { content:''; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:500px; height:280px; background:radial-gradient(ellipse,rgba(196,30,58,.07),transparent 70%); pointer-events:none; }
.bd-pagecap-tag { display:inline-block; font-family:var(--bd-fb); font-size:.48rem; font-weight:700; text-transform:uppercase; letter-spacing:.26em; color:var(--bd-crim); border:1px solid var(--bd-crimbd); padding:.2rem .7rem; border-radius:100px; margin-bottom:.72rem; position:relative; }
.bd-pagecap h1 { color:white; max-width:20ch; margin:0 auto; position:relative; white-space:pre-line; }
.bd-pagecap-sub { color:rgba(255,255,255,.38); max-width:52ch; margin:.72rem auto 0; font-size:.92rem; line-height:1.86; position:relative; }

/* =============================================
   SERVICE PAGE LAYOUT
   ============================================= */
.bd-svc-layout { max-width:var(--bd-max); margin:0 auto; padding:5.5rem 3rem; display:grid; grid-template-columns:1fr 250px; gap:5rem; align-items:start; }
.bd-svc-body h2 { font-family:var(--bd-fh); font-size:1.1rem; color:var(--bd-crim); margin:2.5rem 0 .5rem; }
.bd-svc-body p { margin-bottom:.88rem; }
.bd-svc-inc-list { display:flex; flex-direction:column; gap:.36rem; margin-bottom:1.5rem; }
.bd-svc-inc { display:flex; align-items:flex-start; gap:.5rem; font-size:.86rem; color:var(--bd-ink); }
.bd-svc-inc svg { color:var(--bd-crim); flex-shrink:0; margin-top:.1rem; }
.bd-svc-del { background:var(--bd-crimlt); border-left:3px solid var(--bd-crim); padding:.72rem 1rem; border-radius:0 var(--bd-r) var(--bd-r) 0; margin-bottom:1.5rem; }
.bd-svc-del p { margin:0; font-size:.84rem; color:var(--bd-ink); }
.bd-svc-aside { position:sticky; top:3rem; }
/* ASIDE CARD - dark navy background: buttons must be visible on dark! */
.bd-aside-card { background:var(--bd-navy); border-radius:var(--bd-r3); overflow:hidden; }
.bd-aside-img img { width:100%; height:90px; object-fit:cover; filter:brightness(.15) saturate(.3) hue-rotate(200deg); }
.bd-aside-body { padding:1.2rem; }
.bd-aside-nm { font-size:.44rem; font-weight:700; text-transform:uppercase; letter-spacing:.14em; color:rgba(255,255,255,.25); margin-bottom:.2rem; }
.bd-aside-rate { font-family:var(--bd-fh); font-size:.92rem; font-weight:700; font-style:italic; color:var(--bd-crim); margin-bottom:.8rem; }
/* OTHER SERVICES - outside dark card, on pale background: must be dark! */
.bd-other-h { font-size:.44rem; font-weight:700; text-transform:uppercase; letter-spacing:.2em; color:var(--bd-dim); margin:1.4rem 0 .5rem; }
.bd-other-lk { display:flex; align-items:center; gap:.4rem; font-size:.8rem; color:var(--bd-muted); padding:.36rem 0; border-bottom:1px solid var(--bd-edge); transition:color .14s; }
.bd-other-lk:hover { color:var(--bd-navy); }

/* =============================================
   LEGAL
   ============================================= */
.bd-legal { max-width:820px; margin:0 auto; padding:5.5rem 3rem 8rem; }
.bd-legal h2 { font-family:var(--bd-fh); font-size:1.1rem; color:var(--bd-crim); margin:2.8rem 0 .5rem; }
.bd-legal h3 { font-family:var(--bd-fh); font-size:.96rem; color:var(--bd-ink); margin:1.4rem 0 .3rem; }
.bd-legal p { margin-bottom:.88rem; font-size:.88rem; }
.bd-legal ul { padding-left:1.2rem; margin:.4rem 0 .88rem; }
.bd-legal li { font-size:.88rem; list-style:disc; color:var(--bd-muted); line-height:1.72; margin-bottom:.26rem; }
.bd-legal a { color:var(--bd-crim); }
.bd-legal table { width:100%; border-collapse:collapse; font-size:.82rem; margin:.88rem 0 1.2rem; }
.bd-legal th { background:var(--bd-warm); color:var(--bd-navy); padding:.5rem .9rem; text-align:left; font-size:.58rem; text-transform:uppercase; letter-spacing:.06em; border:1px solid var(--bd-edge); }
.bd-legal td { padding:.5rem .9rem; border:1px solid var(--bd-edge); color:var(--bd-muted); }
.bd-legal address { background:var(--bd-crimlt); border-left:3px solid var(--bd-crim); padding:.88rem 1.1rem; font-size:.86rem; color:var(--bd-ink); line-height:1.86; margin:.88rem 0; border-radius:0 var(--bd-r) var(--bd-r) 0; }
.bd-legal-eff { display:inline-block; font-size:.68rem; color:var(--bd-muted); background:var(--bd-warm); border:1px solid var(--bd-edge); padding:.24rem .7rem; border-radius:100px; margin-bottom:1.5rem; }

/* =============================================
   BUILDER
   ============================================= */
.bd-build-wrap { max-width:var(--bd-max); margin:0 auto; padding:4.5rem 3rem 8rem; display:grid; grid-template-columns:1fr 280px; gap:4rem; align-items:start; }
.bd-build-sec { margin-bottom:2.8rem; }
.bd-build-hd { display:block; font-family:var(--bd-fb); font-size:.5rem; font-weight:700; text-transform:uppercase; letter-spacing:.22em; color:var(--bd-crim); margin-bottom:.88rem; }
.bd-pick-row { background:var(--bd-white); border:1.5px solid var(--bd-edge); border-radius:var(--bd-r2); padding:.82rem 1rem; display:flex; align-items:center; gap:.7rem; cursor:pointer; user-select:none; transition:var(--bd-ease); margin-bottom:.4rem; }
.bd-pick-row:hover { border-color:var(--bd-crimbd); }
.bd-pick-row.bd-sel { border-color:var(--bd-crim); background:var(--bd-crimlt); }
.bd-pick-box { width:18px; height:18px; border:1.5px solid var(--bd-dim); border-radius:var(--bd-r); flex-shrink:0; transition:var(--bd-ease); }
.bd-pick-row.bd-sel .bd-pick-box { background:var(--bd-crim); border-color:var(--bd-crim); }
.bd-pick-nm { font-size:.86rem; color:var(--bd-muted); flex:1; }
.bd-pick-row.bd-sel .bd-pick-nm { color:var(--bd-ink); font-weight:600; }
.bd-pick-pr { font-size:.68rem; font-weight:700; color:var(--bd-crim); }
.bd-addon-row { display:flex; flex-wrap:wrap; gap:.45rem; }
.bd-addon-chip { background:var(--bd-white); border:1.5px solid var(--bd-edge); border-radius:var(--bd-r); padding:.5rem .9rem; cursor:pointer; user-select:none; transition:var(--bd-ease); }
.bd-addon-chip:hover { border-color:var(--bd-crimbd); }
.bd-addon-chip.bd-chip-on { border-color:var(--bd-crim); background:var(--bd-crimlt); }
.bd-chip-nm { font-size:.82rem; font-weight:600; color:var(--bd-muted); }
.bd-addon-chip.bd-chip-on .bd-chip-nm { color:var(--bd-ink); }
.bd-chip-pr { font-size:.6rem; color:var(--bd-dim); }
.bd-addon-chip.bd-chip-on .bd-chip-pr { color:var(--bd-crim); }
.bd-hrs-wrap { background:var(--bd-white); border:1.5px solid var(--bd-edge); border-radius:var(--bd-r2); padding:1rem; }
.bd-hrs-row { display:flex; justify-content:space-between; align-items:center; margin-bottom:.5rem; }
.bd-hrs-lbl { font-size:.86rem; color:var(--bd-muted); }
.bd-hrs-val { font-family:var(--bd-fh); font-size:2rem; font-weight:800; color:var(--bd-crim); line-height:1; }
.bd-hrs-slider { -webkit-appearance:none; width:100%; height:3px; background:var(--bd-edge); border-radius:2px; cursor:pointer; margin-top:.5rem; }
.bd-hrs-slider::-webkit-slider-thumb { -webkit-appearance:none; width:18px; height:18px; border-radius:50%; background:var(--bd-crim); cursor:pointer; }
.bd-hrs-note { font-size:.66rem; color:var(--bd-dim); margin-top:.45rem; line-height:1.6; }
.bd-tally { background:var(--bd-navy); border-radius:var(--bd-r3); overflow:hidden; position:sticky; top:3rem; }
.bd-tally-top { background:rgba(255,255,255,.04); border-bottom:1px solid rgba(255,255,255,.07); padding:.88rem 1.2rem; }
.bd-tally-lbl { font-size:.46rem; font-weight:700; text-transform:uppercase; letter-spacing:.18em; color:rgba(255,255,255,.25); }
.bd-tally-lines { padding:.88rem 1.2rem; min-height:60px; }
.bd-tally-empty { font-size:.76rem; color:rgba(255,255,255,.18); font-style:italic; }
.bd-tally-ln { display:flex; justify-content:space-between; gap:.5rem; font-size:.76rem; margin-bottom:.38rem; }
.bd-tally-lnm { color:rgba(255,255,255,.35); }
.bd-tally-lpr { font-weight:700; color:white; }
.bd-tally-foot { border-top:1px solid rgba(255,255,255,.07); padding:.88rem 1.2rem; }
.bd-tally-sum { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:.88rem; }
.bd-tally-suml { font-size:.44rem; font-weight:700; text-transform:uppercase; letter-spacing:.12em; color:rgba(255,255,255,.2); }
.bd-tally-sumv { font-family:var(--bd-fh); font-size:2.4rem; font-weight:800; color:var(--bd-crim); line-height:1; letter-spacing:-.04em; }
.bd-tally-go { display:block; width:100%; background:var(--bd-crim); color:white; font-family:var(--bd-fb); font-size:.88rem; font-weight:700; padding:.78rem; border-radius:var(--bd-r2); border:none; cursor:pointer; transition:background .14s; }
.bd-tally-go:hover:not(:disabled) { background:var(--bd-crim2); }
.bd-tally-go:disabled { opacity:.2; cursor:not-allowed; }

/* =============================================
   CHECKOUT
   ============================================= */
.bd-co-wrap { max-width:860px; margin:0 auto; padding:5rem 3rem; display:grid; grid-template-columns:1fr 250px; gap:4rem; align-items:start; }
.bd-fg { margin-bottom:.68rem; }
.bd-fl { display:block; font-size:.48rem; font-weight:700; text-transform:uppercase; letter-spacing:.14em; color:var(--bd-muted); margin-bottom:.26rem; }
.bd-fi { width:100%; background:var(--bd-white); border:1.5px solid var(--bd-edge); border-radius:var(--bd-r2); padding:.64rem .9rem; color:var(--bd-ink); font-size:.9rem; transition:border-color .15s; }
.bd-fi:focus { outline:none; border-color:var(--bd-crim); box-shadow:0 0 0 3px var(--bd-crimlt); }
.bd-fi::placeholder { color:var(--bd-dim); }
.bd-agree-row { display:flex; align-items:flex-start; gap:.5rem; font-size:.82rem; color:var(--bd-muted); line-height:1.6; margin:.88rem 0; }
.bd-agree-row input { margin-top:.14rem; accent-color:var(--bd-crim); }
.bd-agree-row a { color:var(--bd-crim); }
.bd-co-sum { background:var(--bd-navy); border-radius:var(--bd-r3); overflow:hidden; position:sticky; top:3rem; }
.bd-co-sum-hd { background:rgba(255,255,255,.04); padding:.72rem 1rem; border-bottom:1px solid rgba(255,255,255,.07); }
.bd-co-sum-hl { font-size:.46rem; font-weight:700; text-transform:uppercase; letter-spacing:.16em; color:rgba(255,255,255,.25); }
.bd-co-sum-body { padding:.88rem 1rem; }
.bd-co-sum-ln { display:flex; justify-content:space-between; gap:1rem; font-size:.76rem; margin-bottom:.38rem; }
.bd-co-sum-lnm { color:rgba(255,255,255,.35); }
.bd-co-sum-lpr { font-weight:700; color:white; }
.bd-co-sum-div { border:none; border-top:1px solid rgba(255,255,255,.07); margin:.5rem 0; }
.bd-co-sum-tot { display:flex; justify-content:space-between; align-items:flex-end; }
.bd-co-sum-totl { font-size:.44rem; font-weight:700; text-transform:uppercase; letter-spacing:.12em; color:rgba(255,255,255,.2); }
.bd-co-sum-totv { font-family:var(--bd-fh); font-size:2rem; font-weight:800; color:var(--bd-crim); line-height:1; }

/* =============================================
   RESULT PAGES
   ============================================= */
.bd-result { min-height:74vh; display:flex; align-items:center; justify-content:center; text-align:center; padding:8rem 3rem 5rem; background:var(--bd-pale); }

/* =============================================
   BUTTONS
   ============================================= */
.bd-btn-crim { display:inline-flex; align-items:center; gap:.4rem; font-family:var(--bd-fb); font-size:.88rem; font-weight:700; color:white; background:var(--bd-crim); padding:.72rem 1.9rem; border-radius:100px; transition:background .14s; border:none; cursor:pointer; white-space:nowrap; }
.bd-btn-crim:hover { background:var(--bd-crim2); }
.bd-btn-navy { display:inline-flex; align-items:center; gap:.4rem; font-family:var(--bd-fb); font-size:.88rem; font-weight:700; color:white; background:var(--bd-navy); padding:.72rem 1.9rem; border-radius:100px; transition:background .14s; border:none; cursor:pointer; white-space:nowrap; }
.bd-btn-navy:hover { background:var(--bd-navy2); }
.bd-btn-ghost { display:inline-flex; align-items:center; gap:.4rem; font-family:var(--bd-fb); font-size:.88rem; font-weight:700; color:var(--bd-navy); background:transparent; padding:.7rem 1.8rem; border-radius:100px; border:1.5px solid var(--bd-edge); transition:var(--bd-ease); white-space:nowrap; }
.bd-btn-ghost:hover { border-color:var(--bd-navy); }
/* White ghost - for dark backgrounds */
.bd-btn-ghost-w { display:inline-flex; align-items:center; gap:.4rem; font-family:var(--bd-fb); font-size:.88rem; font-weight:700; color:white; background:transparent; padding:.7rem 1.8rem; border-radius:100px; border:1.5px solid rgba(255,255,255,.25); transition:border-color .14s; white-space:nowrap; }
.bd-btn-ghost-w:hover { border-color:rgba(255,255,255,.7); }

/* =============================================
   NAVY CTA BAND
   ============================================= */
.bd-ctaband { background:var(--bd-navy); position:relative; overflow:hidden; }
.bd-ctaband::before { content:''; position:absolute; top:-80px; right:-80px; width:380px; height:380px; border-radius:50%; border:1px solid rgba(196,30,58,.1); }
.bd-ctaband::after  { content:''; position:absolute; top:-20px; right:-20px; width:200px; height:200px; border-radius:50%; border:1px solid rgba(196,30,58,.07); }
.bd-ctaband-in { max-width:680px; margin:0 auto; padding:8rem 3rem; text-align:center; position:relative; }
.bd-ctaband-in h2 { color:white; white-space:pre-line; margin-bottom:.7rem; }
.bd-ctaband-in p { color:rgba(255,255,255,.4); margin-bottom:2.2rem; font-size:1rem; max-width:42ch; margin-left:auto; margin-right:auto; }
.bd-cta-row { display:flex; gap:.7rem; justify-content:center; flex-wrap:wrap; }

/* =============================================
   COOKIE + CHAT
   ============================================= */
.bd-ck-bar { position:fixed; bottom:0; left:var(--bd-sb-w); right:0; background:var(--bd-ink); border-top:3px solid var(--bd-crim); z-index:9999; padding:.9rem 2rem; display:none; gap:1rem; align-items:center; justify-content:space-between; flex-wrap:wrap; }
.bd-ck-bar p { font-size:.78rem; color:rgba(255,255,255,.45); margin:0; }
.bd-ck-bar a { color:var(--bd-crim); }
.bd-ck-btns { display:flex; gap:.4rem; flex-shrink:0; }
.bd-ck-yes { background:var(--bd-crim); color:white; font-size:.76rem; font-weight:700; padding:.38rem .92rem; border:none; border-radius:100px; cursor:pointer; }
.bd-ck-no  { background:transparent; color:rgba(255,255,255,.38); font-size:.76rem; padding:.38rem .92rem; border:1px solid rgba(255,255,255,.14); border-radius:100px; cursor:pointer; }
.bd-chat-fab { position:fixed; bottom:4.5rem; right:1.5rem; z-index:9990; width:50px; height:50px; background:var(--bd-crim); border-radius:50%; display:flex; align-items:center; justify-content:center; box-shadow:0 4px 20px rgba(196,30,58,.4); cursor:pointer; border:none; transition:var(--bd-ease); }
.bd-chat-fab:hover { background:var(--bd-crim2); transform:scale(1.06); }
.bd-chatpop { position:fixed; bottom:7.8rem; right:1.5rem; z-index:9989; width:272px; background:var(--bd-white); border:1px solid var(--bd-edge); border-radius:var(--bd-r3); box-shadow:var(--bd-sh2); opacity:0; pointer-events:none; transform:translateY(10px) scale(.97); transition:opacity .2s,transform .22s; overflow:hidden; }
.bd-chatpop.bd-cp-on { opacity:1; pointer-events:auto; transform:none; }
.bd-chatpop-hd { background:var(--bd-navy); padding:.9rem 1rem; display:flex; align-items:center; justify-content:space-between; }
.bd-chatpop-nm { font-family:var(--bd-fh); font-size:.86rem; font-style:italic; color:white; }
.bd-chatpop-sub { font-size:.54rem; color:rgba(255,255,255,.3); }
.bd-chatpop-x { color:rgba(255,255,255,.4); background:none; border:none; cursor:pointer; }
.bd-chatpop-bd { padding:.9rem; }
.bd-chat-done { display:none; text-align:center; padding:.8rem; font-size:.82rem; color:var(--bd-crim); font-weight:700; }
.bd-chat-inp { width:100%; background:var(--bd-warm); border:1px solid var(--bd-edge); border-radius:var(--bd-r2); padding:.46rem .76rem; font-size:.8rem; color:var(--bd-ink); margin-bottom:.38rem; resize:none; }
.bd-chat-inp:focus { outline:none; border-color:var(--bd-crimbd); }
.bd-chat-inp::placeholder { color:var(--bd-dim); }
.bd-chat-send { width:100%; background:var(--bd-crim); color:white; font-size:.78rem; font-weight:700; padding:.48rem; border-radius:var(--bd-r2); border:none; cursor:pointer; }

/* =============================================
   FOOTER
   ============================================= */
.bd-foot { background:var(--bd-navy); }
.bd-foot-top { max-width:var(--bd-max); margin:0 auto; padding:5rem 3rem 2.5rem; display:grid; grid-template-columns:2fr 1fr 1fr 1.4fr; gap:3rem; }
.bd-foot-brand { font-family:var(--bd-fh); font-size:.88rem; font-weight:700; font-style:italic; color:white; margin-bottom:.3rem; }
.bd-foot-brand em { color:var(--bd-crim); font-style:normal; }
.bd-foot-tag { font-size:.72rem; color:rgba(255,255,255,.2); max-width:26ch; line-height:1.72; margin-bottom:.65rem; }
.bd-foot-siret { font-size:.56rem; color:rgba(255,255,255,.1); margin-bottom:1rem; }
.bd-foot-soc { display:flex; gap:.3rem; }
.bd-foot-soc a { width:30px; height:30px; border:1px solid rgba(255,255,255,.1); border-radius:var(--bd-r); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.2); transition:var(--bd-ease); }
.bd-foot-soc a:hover { border-color:var(--bd-crim); color:var(--bd-crim); }
.bd-foot-col-h { font-size:.44rem; font-weight:700; letter-spacing:.24em; text-transform:uppercase; color:rgba(255,255,255,.18); margin-bottom:.8rem; }
.bd-foot-links { display:flex; flex-direction:column; gap:.42rem; }
.bd-foot-links a { font-size:.78rem; color:rgba(255,255,255,.24); transition:color .14s; }
.bd-foot-links a:hover { color:var(--bd-crim); }
.bd-foot-ct a { font-size:.76rem; color:rgba(255,255,255,.24); display:flex; align-items:flex-start; gap:.42rem; line-height:1.52; transition:color .14s; margin-bottom:.5rem; }
.bd-foot-ct a:hover { color:var(--bd-crim); }
.bd-foot-ct svg { flex-shrink:0; color:var(--bd-crim); opacity:.5; margin-top:.04rem; }
.bd-foot-btm { border-top:1px solid rgba(255,255,255,.05); max-width:var(--bd-max); margin:0 auto; padding:1.4rem 3rem; display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap; }
.bd-foot-copy { font-size:.58rem; color:rgba(255,255,255,.14); }
.bd-foot-leg { display:flex; gap:1.2rem; flex-wrap:wrap; }
.bd-foot-leg a { font-size:.58rem; color:rgba(255,255,255,.2); transition:color .14s; }
.bd-foot-leg a:hover { color:var(--bd-crim); }

/* =============================================
   ANIMATIONS
   ============================================= */
.bd-up { opacity:0; transform:translateY(14px); transition:opacity .5s ease,transform .5s ease; }
.bd-up.bd-vis { opacity:1; transform:none; }
.bd-left { opacity:0; transform:translateX(-14px); transition:opacity .5s ease,transform .5s ease; }
.bd-left.bd-vis { opacity:1; transform:none; }

/* =============================================
   RESPONSIVE (sidebar collapses on mobile)
   ============================================= */
@media (max-width:1024px) {
  body { display:block; }
  .bd-sidebar { transform:translateX(-100%); transition:transform .3s cubic-bezier(.4,0,.2,1); }
  .bd-sidebar.bd-sb-open { transform:translateX(0); }
  .bd-main { margin-left:0; }
  .bd-topbar { display:flex; }
  .bd-hero { grid-template-columns:1fr; min-height:auto; padding-top:56px; }
  .bd-hero-right { height:300px; }
  .bd-svc-grid { grid-template-columns:1fr 1fr; }
  .bd-pkg-grid { grid-template-columns:1fr 1fr; }
  .bd-vals-grid { grid-template-columns:1fr 1fr; }
  .bd-case-row { grid-template-columns:1fr; min-height:auto; }
  .bd-case-row:nth-child(even) .bd-case-img-side { order:0; }
  .bd-case-row:nth-child(even) .bd-case-text-side { order:1; }
  .bd-case-img-side { height:280px; }
  .bd-svc-layout,.bd-build-wrap,.bd-co-wrap { grid-template-columns:1fr; }
  .bd-foot-top { grid-template-columns:1fr 1fr; gap:2rem; }
  .bd-ck-bar { left:0; }
  .bd-credit-explain-in { grid-template-columns:1fr; gap:2.5rem; }
}
@media (max-width:640px) {
  .bd-shell { padding:0 1.4rem; }
  .bd-slab { padding:5rem 0; }
  .bd-hero-left { padding:3rem 1.4rem 2.5rem; }
  .bd-case-text-side { padding:2.5rem 1.4rem; }
  .bd-svc-grid { grid-template-columns:1fr; }
  .bd-pkg-grid { grid-template-columns:1fr; }
  .bd-vals-grid { grid-template-columns:1fr; }
  .bd-faq-item { grid-template-columns:44px 1fr; gap:1rem; }
  .bd-proc-item { grid-template-columns:60px 1fr; gap:1.5rem; }
  .bd-proc-n { font-size:2.5rem; }
  .bd-foot-top { grid-template-columns:1fr; }
  .bd-build-wrap,.bd-co-wrap { padding:3rem 1.4rem 5rem; }
  .bd-shell { padding:0 1.4rem; }
}
