/* ═══════════════════════════════════
   TOKENS  (aligned with Magpiie design system)
═══════════════════════════════════ */
:root{
  --bg:#0B0A11; --surf:#121019; --raised:#1A1724; --card:#1E1B2C;
  --bdr:rgba(139,116,199,.15); --bdh:rgba(139,116,199,.32);
  --purple:#8B74C7; --gold:#E6AA5A; --rose:#C46F6E;
  --hi:#ffffff; --md:#8E879A; --lo:#7a6ea8; --green:#6ce89a;
  --grad:linear-gradient(135deg,#E6AA5A 0%,#8B74C7 55%,#C46F6E 100%);
}
.bf{ background:var(--bg); font-family:'Urbanist',sans-serif,Arial,sans-serif; overflow-x:hidden; }
.bf-grid-bg{
  position:fixed; inset:0; pointer-events:none; z-index:0;
  background-image:linear-gradient(rgba(139,116,199,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(139,116,199,.035) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 90% 80% at 50% 30%,black 5%,transparent 100%);
}
.bf .sec{ padding:100px 0; position:relative; z-index:2; }
.bf .sec.surf{ background:var(--surf); }
.bf .sec.dark{ background:#09080F; }
.bf .sdiv{ width:100%; height:1px; background:linear-gradient(90deg,transparent,var(--bdr),transparent); }

/* Eyebrow */
.bf .eb{ display:inline-flex; align-items:center; gap:8px; background:rgba(139,116,199,.10); border:1px solid rgba(139,116,199,.22); border-radius:50px; padding:5px 16px 5px 8px; margin-bottom:18px; }
.bf .eb-dot{ width:7px; height:7px; border-radius:50%; background:var(--grad); box-shadow:0 0 8px rgba(139,116,199,.6); animation:bfBlink 2.4s ease-in-out infinite; }
@keyframes bfBlink{ 0%,100%{opacity:1;} 50%{opacity:.3;} }
.bf .eb span{ font-size:11px; font-weight:700; letter-spacing:.09em; text-transform:uppercase; color:var(--lo); }

/* Headlines */
.bf .sh{ font-size:clamp(28px,3.8vw,52px); font-weight:500; line-height:1.07; letter-spacing:-.033em; color:var(--hi); margin-bottom:14px; }
.bf .sh .g{ background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; background-size:200% auto; animation:bfGrad 5s ease infinite; display:inline-block; padding-bottom:8px; line-height:1.15; }
@keyframes bfGrad{ 0%,100%{background-position:0% center;} 50%{background-position:100% center;} }
.bf .ss{ font-size:16px; line-height:1.75; color:var(--lo); max-width:640px; }
.bf .ss.c{ margin:0 auto; text-align:center; }

/* Reveal */
.bf .rv{ opacity:0; transform:translateY(22px); transition:opacity .7s ease,transform .7s cubic-bezier(.22,.68,0,1.2); }
.bf .rv.on{ opacity:1; transform:translateY(0); }
.bf .rvl{ opacity:0; transform:translateX(-26px); transition:opacity .7s ease,transform .7s cubic-bezier(.22,.68,0,1.2); }
.bf .rvl.on{ opacity:1; transform:translateX(0); }
.bf .rvr{ opacity:0; transform:translateX(26px); transition:opacity .7s ease,transform .7s cubic-bezier(.22,.68,0,1.2); }
.bf .rvr.on{ opacity:1; transform:translateX(0); }
.bf .sc{ opacity:0; transform:scale(.94); transition:opacity .7s ease,transform .8s cubic-bezier(.22,.68,0,1.25); }
.bf .sc.on{ opacity:1; transform:scale(1); }
.bf .d1{transition-delay:.06s!important;} .bf .d2{transition-delay:.13s!important;}
.bf .d3{transition-delay:.20s!important;} .bf .d4{transition-delay:.27s!important;}
.bf .d5{transition-delay:.34s!important;} .bf .d6{transition-delay:.41s!important;}

/* Buttons */
.bf .btn-p{ display:inline-flex; align-items:center; gap:9px; background:linear-gradient(135deg,#8B74C7,#4a4e8a); color:#fff; font-weight:700; font-size:14.5px; padding:14px 28px; border-radius:12px; text-decoration:none; box-shadow:0 4px 28px rgba(139,116,199,.40); transition:transform .25s cubic-bezier(.22,.68,0,1.2),box-shadow .25s; position:relative; overflow:hidden; }
.bf .btn-p::after{ content:''; position:absolute; top:0; left:-75%; width:50%; height:100%; background:linear-gradient(90deg,transparent,rgba(255,255,255,.10),transparent); transform:skewX(-18deg); transition:left .5s; pointer-events:none; }
.bf .btn-p:hover::after{ left:130%; }
.bf .btn-p:hover{ transform:translateY(-2px) scale(1.02); box-shadow:0 10px 36px rgba(139,116,199,.55); color:#fff; text-decoration:none; }
.bf .btn-p svg{ transition:transform .2s; } .bf .btn-p:hover svg{ transform:translateX(3px); }
.bf .btn-o{ display:inline-flex; align-items:center; gap:8px; background:transparent; border:1px solid rgba(200,191,240,.18); color:var(--md); font-weight:600; font-size:14.5px; padding:13px 24px; border-radius:12px; text-decoration:none; transition:all .25s; }
.bf .btn-o:hover{ background:rgba(200,191,240,.07); border-color:rgba(200,191,240,.38); color:#fff; text-decoration:none; }

/* ═══════════════════════════════════
   HERO
═══════════════════════════════════ */
.bf-hero{ min-height:90vh; display:flex; align-items:center; padding:60px 0 90px; position:relative; z-index:2; overflow:hidden; }
.bf-orb{ position:absolute; border-radius:50%; pointer-events:none; z-index:0; }
.bf-o1{ width:680px; height:680px; background:radial-gradient(circle,rgba(139,116,199,.16) 0%,transparent 65%); top:-200px; right:-140px; animation:bfFloat 12s ease-in-out infinite; }
.bf-o2{ width:460px; height:460px; background:radial-gradient(circle,rgba(230,170,90,.10) 0%,transparent 65%); bottom:-80px; left:-100px; animation:bfFloat 16s ease-in-out 5s infinite reverse; }
@keyframes bfFloat{ 0%,100%{transform:translate(0,0) scale(1);} 33%{transform:translate(-18px,14px) scale(1.05);} 66%{transform:translate(12px,-10px) scale(.97);} }
.bf-hero-inner{ position:relative; z-index:3; display:grid; grid-template-columns:1.05fr .95fr; gap:60px; align-items:center; }
.bf-hl{ font-size:clamp(40px,6vw,72px); font-weight:500; line-height:1.08; letter-spacing:-.038em; color:var(--hi); padding-bottom:6px; animation:bfRise .8s cubic-bezier(.22,.68,0,1.2) .1s both; }
.bf-hl .g{ background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; background-size:200% auto; animation:bfGrad 5s ease infinite; display:inline-block; padding-bottom:8px; line-height:1.15; }
.bf-lead{ font-size:17.5px; line-height:1.78; color:var(--lo); max-width:520px; margin:22px 0 36px; animation:bfRise .8s cubic-bezier(.22,.68,0,1.2) .18s both; }
@keyframes bfRise{ from{opacity:0;transform:translateY(24px);} to{opacity:1;transform:translateY(0);} }
.bf-hero-ctas{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; animation:bfRise .8s cubic-bezier(.22,.68,0,1.2) .26s both; margin-bottom:40px; }
.bf-hero-stats{ display:flex; gap:0; background:rgba(22,19,48,.72); border:1px solid var(--bdr); border-radius:16px; overflow:hidden; backdrop-filter:blur(14px); animation:bfRise .8s cubic-bezier(.22,.68,0,1.2) .42s both; max-width:480px; }
.bf-hs{ flex:1; padding:16px 18px; text-align:center; position:relative; transition:background .3s; cursor:default; }
.bf-hs:hover{ background:rgba(139,116,199,.10); }
.bf-hs+.bf-hs::before{ content:''; position:absolute; left:0; top:20%; bottom:20%; width:1px; background:rgba(139,116,199,.18); }
.bf-hs-n{ font-size:22px; font-weight:900; letter-spacing:-.02em; line-height:1.1; background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.bf-hs-l{ font-size:10px; color:var(--lo); font-weight:500; text-transform:uppercase; letter-spacing:.06em; margin-top:3px; }

/* Hero collage */
.bf-collage{ position:relative; height:520px; animation:bfRise .9s cubic-bezier(.22,.68,0,1.1) .2s both; }
.bf-collage .cimg{ position:absolute; border-radius:18px; overflow:hidden; border:1px solid rgba(139,116,199,.20); box-shadow:0 24px 60px rgba(0,0,0,.5); background:#0f0d18; }
.bf-collage .cimg img{ width:100%; height:100%; object-fit:cover; display:block; }
.bf-collage .c1{ width:60%; height:54%; top:0; right:0; z-index:3; animation:bfFloatA 7s ease-in-out infinite; }
.bf-collage .c2{ width:52%; height:46%; bottom:0; left:0; z-index:2; animation:bfFloatA 9s ease-in-out .8s infinite reverse; }
.bf-collage .c3{ width:42%; height:40%; bottom:14%; right:6%; z-index:4; animation:bfFloatA 8s ease-in-out 1.4s infinite; }
@keyframes bfFloatA{ 0%,100%{transform:translateY(0) rotate(0);} 50%{transform:translateY(-12px) rotate(.4deg);} }
.bf-collage-glow{ position:absolute; inset:-10% 5% 5% -10%; background:radial-gradient(ellipse at center,rgba(139,116,199,.18),transparent 65%); filter:blur(20px); z-index:0; }

/* ═══════════════════════════════════
   MARQUEE - clientele
═══════════════════════════════════ */
.bf-clients{ background:var(--surf); border-top:1px solid var(--bdr); border-bottom:1px solid var(--bdr); padding:40px 0; overflow:hidden; position:relative; z-index:2; }
.bf-clients-label{ text-align:center; font-size:11px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--lo); margin-bottom:26px; }
.bf-marquee{ display:flex; gap:18px; width:max-content; animation:bfScroll 34s linear infinite; }
.bf-clients:hover .bf-marquee{ animation-play-state:paused; }
@keyframes bfScroll{ from{transform:translateX(0);} to{transform:translateX(-50%);} }
.bf-chip{ display:inline-flex; align-items:center; gap:10px; padding:12px 22px; border:1px solid var(--bdr); border-radius:50px; background:rgba(26,23,36,.6); white-space:nowrap; transition:border-color .3s,background .3s; }
.bf-chip:hover{ border-color:var(--bdh); background:rgba(139,116,199,.10); }
.bf-chip-dot{ width:8px; height:8px; border-radius:50%; background:var(--grad); flex-shrink:0; }
.bf-chip span{ font-size:14.5px; font-weight:600; color:var(--md); }
.bf-chip small{ font-size:11px; color:var(--lo); }

/* ═══════════════════════════════════
   CAPABILITIES (deliverables)
═══════════════════════════════════ */
.bf-cap-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:52px; }
.bf-cap{ background:var(--raised); border:1px solid var(--bdr); border-radius:22px; padding:34px 28px; position:relative; overflow:hidden; transition:border-color .3s,box-shadow .3s,transform .3s cubic-bezier(.22,.68,0,1.3); }
.bf-cap::before{ content:''; position:absolute; top:0; left:15%; right:15%; height:1px; background:linear-gradient(90deg,transparent,rgba(139,116,199,.40),transparent); opacity:0; transition:opacity .3s; }
.bf-cap:hover{ border-color:var(--bdh); box-shadow:0 20px 60px rgba(0,0,0,.40); transform:translateY(-5px); }
.bf-cap:hover::before{ opacity:1; }
.bf-cap-icon{ width:54px; height:54px; border-radius:16px; background:rgba(139,116,199,.12); border:1px solid var(--bdr); display:flex; align-items:center; justify-content:center; margin-bottom:22px; transition:transform .35s cubic-bezier(.22,.68,0,1.5),background .3s; }
.bf-cap-icon svg{ color:var(--purple); transition:color .3s; }
.bf-cap:hover .bf-cap-icon{ transform:scale(1.12) rotate(-6deg); background:rgba(139,116,199,.22); }
.bf-cap-title{ font-size:19px; font-weight:600; color:var(--hi); margin-bottom:10px; }
.bf-cap-desc{ font-size:14px; line-height:1.72; color:var(--lo); margin-bottom:16px; }
.bf-cap-tags{ display:flex; flex-wrap:wrap; gap:7px; }
.bf-cap-tag{ font-size:11px; font-weight:600; color:var(--md); padding:4px 11px; border-radius:20px; background:rgba(139,116,199,.08); border:1px solid rgba(139,116,199,.14); }

/* ═══════════════════════════════════
   PROCESS
═══════════════════════════════════ */
.bf-process{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; margin-top:54px; position:relative; }
.bf-step{ padding:0 24px; position:relative; }
.bf-step+.bf-step::before{ content:''; position:absolute; left:0; top:26px; width:1px; height:calc(100% - 26px); background:linear-gradient(180deg,var(--bdr),transparent); }
.bf-step-n{ width:52px; height:52px; border-radius:14px; background:linear-gradient(160deg,rgba(139,116,199,.20),rgba(20,17,46,.9)); border:1px solid rgba(139,116,199,.3); display:flex; align-items:center; justify-content:center; font-size:18px; font-weight:900; color:var(--hi); margin-bottom:20px; }
.bf-step-t{ font-size:17px; font-weight:600; color:var(--hi); margin-bottom:9px; }
.bf-step-d{ font-size:13.5px; line-height:1.65; color:var(--lo); }

/* ═══════════════════════════════════
   FEATURED PACKAGING SPOTLIGHT
═══════════════════════════════════ */
.bf-spot{ display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; margin-top:54px; }
.bf-spot-media{ position:relative; border-radius:24px; overflow:hidden; border:1px solid var(--bdr); box-shadow:0 30px 80px rgba(0,0,0,.5); }
.bf-spot-media img{ width:100%; display:block; }
.bf-spot-media::after{ content:''; position:absolute; inset:0; background:linear-gradient(160deg,transparent 60%,rgba(11,10,17,.35)); pointer-events:none; }
.bf-spot-tag{ display:inline-flex; align-items:center; gap:6px; font-size:11px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--gold); background:rgba(230,170,90,.10); border:1px solid rgba(230,170,90,.24); border-radius:20px; padding:5px 14px; margin-bottom:18px; }
.bf-spot h3{ font-size:clamp(26px,3vw,38px); font-weight:500; color:var(--hi); letter-spacing:-.025em; margin-bottom:14px; line-height:1.1; }
.bf-spot p{ font-size:15.5px; line-height:1.78; color:var(--lo); margin-bottom:18px; }
.bf-spot-meta{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:26px; }
.bf-meta-pill{ font-size:12px; color:var(--md); padding:6px 14px; border-radius:20px; background:rgba(139,116,199,.08); border:1px solid rgba(139,116,199,.16); }
.bf-meta-pill b{ color:var(--hi); font-weight:600; }

/* ═══════════════════════════════════
   CASE STUDIES GRID
═══════════════════════════════════ */
.bf-cases{ display:grid; grid-template-columns:repeat(2,1fr); gap:24px; margin-top:54px; }
.bf-case{ grid-column:span 1; background:var(--raised); border:1px solid var(--bdr); border-radius:24px; overflow:hidden; position:relative; transition:border-color .35s,box-shadow .35s,transform .4s cubic-bezier(.22,.68,0,1.2); display:flex; flex-direction:column; }
.bf-case.wide{ grid-column:span 2; }
.bf-case:hover{ border-color:var(--bdh); box-shadow:0 30px 80px rgba(0,0,0,.45); transform:translateY(-6px); }
.bf-case-media{ position:relative; overflow:hidden; aspect-ratio:16/9; background:#0f0d18; }
.bf-case.wide .bf-case-media{ aspect-ratio:21/9; }
.bf-case-media img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .8s cubic-bezier(.22,.68,0,1.1); }
.bf-case:hover .bf-case-media img{ transform:scale(1.05); }
.bf-case-media::after{ content:''; position:absolute; inset:0; background:linear-gradient(180deg,transparent 45%,rgba(15,13,24,.55)); pointer-events:none; }
.bf-case-body{ padding:26px 28px 30px; display:flex; flex-direction:column; flex:1; }
.bf-case-cat{ font-size:10.5px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--purple); margin-bottom:10px; }
.bf-case-title{ font-size:23px; font-weight:600; color:var(--hi); line-height:1.12; margin-bottom:6px; letter-spacing:-.02em; }
.bf-case-client{ font-size:13px; color:var(--md); margin-bottom:14px; }
.bf-case-desc{ font-size:14px; line-height:1.7; color:var(--lo); margin-bottom:18px; flex:1; }
.bf-case-media-tags{ display:flex; flex-wrap:wrap; gap:7px; }
.bf-case-mtag{ font-size:11px; font-weight:600; color:var(--md); padding:4px 11px; border-radius:20px; background:rgba(139,116,199,.07); border:1px solid rgba(139,116,199,.14); }

/* ═══════════════════════════════════
   LOGOFOLIO
═══════════════════════════════════ */
.bf-logos{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:50px; }
.bf-logo{ aspect-ratio:4/3; border-radius:18px; overflow:hidden; border:1px solid var(--bdr); position:relative; transition:border-color .3s,transform .35s cubic-bezier(.22,.68,0,1.2),box-shadow .3s; }
.bf-logo:hover{ border-color:var(--bdh); transform:translateY(-5px); box-shadow:0 20px 50px rgba(0,0,0,.45); }
.bf-logo img{ width:100%; height:100%; object-fit:cover; display:block; }
.bf-logo-cap{ position:absolute; left:0; right:0; bottom:0; padding:14px 16px; background:linear-gradient(180deg,transparent,rgba(9,8,15,.85)); }
.bf-logo-cap b{ display:block; font-size:13px; font-weight:700; color:#fff; }
.bf-logo-cap small{ font-size:11px; color:rgba(255,255,255,.6); }

/* ═══════════════════════════════════
   PORTFOLIO DOWNLOAD CTA
═══════════════════════════════════ */
.bf-dl{ background:linear-gradient(160deg,rgba(139,116,199,.16) 0%,rgba(20,17,46,.96) 100%); border:1px solid rgba(139,116,199,.30); border-radius:28px; padding:54px 48px; display:grid; grid-template-columns:1fr auto; gap:36px; align-items:center; position:relative; overflow:hidden; }
.bf-dl::before{ content:''; position:absolute; top:0; left:8%; right:8%; height:1px; background:linear-gradient(90deg,transparent,rgba(139,116,199,.65),transparent); animation:bfGlowLine 3.5s ease-in-out infinite; }
@keyframes bfGlowLine{ 0%,100%{opacity:.4;} 50%{opacity:1;} }
.bf-dl h3{ font-size:clamp(24px,2.6vw,34px); font-weight:500; color:var(--hi); letter-spacing:-.025em; margin-bottom:12px; line-height:1.12; }
.bf-dl p{ font-size:15px; line-height:1.7; color:var(--lo); max-width:520px; }

/* ═══════════════════════════════════
   FINAL CTA
═══════════════════════════════════ */
.bf-fcta{ text-align:center; max-width:720px; margin:0 auto; }
.bf-fcta .btn-p{ font-size:16px; padding:16px 34px; }
.bf-fcta-row{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top:30px; }

/* ═══════════════════════════════════
   RESPONSIVE
═══════════════════════════════════ */
@media (max-width:991px){
  .bf .sec{ padding:72px 0; }
  .bf-hero-inner{ grid-template-columns:1fr; gap:44px; }
  .bf-collage{ height:380px; }
  .bf-cap-grid{ grid-template-columns:1fr; }
  .bf-process{ grid-template-columns:1fr 1fr; gap:36px 0; }
  .bf-step+.bf-step:nth-child(odd)::before{ display:none; }
  .bf-spot{ grid-template-columns:1fr; gap:32px; }
  .bf-cases{ grid-template-columns:1fr; }
  .bf-case.wide{ grid-column:span 1; }
  .bf-case.wide .bf-case-media{ aspect-ratio:16/9; }
  .bf-logos{ grid-template-columns:1fr 1fr; }
  .bf-dl{ grid-template-columns:1fr; text-align:center; padding:42px 28px; }
  .bf-dl .btn-p{ justify-self:center; }
}
@media (max-width:560px){
  .bf-cap-grid,.bf-process{ grid-template-columns:1fr; }
  .bf-step+.bf-step::before{ display:none; }
  .bf-logos{ grid-template-columns:1fr; }
  .bf-hero-stats{ flex-direction:column; }
  .bf-hs+.bf-hs::before{ display:none; }
}
