/* ============================================================
   redesign2.css  ·  Fully Built landing — fb-* component layer
   Loads LAST (after warm-theme.css + revamp.css). Reuses the warm
   tokens from revamp.css (:root). Satoshi everywhere. No NEW
   gradients (the CX orb in revamp.css is the one kept exception).
   Scope: redesigns the MIDDLE sections only — hero, dashboard
   panels, CX orb and footer markup are inherited unchanged.
   ============================================================ */

:root{
  --fb-radius: 14px;
  --fb-radius-sm: 10px;
  --fb-maxw: 1180px;
  --fb-shadow: 0 1px 2px rgba(28,30,36,.05), 0 10px 30px rgba(28,30,36,.06);
  --fb-shadow-h: 0 2px 6px rgba(28,30,36,.07), 0 20px 48px rgba(28,30,36,.10);
  --fb-ease: cubic-bezier(.16,.84,.3,1);
}

/* ---- shared section shell ---------------------------------- */
.fb-section{ background:var(--bg); padding:96px 24px; }
.fb-wrap{ max-width:var(--fb-maxw); margin:0 auto; }

/* ---- fb-section-head --------------------------------------- */
.fb-head{ max-width:680px; margin:0 0 48px; text-align:left; }
.fb-head.is-center{ margin-left:auto; margin-right:auto; text-align:center; }
.fb-eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:'Satoshi',sans-serif; font-weight:700;
  font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--green-d); margin-bottom:16px;
}
.fb-eyebrow .dot{ display:none; }
@keyframes fb-pulse{
  0%{ box-shadow:0 0 0 0 rgba(43,158,143,.45); }
  70%{ box-shadow:0 0 0 7px rgba(43,158,143,0); }
  100%{ box-shadow:0 0 0 0 rgba(43,158,143,0); }
}
.fb-h2{
  font-family:'Satoshi',sans-serif; font-weight:900;
  font-size:clamp(30px,4.2vw,50px); line-height:1.04;
  letter-spacing:-.025em; color:var(--ink); margin:0;
}
.fb-h2 .it{ font-style:italic; color:var(--green-d); font-weight:700; }
.fb-lede{
  font-family:'Satoshi',sans-serif; font-weight:500;
  font-size:clamp(16px,1.4vw,18px); line-height:1.6;
  color:var(--sub); margin:18px 0 0; max-width:62ch;
}
.fb-head.is-center .fb-lede{ margin-left:auto; margin-right:auto; }

/* ---- fb-rule ----------------------------------------------- */
.fb-rule{ height:1px; background:var(--border); border:0; width:100%; }
.fb-rule.draw{ transform:scaleX(0); transform-origin:left; transition:transform .9s var(--fb-ease); }
.fb-rule.draw.in{ transform:scaleX(1); }

/* ---- fb-btn ------------------------------------------------- */
.fb-btn{
  display:inline-flex; align-items:center; gap:9px;
  font-family:'Satoshi',sans-serif; font-weight:700; font-size:15px;
  padding:13px 22px; border-radius:11px; cursor:pointer; border:0;
  text-decoration:none; transition:transform .18s var(--fb-ease), box-shadow .18s var(--fb-ease), background-color .18s var(--fb-ease);
}
.fb-btn .arr{ transition:transform .2s var(--fb-ease); }
.fb-btn:hover .arr{ transform:translateX(3px); }
.fb-btn--primary{ background:var(--green); color:#fff;
  box-shadow:0 1px 2px rgba(31,122,111,.18), 0 8px 18px rgba(43,158,143,.22); }
.fb-btn--primary:hover{ background:var(--green-d); transform:translateY(-2px);
  box-shadow:0 2px 4px rgba(31,122,111,.24), 0 14px 28px rgba(43,158,143,.30); }
.fb-btn--ghost{ background:var(--card); color:var(--ink); border:1px solid var(--border); }
.fb-btn--ghost:hover{ transform:translateY(-2px); box-shadow:var(--fb-shadow); }
.fb-btn--white{ background:#fff; color:var(--green-d); }
.fb-btn--white:hover{ transform:translateY(-2px); box-shadow:0 14px 28px rgba(12,40,36,.22); }
.fb-btn--link{
  background:transparent; padding:6px 2px; color:var(--green-d); border-radius:0;
  position:relative;
}
.fb-btn--link::after{ content:""; position:absolute; left:2px; right:2px; bottom:2px; height:1.5px;
  background:var(--green-d); transform:scaleX(0); transform-origin:left; transition:transform .25s var(--fb-ease); }
.fb-btn--link:hover::after{ transform:scaleX(1); }

/* ---- fb-numeral (proof stat) ------------------------------- */
.fb-stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.fb-stat{
  background:var(--card); border:1px solid var(--border); border-radius:var(--fb-radius);
  padding:30px 28px; box-shadow:var(--fb-shadow); text-align:left;
  transition:transform .22s var(--fb-ease), box-shadow .22s var(--fb-ease);
}
.fb-stat:hover{ transform:translateY(-3px); box-shadow:var(--fb-shadow-h); }
.fb-num{
  font-family:'Satoshi',sans-serif; font-weight:900; color:var(--ink);
  font-size:clamp(40px,5.4vw,58px); line-height:1; letter-spacing:-.03em;
  display:flex; align-items:baseline; gap:2px;
}
.fb-num .u{ font-size:.5em; font-weight:700; color:var(--green-d); }
.fb-stat .fb-stat-rule{ width:38px; height:3px; background:var(--green); border-radius:2px; margin:16px 0 14px; }
.fb-stat-l{ font-family:'Satoshi',sans-serif; font-weight:700; font-size:15px; color:var(--ink); }
.fb-stat-s{ font-family:'Satoshi',sans-serif; font-weight:500; font-size:13.5px; color:var(--sub); margin-top:4px; }

/* ---- fb-mark (qualitative card top accent) ----------------- */
.fb-mark{ width:38px; height:3px; background:var(--green); border-radius:2px; margin-bottom:18px; }

/* ---- fb-card (feature + small) ----------------------------- */
.fb-grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:22px; margin-bottom:22px; }
.fb-grid-4{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.fb-card{
  position:relative; background:var(--card); border:1px solid var(--border);
  border-radius:var(--fb-radius); padding:28px;
  box-shadow:var(--fb-shadow); transition:transform .22s var(--fb-ease), box-shadow .22s var(--fb-ease);
  display:flex; flex-direction:column; text-align:left;
}
.fb-card:hover{ transform:translateY(-3px); box-shadow:var(--fb-shadow-h); }
.fb-card .fb-idx{
  font-family:'Satoshi',sans-serif; font-weight:700; font-size:12px; letter-spacing:.1em;
  color:var(--faint); margin-bottom:14px;
}
.fb-card .fb-ic{ width:42px; height:42px; margin-bottom:16px; object-fit:contain;
  align-self:flex-start; }
.fb-card h3{
  font-family:'Satoshi',sans-serif; font-weight:800; font-size:18.5px; line-height:1.22;
  letter-spacing:-.01em; color:var(--ink); margin:0 0 9px;
}
.fb-card p{ font-family:'Satoshi',sans-serif; font-weight:500; font-size:14.5px; line-height:1.55;
  color:var(--sub); margin:0; }
.fb-card--feature{ padding:34px; }
.fb-card--feature h3{ font-size:23px; }
.fb-card--feature .fb-ic{ width:50px; height:50px; }
/* kraft corner accent — solid fills only */
.fb-card--feature::after{
  content:""; position:absolute; top:0; right:0; width:46px; height:46px;
  background:var(--kraft-2,#D9C2A0); opacity:.9;
  border-bottom-left-radius:14px; border-top-right-radius:var(--fb-radius);
}
.fb-card--feature::before{
  content:""; position:absolute; top:13px; right:8px; width:30px; height:2px;
  background:rgba(28,30,36,.16); z-index:1; transform:rotate(-45deg);
}

/* ---- fb-logos (integration / carrier strip) --------------- */
.fb-logos{ display:flex; flex-wrap:wrap; align-items:center; gap:22px 30px;
  margin-top:20px; padding-top:20px; border-top:1px solid var(--border); }
.fb-logos img{ height:22px; width:auto; opacity:.78;
  filter:grayscale(1) brightness(.55); transition:opacity .2s var(--fb-ease), filter .2s var(--fb-ease); }
.fb-card:hover .fb-logos img{ opacity:.9; }

/* ============================================================
   SECTION: Facts → proof stats band
   ============================================================ */
.facts-section{ background:var(--bg); padding:70px 24px 20px !important; }
.facts-section .container-3{ max-width:var(--fb-maxw) !important; }

/* ============================================================
   SECTION: Fulfillment solutions
   ============================================================ */
.section-how-build{ background:var(--bg) !important; padding:80px 24px !important; overflow-x:clip; }
.section-how-build .container-4{ max-width:var(--fb-maxw) !important; }

/* ---- editorial capability index (replaces the solution cards) ---- */
.fb-index{ display:grid; grid-template-columns:1fr 1fr; column-gap:clamp(36px,5vw,72px); margin-top:8px; }
.fb-idx-item{ display:flex; gap:22px; align-items:baseline; padding:26px 6px;
  border-top:1px solid var(--border); cursor:default;
  transition:background-color .25s var(--fb-ease); }
.fb-index-col .fb-idx-item:last-child{ border-bottom:1px solid var(--border); }
.fb-idx-n{ font-family:'Satoshi',sans-serif; font-weight:800; letter-spacing:-.02em;
  font-size:clamp(24px,2.3vw,32px); line-height:1; color:var(--faint); flex:none; width:42px;
  transition:color .25s var(--fb-ease); }
.fb-idx-body{ text-align:left; transition:transform .25s var(--fb-ease); }
.fb-idx-body h3{ font-family:'Satoshi',sans-serif; font-weight:800; font-size:18px; line-height:1.25;
  letter-spacing:-.01em; color:var(--ink); margin:0 0 6px; }
.fb-idx-body p{ font-family:'Satoshi',sans-serif; font-weight:500; font-size:14.5px; line-height:1.5;
  color:var(--sub); margin:0; max-width:42ch; }
.fb-idx-item:hover .fb-idx-n{ color:var(--green-d); }
.fb-idx-item:hover .fb-idx-body{ transform:translateX(5px); }
@media (max-width:760px){
  .fb-index{ grid-template-columns:1fr; }
  /* avoid a doubled rule where the two columns would meet */
  .fb-index-col:last-child .fb-idx-item:first-child{ border-top:0; }
  .fb-index-col:first-child .fb-idx-item:last-child{ border-bottom:0; }
}

/* ============================================================
   Fulfillment · self-playing (looping) Lottie cardboard box
   ============================================================ */
.fb-fulfill{ position:relative; margin:10px 0 40px; }
.fb-fulfill-sticky{
  display:grid; grid-template-columns:1.05fr 1fr; gap:48px; align-items:center;
}
.fb-fulfill-copy .fb-head{ margin-bottom:30px; }
.fb-steps{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:4px; }
.fb-step{ display:flex; align-items:flex-start; gap:14px; padding:14px 16px; border-radius:12px;
  border:1px solid transparent; transition:background-color .3s var(--fb-ease), border-color .3s var(--fb-ease); }
.fb-step.is-active{ background:var(--card); border-color:var(--border); box-shadow:var(--fb-shadow); }
.fb-step-n{ font-family:'Satoshi',sans-serif; font-weight:800; font-size:13px; color:var(--faint);
  flex:none; width:24px; padding-top:1px; transition:color .3s var(--fb-ease); }
.fb-step.is-active .fb-step-n{ color:var(--green-d); }
.fb-step-tx{ font-family:'Satoshi',sans-serif; font-weight:500; font-size:15px; line-height:1.45; color:var(--sub); }
.fb-step-tx b{ color:var(--ink); font-weight:700; }

/* overflow visible so the box can travel past the column; the section clips it
   at the screen edge (set below) instead of inside the stage */
.fb-box-stage{ position:relative; display:grid; place-items:center; height:460px; overflow:visible; }
/* progress vars set by JS (0..1) */
.fb-lottie-stage{ position:relative; width:440px; max-width:100%; height:400px;
  display:grid; place-items:center; --drop:0; --ship:0; }

/* the box ships off the whole way to the screen edge */
.fb-ship-group{ position:relative; width:100%; height:100%; display:grid; place-items:center;
  transform:translateX(calc(var(--ship)*82vw)); }

/* Lottie renders its <svg> into here */
.fb-lottie{ width:440px; height:367px; }
.fb-lottie svg{ display:block; }

/* shampoo bottle drops from above into the open box, then fades as it closes */
/* USPS shipping label · centered & pressed onto the box's RIGHT face (isometric
   skew so it lies flush on the angled side), slaps on with --label, ships with box */
.fb-label{ position:absolute; left:60.5%; top:55%; width:80px;
  z-index:3; background:#fff; border-radius:3px; box-shadow:0 1px 3px rgba(28,30,36,.22);
  display:flex; flex-direction:column; padding:0; overflow:visible;
  transform-origin:50% 50%;
  /* skewY(-26deg) maps the flat label onto the up-to-the-right box face;
     scale settles from slightly oversized → flush (the "press on") */
  transform:translate(-50%,-50%) skewY(-26deg) scale(calc(1.16 - var(--label,0)*0.16));
  opacity:calc(var(--label,0)*1.4); }
/* tiny peeled bottom-left corner (underside of the label, lifting with a shadow) */
.fb-label::after{ content:""; position:absolute; left:-1px; bottom:-1px; width:15px; height:15px;
  background:#E8E6E2; border-bottom-left-radius:3px;
  clip-path:polygon(0 0, 0 100%, 100% 100%);
  transform:rotate(7deg); transform-origin:bottom left;
  box-shadow:2px -2px 3px rgba(28,30,36,.25); }
.fb-label-head{ display:flex; align-items:center; gap:6px; padding:5px 7px 4px;
  border-bottom:2px solid #DA291C; /* USPS red rule */ }
.fb-usps{ width:30px; height:auto; flex:none; }
.fb-usps-tx{ font-family:'Satoshi',sans-serif; font-weight:800; font-size:7.5px; line-height:1.05;
  letter-spacing:.02em; color:#333366; }
.fb-label-bars{ height:15px; margin:5px 7px 6px; background:#1C1E24;
  box-shadow:2px 0 0 #fff inset, 5px 0 0 #1C1E24 inset, 8px 0 0 #fff inset, 11px 0 0 #1C1E24 inset,
    15px 0 0 #fff inset, 18px 0 0 #1C1E24 inset, 22px 0 0 #fff inset, 25px 0 0 #1C1E24 inset,
    29px 0 0 #fff inset, 33px 0 0 #1C1E24 inset, 38px 0 0 #fff inset, 42px 0 0 #1C1E24 inset; }

/* shipped badge appears centre-stage as the box leaves */
.fb-ship-badge{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%) scale(calc(.85 + var(--ship)*.15));
  display:inline-flex; align-items:center; gap:8px; white-space:nowrap; z-index:3;
  background:var(--green); color:#fff; font-family:'Satoshi',sans-serif; font-weight:800; font-size:16px;
  padding:11px 20px; border-radius:99px; box-shadow:0 10px 26px rgba(43,158,143,.35);
  opacity:calc(max(0, var(--ship)*2 - 1)); pointer-events:none; }
.fb-ship-badge svg{ width:18px; height:18px; }

@media (max-width:860px){
  .fb-fulfill{ height:auto; margin-bottom:30px; }
  .fb-fulfill-sticky{ position:static; grid-template-columns:1fr; gap:24px; min-height:0; }
  .fb-box-stage{ height:380px; order:-1; }
}

/* ============================================================
   SECTION: Green CTA band → fb-cta-band
   ============================================================ */
.section-call-to-action{ background:var(--bg); padding:40px 24px 80px; }
.fb-cta{
  /* full-bleed: span the whole viewport and hit the sides */
  max-width:none; width:100vw; margin-left:calc(-50vw + 50%);
  position:relative; overflow:hidden;
  background:var(--green); border-radius:0; color:#fff;
  padding-top:64px; padding-bottom:64px;
  /* keep inner content aligned to the content column */
  padding-left:max(28px, calc((100vw - var(--fb-maxw)) / 2));
  padding-right:max(28px, calc((100vw - var(--fb-maxw)) / 2));
  box-shadow:none;
}
.fb-cta-grid{ display:grid; grid-template-columns:1.3fr .9fr; gap:40px; align-items:center; }
.fb-cta-text{ max-width:760px; }
.fb-cta h2{
  font-family:'Satoshi',sans-serif; font-weight:900; letter-spacing:-.02em;
  font-size:clamp(26px,3.4vw,40px); line-height:1.08; margin:0 0 16px; color:#fff;
}
.fb-cta p{ font-family:'Satoshi',sans-serif; font-weight:500; font-size:16px; line-height:1.55;
  color:rgba(255,255,255,.86); margin:0 0 24px; max-width:46ch; }
.fb-cta-actions{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; }
.fb-cta-note{ font-family:'Satoshi',sans-serif; font-weight:600; font-size:13.5px; color:rgba(255,255,255,.82); }
.fb-cta-stats{ display:flex; flex-direction:column; gap:16px; }
.fb-cta-stat{ background:rgba(255,255,255,.10); border:1px solid rgba(255,255,255,.18);
  border-radius:14px; padding:18px 20px; }
.fb-cta-stat .n{ font-family:'Satoshi',sans-serif; font-weight:900; font-size:30px; line-height:1; color:#fff; }
.fb-cta-stat .l{ font-family:'Satoshi',sans-serif; font-weight:500; font-size:13.5px; color:rgba(255,255,255,.82); margin-top:6px; }

/* ============================================================
   SECTION: Technologies & integrations
   ============================================================ */
.section-auto-reply{ background:var(--bg) !important; padding:80px 24px !important; }
.section-auto-reply .container-6{ max-width:var(--fb-maxw) !important; }
.fb-tech-grid{ display:grid; grid-template-columns:1fr 1fr; gap:22px; }

/* ---- fb-bento · ONE combined card, 2x2 with hairline dividers ---- */
.fb-bento{
  display:grid; grid-template-columns:1fr 1fr; grid-template-rows:auto auto;
  background:var(--card); border:1px solid var(--border); border-radius:18px;
  overflow:hidden; box-shadow:var(--fb-shadow);
}
.b-cell{ position:relative; display:flex; flex-direction:column; padding:30px; min-width:0; }
/* internal dividers (no gaps — shared hairlines) */
.b-cell-a{ border-right:1px solid var(--border); border-bottom:1px solid var(--border); }
.b-cell-b{ border-bottom:1px solid var(--border); }
.b-cell-c{ border-right:1px solid var(--border); }

.b-eyebrow{ display:inline-flex; align-items:center; gap:8px;
  font-family:'Satoshi',sans-serif; font-weight:600; font-size:12.5px; letter-spacing:.01em;
  color:var(--sub); margin-bottom:14px; }
.b-eyebrow svg{ width:16px; height:16px; color:var(--faint); flex:none; }
.b-h{ font-family:'Satoshi',sans-serif; font-weight:700; font-size:19px; line-height:1.34;
  letter-spacing:-.01em; color:var(--ink); margin:0; }
.b-h .mut{ color:var(--sub); font-weight:500; }

/* map */
.b-map-stage{ position:relative; flex:1; margin-top:20px; min-height:176px;
  border-radius:12px; overflow:hidden; background:var(--bg); border:1px solid var(--border); }
.b-mapsvg{ display:block; width:100%; height:100%; position:absolute; inset:0; }
.b-pin{ position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  display:inline-flex; align-items:center; gap:7px; white-space:nowrap;
  background:var(--card); border:1px solid var(--border); border-radius:99px;
  padding:7px 13px; font-family:'Satoshi',sans-serif; font-weight:700; font-size:12.5px; color:var(--ink);
  box-shadow:0 4px 14px rgba(28,30,36,.10); }
.b-pin-dot{ display:none; }

/* CX toast */
.b-toast{ display:flex; align-items:center; gap:12px; margin-top:auto;
  background:var(--bg); border:1px solid var(--border); border-radius:13px; padding:13px 15px; }
.b-toast-av{ width:34px; height:34px; border-radius:50%; background:var(--green); flex:none;
  display:grid; place-items:center; }
.b-toast-av svg{ width:17px; height:17px; }
.b-toast-t{ font-family:'Satoshi',sans-serif; font-weight:700; font-size:12.5px; color:var(--ink); }
.b-toast-s{ font-family:'Satoshi',sans-serif; font-weight:500; font-size:12.5px; color:var(--sub); margin-top:2px; }

/* inventory chart */
.b-chartwrap{ margin-top:20px; flex:1; min-height:120px; display:flex; align-items:flex-end; }
.b-linechart{ width:100%; height:120px; display:block; }

/* bottom-right cell · split into two arrow sub-cards */
.b-cell-d{ padding:0; display:grid; grid-template-columns:1fr 1fr; }
.b-sub{ position:relative; display:flex; flex-direction:column; padding:30px; min-width:0;
  min-height:200px; text-decoration:none; text-align:left;
  transition:background-color .2s var(--fb-ease); }
.b-sub + .b-sub{ border-left:1px solid var(--border); }
.b-sub:hover{ background:var(--bg); }
.b-sub .b-h{ font-size:17px; }
.b-arrow{ position:absolute; right:24px; bottom:24px; width:38px; height:38px; border-radius:50%;
  border:1px solid var(--border); display:grid; place-items:center; color:var(--ink);
  background:var(--card); transition:background-color .2s var(--fb-ease), color .2s var(--fb-ease), transform .2s var(--fb-ease); }
.b-arrow svg{ width:17px; height:17px; }
.b-sub:hover .b-arrow{ background:var(--green); color:#fff; border-color:var(--green); transform:translateX(2px); }

@media (max-width:760px){
  .fb-bento{ grid-template-columns:1fr; }
  .b-cell-a{ border-right:0; }
  .b-cell-c{ border-right:0; border-bottom:1px solid var(--border); }
  .b-cell-b{ border-bottom:1px solid var(--border); }
}
@media (max-width:480px){
  .b-cell-d{ grid-template-columns:1fr; }
  .b-sub + .b-sub{ border-left:0; border-top:1px solid var(--border); }
}

/* ============================================================
   SECTION: Dashboard window — restyle tabs to ghost-underline
   (markup unchanged; overriding revamp.css .rv-tab pills)
   ============================================================ */
.rv-dash-tabs{ gap:4px !important; background:transparent !important; border:0 !important;
  border-bottom:1px solid var(--border) !important; border-radius:0 !important;
  padding:0 !important; box-shadow:none !important; }
.rv-tab{
  background:transparent !important; border:0 !important; border-radius:0 !important;
  color:var(--sub) !important; font-weight:700 !important; padding:11px 16px !important;
  position:relative; box-shadow:none !important;
}
.rv-tab::after{ content:""; position:absolute; left:10px; right:10px; bottom:-1px; height:2px;
  background:var(--green); transform:scaleX(0); transform-origin:center; transition:transform .25s var(--fb-ease); }
.rv-tab:hover{ color:var(--ink) !important; }
.rv-tab.is-active{ color:var(--green-d) !important; background:transparent !important; }
.rv-tab.is-active::after{ transform:scaleX(1); }

/* ============================================================
   SECTION: FAQ → fb-faq
   ============================================================ */
.section-faq{ background:var(--bg) !important; padding:80px 24px !important; }
.section-faq .container-7{ max-width:840px !important; }
.fb-faq{ border-top:1px solid var(--border); }
.fb-faq .accordion__item{ border-bottom:1px solid var(--border) !important;
  background:transparent !important; box-shadow:none !important; border-radius:0 !important; margin:0 !important; }
.fb-faq .accordion-header{ padding:24px 6px !important; cursor:pointer; }
.fb-faq .question-text{ font-family:'Satoshi',sans-serif !important; font-weight:700 !important;
  font-size:18px !important; color:var(--ink) !important; margin:0 !important; }
.fb-faq .question-text strong{ font-weight:700 !important; }
.fb-faq .accordion-body__contents{ font-family:'Satoshi',sans-serif !important; font-weight:500 !important;
  font-size:15px !important; line-height:1.62 !important; color:var(--sub) !important;
  padding:0 6px 26px !important; max-width:70ch; }

/* ============================================================
   SECTION: Pricing → fb-plan
   ============================================================ */
.section-plans{ background:var(--bg) !important; padding:80px 24px !important; }
.section-plans .container-8{ max-width:var(--fb-maxw) !important; }
.fb-plans{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; align-items:stretch; }
.fb-plan{
  position:relative; display:flex; flex-direction:column;
  background:var(--card); border:1px solid var(--border); border-radius:18px;
  padding:32px 28px; box-shadow:var(--fb-shadow); text-align:left;
  transition:transform .22s var(--fb-ease), box-shadow .22s var(--fb-ease);
}
.fb-plan:hover{ transform:translateY(-4px); box-shadow:var(--fb-shadow-h); }
.fb-plan--featured{ border:1.5px solid var(--green); box-shadow:0 2px 6px rgba(28,30,36,.07), 0 24px 54px rgba(43,158,143,.16); }
.fb-plan-tag{ position:absolute; top:-12px; left:28px; background:var(--green); color:#fff;
  font-family:'Satoshi',sans-serif; font-weight:700; font-size:12px; letter-spacing:.04em;
  padding:5px 12px; border-radius:99px; }
.fb-plan h3{ font-family:'Satoshi',sans-serif; font-weight:800; font-size:20px; color:var(--ink); margin:0 0 6px; }
.fb-plan .fb-plan-sub{ font-family:'Satoshi',sans-serif; font-weight:500; font-size:13.5px; line-height:1.5; color:var(--sub); margin:0 0 20px; min-height:40px; }
.fb-plan-price{ display:flex; align-items:baseline; gap:6px; padding-bottom:22px; margin-bottom:22px; border-bottom:1px solid var(--border); }
.fb-plan-price .amt{ font-family:'Satoshi',sans-serif; font-weight:900; font-size:42px; letter-spacing:-.02em; color:var(--ink); line-height:1; }
.fb-plan-price .per{ font-family:'Satoshi',sans-serif; font-weight:500; font-size:14px; color:var(--sub); }
.fb-plan-feats{ list-style:none; margin:0 0 26px; padding:0; display:flex; flex-direction:column; gap:13px; flex:1; }
.fb-plan-feats li{ position:relative; padding-left:28px; font-family:'Satoshi',sans-serif; font-weight:500;
  font-size:14.5px; line-height:1.45; color:var(--ink); }
.fb-plan-feats li::before{ content:""; position:absolute; left:0; top:1px; width:18px; height:18px;
  border-radius:50%; background:var(--green-soft);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%231F7A6F' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:center; }
.fb-plan .fb-btn{ width:100%; justify-content:center; }

/* ============================================================
   SECTION: Testimonials → fb-quote (restyle slider cards)
   ============================================================ */
.section-client-review{ background:var(--bg) !important; padding:80px 24px !important; }
.section-client-review .container-9{ max-width:980px !important; }
.slide-inner-2{
  position:relative; background:var(--card) !important; border:1px solid var(--border) !important;
  border-radius:20px !important; box-shadow:var(--fb-shadow) !important;
  padding:46px clamp(28px,4vw,56px) 36px !important;
}
.slide-inner-2::before{
  content:"\201C"; position:absolute; top:18px; left:26px;
  font-family:Georgia,'Times New Roman',serif; font-size:96px; line-height:1;
  color:var(--green-soft); z-index:0;
}
.slide-inner-2 .image-21{ position:relative; z-index:1; }
.slide-inner-2 .client-quote{
  font-family:'Satoshi',sans-serif !important; font-weight:500 !important;
  font-size:clamp(17px,1.7vw,21px) !important; line-height:1.55 !important;
  color:var(--ink) !important; position:relative; z-index:1; letter-spacing:-.01em;
}
.section-client-review .div-block-10{ border-top:1px solid var(--border); padding-top:20px; margin-top:6px; }
.section-client-review .text-block-32{ font-family:'Satoshi',sans-serif !important; font-weight:700 !important; color:var(--ink) !important; }
.section-client-review .text-block-31{ font-family:'Satoshi',sans-serif !important; font-weight:500 !important; color:var(--green-d) !important; }
.review-btn{ display:flex !important; width:max-content; margin:34px auto 0 !important; }

/* ============================================================
   Footer — light cleanup to match system
   ============================================================ */
.section-footer{ background:var(--bg) !important; }
.section-footer .heading-11{ font-family:'Satoshi',sans-serif !important; font-weight:800 !important; }
.section-footer .paragraph-9{ font-family:'Satoshi',sans-serif !important; }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:900px){
  .fb-grid-4{ grid-template-columns:1fr 1fr; }
  .fb-tech-grid{ grid-template-columns:1fr; }
  .fb-cta-grid{ grid-template-columns:1fr; gap:28px; }
  .fb-plans{ grid-template-columns:1fr; max-width:460px; margin:0 auto; }
}
@media (max-width:760px){
  .fb-section{ padding:64px 20px; }
  .fb-stats{ grid-template-columns:1fr; }
  .fb-grid-2{ grid-template-columns:1fr; }
  .fb-grid-4{ grid-template-columns:1fr; }
}

/* ============================================================
   Reduced motion
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  .fb-eyebrow .dot, .b-pin-dot{ animation:none; }
  .fb-rule.draw{ transition:none; transform:scaleX(1); }
  .fb-btn, .fb-card, .fb-stat, .fb-plan, .b-sub, .b-arrow{ transition:none; }
  .fb-btn:hover, .fb-card:hover, .fb-stat:hover, .fb-plan:hover,
  .b-sub:hover .b-arrow{ transform:none; }
  .rv-tab::after{ transition:none; }
}

/* restored hero warehouse illustration (centered showpiece) */
.rv-herofig-c{ max-width:600px; margin:38px auto 0; }
.rv-herofig-c .rv-heroimg{ width:100%; height:auto; display:block; }

/* two-column hero: copy left, illustration right */
.rv-hero2-2col .rv-hero2-grid{
  max-width:1240px; margin:0 auto;
  padding:clamp(28px,6vh,72px) clamp(20px,5vw,52px) clamp(18px,3vh,36px);
  display:grid; grid-template-columns:1.04fr 1.02fr; gap:clamp(28px,4.5vw,64px); align-items:center;
}
.rv-hero2-2col .rv-hero2-inner{ max-width:none!important; margin:0!important; text-align:left!important; border:0!important; padding:0!important; }
.rv-hero2-2col .rv-hero2-inner::before, .rv-hero2-2col .rv-hero2-inner::after{ display:none!important; }
.rv-hero2-2col .rv-h1{ text-align:left; max-width:none; margin:0 0 18px; }
.rv-hero2-2col .rv-lede2{ margin-left:0; margin-right:0; }
.rv-hero2-2col .rv-cta2{ justify-content:flex-start; }
.rv-hero2-2col .rv-herofig{ margin:0!important; max-width:none!important; }
.rv-hero2-2col .rv-heroimg{ width:100%; height:auto; display:block; }
@media (max-width:900px){
  .rv-hero2-2col .rv-hero2-grid{ grid-template-columns:1fr; }
  .rv-hero2-2col .rv-herofig{ order:2; max-width:520px; margin:0 auto!important; }
}

/* ── Solutions as compact card grid (smaller illustrations) ── */
.fb-sol-grid{ display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.fb-sol{ background:var(--card); border:1px solid var(--border); border-radius:var(--fb-radius);
  padding:24px 26px 22px; box-shadow:var(--fb-shadow); display:flex; flex-direction:column;
  transition:transform .22s var(--fb-ease), box-shadow .22s var(--fb-ease); }
.fb-sol:hover{ transform:translateY(-3px); box-shadow:var(--fb-shadow-h); }
.fb-sol-art{ height:158px; display:flex; align-items:center; justify-content:center;
  background:var(--bg); border:1px solid var(--border); border-radius:var(--fb-radius-sm);
  margin-bottom:18px; padding:14px; }
.fb-sol-art img{ max-height:100%; max-width:100%; width:auto; object-fit:contain; }
.fb-sol h3{ font-family:'Satoshi',sans-serif; font-weight:800; font-size:20px; letter-spacing:-.01em;
  color:var(--ink); margin:0 0 8px; }
.fb-sol p{ font-family:'Satoshi',sans-serif; font-weight:500; font-size:14.5px; line-height:1.55;
  color:var(--sub); margin:0; }
.fb-sol-logos{ display:flex; flex-wrap:wrap; align-items:center; gap:16px 22px;
  margin-top:auto; padding-top:18px; border-top:1px solid var(--border); }
.fb-sol-logos img{ height:20px; width:auto; filter:brightness(0); opacity:.5; }
@media (max-width:820px){ .fb-sol-grid{ grid-template-columns:1fr; } }

/* ── Unified "Book a call" CTA (adapted from 21st.dev book-a-call-button, green, no surface gradient) ── */
.fb-bookcall{
  display:inline-flex; align-items:center; gap:9px;
  background:var(--green); color:#fff; text-decoration:none;
  font-family:'Satoshi',sans-serif; font-weight:700; font-size:15px;
  padding:13px 24px; border-radius:999px; border:0; cursor:pointer;
  position:relative; overflow:hidden; white-space:nowrap;
  box-shadow:0 1px 2px rgba(31,122,111,.22), 0 8px 18px rgba(43,158,143,.24);
  transition:transform .18s var(--fb-ease), box-shadow .25s var(--fb-ease), background-color .18s var(--fb-ease);
}
.fb-bookcall svg{ width:17px; height:17px; flex:none; transition:transform .25s var(--fb-ease); }
.fb-bookcall:hover{ background:var(--green-d); transform:translateY(-2px);
  box-shadow:0 12px 26px rgba(43,158,143,.34); }
.fb-bookcall:hover svg{ transform:rotate(-14deg) scale(1.08); }   /* phone "ring" tilt */
.fb-bookcall:active{ transform:scale(.96); }
/* shine sweep on hover */
.fb-bookcall::after{
  content:""; position:absolute; top:0; left:-60%; width:45%; height:100%;
  background:linear-gradient(100deg, transparent, rgba(255,255,255,.38), transparent);
  transform:skewX(-18deg); pointer-events:none; transition:left .6s var(--fb-ease);
}
.fb-bookcall:hover::after{ left:130%; }
@media (prefers-reduced-motion:reduce){ .fb-bookcall, .fb-bookcall svg, .fb-bookcall::after{ transition:none; } }

/* Book-a-call button on the green CTA band -> white for contrast */
.fb-cta .fb-bookcall{ background:#fff; color:var(--green-d);
  box-shadow:0 1px 2px rgba(12,40,36,.14), 0 10px 24px rgba(12,40,36,.20); }
.fb-cta .fb-bookcall:hover{ background:#F2FBF9; color:var(--green-d); }

/* ── Testimonials: 3-column scrolling wall (21st.dev style, green) ── */
.fb-testi{ background:var(--bg); padding:90px 24px; overflow:hidden; }
.fb-testi-cols{ max-width:var(--fb-maxw); margin:0 auto; display:grid; grid-template-columns:repeat(3,1fr); gap:18px; height:560px; overflow:hidden;
  -webkit-mask-image:linear-gradient(180deg,transparent,#000 13%,#000 87%,transparent);
          mask-image:linear-gradient(180deg,transparent,#000 13%,#000 87%,transparent); }
.fb-testi-col{ overflow:hidden; }
.fb-testi-track{ display:flex; flex-direction:column; gap:18px; animation:fb-scroll-up var(--dur,34s) linear infinite; will-change:transform; }
.fb-testi-cols:hover .fb-testi-track{ animation-play-state:paused; }
@keyframes fb-scroll-up{ from{ transform:translateY(0); } to{ transform:translateY(-50%); } }
.fb-testi-card{ background:var(--card); border:1px solid var(--border); border-radius:16px; padding:22px 22px 20px; box-shadow:var(--fb-shadow); margin:0; }
.fb-testi-stars{ display:block; color:#E0A422; font-size:13px; letter-spacing:3px; margin-bottom:12px; }
.fb-testi-card blockquote{ margin:0 0 16px; font-family:'Satoshi',sans-serif; font-weight:500; font-size:14.5px; line-height:1.6; color:var(--ink); }
.fb-testi-by{ display:flex; align-items:center; gap:11px; }
.fb-testi-av{ width:40px; height:40px; border-radius:50%; background:var(--green-soft); color:var(--green-d); display:grid; place-items:center; font-family:'Satoshi',sans-serif; font-weight:800; font-size:13px; flex:none; }
.fb-testi-av-img{ width:42px; height:42px; border-radius:50%; object-fit:cover; flex:none; border:1px solid var(--border); }
.fb-testi-meta b{ display:block; font-family:'Satoshi',sans-serif; font-weight:700; font-size:14px; color:var(--ink); }
.fb-testi-meta small{ font-size:12.5px; color:var(--sub); }
.fb-testi-cta{ text-align:center; margin-top:40px; }
@media (max-width:820px){ .fb-testi-cols{ grid-template-columns:1fr 1fr; } .fb-col-3{ display:none; } }
@media (max-width:560px){ .fb-testi-cols{ grid-template-columns:1fr; } .fb-col-2{ display:none; } }
@media (prefers-reduced-motion:reduce){ .fb-testi-track{ animation:none; } }
