/* =====================================================================
   VendorBox — Homepage rebuild (modern marketplace)
   New markup uses .vbx-* classes; this file owns their full design.
   Loaded after redesign.css. Brand: orange #F2541B + ink #17130F.
   ===================================================================== */

.vbx-home { --o:#F2541B; --o2:#C2410C; --ink:#17130F; --ink2:#211B16;
  --body:#4A433C; --muted:#8A8079; --line:#ECE4DA; --canvas:#FBF8F4; --sand:#F3ECE2; --card:#fff;
  --disp:'Bricolage Grotesque','Plus Jakarta Sans',sans-serif; --sans:'Plus Jakarta Sans',system-ui,sans-serif;
  --r:18px; --rsm:12px; --ease:cubic-bezier(.22,.61,.36,1);
}
.vbx-home *{ box-sizing:border-box; }
.vbx-sec{ position:relative; }
.vbx-wrap{ max-width:1180px; margin:0 auto; padding:0 24px; }
.vbx-eyebrow{ font-family:var(--sans); font-weight:700; font-size:13px; letter-spacing:.22em;
  text-transform:uppercase; color:var(--o); margin:0 0 14px; }
.vbx-h2{ font-family:var(--disp); font-weight:800; font-size:clamp(1.9rem,4vw,3rem);
  line-height:1.05; letter-spacing:-.025em; color:var(--ink); margin:0 0 16px; }
.vbx-sub{ font-family:var(--sans); font-size:clamp(1rem,1.4vw,1.15rem); color:var(--muted); line-height:1.6; margin:0; }

/* buttons */
.vbx-btn{ display:inline-flex; align-items:center; gap:9px; font-family:var(--sans); font-weight:700;
  font-size:15px; border-radius:999px; padding:15px 30px; border:1.5px solid transparent; cursor:pointer;
  text-decoration:none !important; transition:transform .2s var(--ease), background .2s var(--ease), box-shadow .2s var(--ease), color .2s; }
.vbx-btn--primary{ background:var(--o); color:#fff !important; box-shadow:0 12px 26px -10px rgba(242,84,27,.6); }
.vbx-btn--primary:hover{ background:var(--o2); transform:translateY(-2px); box-shadow:0 18px 34px -10px rgba(242,84,27,.7); }
.vbx-btn--ghost{ background:rgba(255,255,255,.06); color:#fff !important; border-color:rgba(255,255,255,.25); }
.vbx-btn--ghost:hover{ background:rgba(255,255,255,.14); border-color:#fff; transform:translateY(-2px); }
.vbx-btn--dark{ background:var(--ink); color:#fff !important; }
.vbx-btn--dark:hover{ background:#000; transform:translateY(-2px); }
.vbx-btn--light{ background:#fff; color:var(--ink) !important; }
.vbx-btn--light:hover{ transform:translateY(-2px); box-shadow:0 16px 30px -12px rgba(0,0,0,.3); }

/* =================== HERO =================== */
.vbx-hero{ position:relative; background:var(--ink); color:#fff; overflow:hidden;
  padding:170px 0 110px; }
.vbx-hero::before{ /* warm glow */ content:""; position:absolute; inset:0;
  background:radial-gradient(80% 70% at 78% 8%, rgba(242,84,27,.42) 0%, rgba(242,84,27,0) 55%),
             radial-gradient(60% 60% at 10% 100%, rgba(242,84,27,.18) 0%, rgba(242,84,27,0) 60%); }
.vbx-hero::after{ /* dotted grid */ content:""; position:absolute; inset:0; opacity:.5;
  background-image:radial-gradient(rgba(255,255,255,.07) 1px, transparent 1px); background-size:26px 26px;
  -webkit-mask-image:linear-gradient(180deg,#000,transparent 80%); mask-image:linear-gradient(180deg,#000,transparent 80%); }
.vbx-hero .vbx-wrap{ position:relative; z-index:2; max-width:920px; text-align:center; }
.vbx-hero__eyebrow{ display:inline-flex; align-items:center; gap:8px; font-family:var(--sans);
  font-weight:600; font-size:13px; letter-spacing:.04em; color:#fff; background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.16); padding:7px 16px; border-radius:999px; margin-bottom:26px; }
.vbx-hero__eyebrow i{ color:var(--o); }
.vbx-hero h1{ font-family:var(--disp); font-weight:800; font-size:clamp(2.6rem,6vw,4.7rem);
  line-height:1.04; letter-spacing:-.035em; margin:0 0 22px; color:#fff !important; }
.vbx-hero h1 em{ font-style:normal; color:var(--o); }
.vbx-hero p.vbx-lead{ font-family:var(--sans); font-size:clamp(1.05rem,1.8vw,1.35rem);
  color:rgba(255,255,255,.8); max-width:620px; margin:0 auto 34px; line-height:1.55; }
.vbx-hero__cta{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-bottom:38px; }
.vbx-chips{ display:flex; gap:10px; justify-content:center; flex-wrap:wrap; }
.vbx-chips__label{ width:100%; font-size:12.5px; letter-spacing:.14em; text-transform:uppercase;
  color:rgba(255,255,255,.45); margin-bottom:4px; font-weight:600; }
.vbx-chip{ font-family:var(--sans); font-size:13.5px; font-weight:600; color:rgba(255,255,255,.82) !important;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14); border-radius:999px;
  padding:8px 16px; text-decoration:none !important; transition:all .18s var(--ease); }
.vbx-chip:hover{ background:var(--o); border-color:var(--o); color:#fff !important; transform:translateY(-1px); }

/* hero anim */
.vbx-hero .vbx-up{ opacity:0; transform:translateY(22px); animation:vbxUp .7s var(--ease) forwards; }
.vbx-hero .vbx-up:nth-child(1){animation-delay:.05s}
.vbx-hero h1.vbx-up{animation-delay:.13s}
.vbx-hero p.vbx-up{animation-delay:.22s}
.vbx-hero .vbx-hero__cta.vbx-up{animation-delay:.3s}
.vbx-hero .vbx-chips.vbx-up{animation-delay:.38s}
@keyframes vbxUp{ to{opacity:1; transform:none;} }

/* =================== CATEGORIES =================== */
.vbx-cats{ background:var(--canvas); padding:clamp(60px,8vw,100px) 0; }
.vbx-cats__head{ text-align:center; max-width:640px; margin:0 auto 48px; }
.vbx-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; list-style:none; margin:0; padding:0; }
.vbx-cat{ margin:0; }
.vbx-cat a{ display:flex; flex-direction:column; gap:16px; height:100%; text-decoration:none !important;
  background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:24px 22px;
  transition:transform .28s var(--ease), box-shadow .28s var(--ease), border-color .28s var(--ease); }
.vbx-cat a:hover{ transform:translateY(-6px); border-color:var(--o); box-shadow:0 24px 44px -22px rgba(23,19,15,.4); }
/* NOTE: #list specificity + !important to beat responsive.css's
   "ul#list li a span { display:none }" @media rule from the old template. */
#list .vbx-cat__icon, .vbx-cat__icon{ width:52px !important; height:52px !important; border-radius:14px; display:flex !important;
  align-items:center; justify-content:center; background:#FFE9DF; color:var(--o); font-size:22px !important;
  transition:background .28s var(--ease), color .28s var(--ease); }
#list .vbx-cat__icon i{ display:inline-block !important; font-size:22px !important; line-height:1 !important; color:inherit !important; }
.vbx-cat a:hover .vbx-cat__icon{ background:var(--o); color:#fff; }
#list .vbx-cat__name, .vbx-cat__name{ display:flex !important; align-items:center; justify-content:space-between; gap:8px;
  font-family:var(--sans) !important; font-weight:700 !important; font-size:15.5px !important; color:var(--ink); margin:0; }
#list .vbx-cat__name .fa{ display:inline-block !important; color:var(--o) !important; font-size:16px !important; transition:transform .22s var(--ease); }
.vbx-cat a:hover .vbx-cat__name .fa{ transform:translateX(5px); }
.vbx-cat__meta{ font-size:13px; color:var(--muted); margin:-6px 0 0; }
.vbx-cats__more{ text-align:center; margin-top:40px; }
.vbx-morebtn{ display:inline-flex; align-items:center; gap:8px; font-family:var(--sans); font-weight:700;
  font-size:14.5px; color:var(--ink); background:#fff; border:1px solid var(--line); border-radius:999px;
  padding:12px 26px; cursor:pointer; transition:all .2s var(--ease); }
.vbx-morebtn:hover{ border-color:var(--o); color:var(--o); }
.vbx-cat.vbx-hide{ display:none; }

/* =================== STATS =================== */
.vbx-stats{ background:var(--ink); color:#fff; padding:clamp(48px,6vw,72px) 0; }
.vbx-stats__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.vbx-stat{ display:flex; flex-direction:column; align-items:center; text-align:center; gap:6px;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.09); border-radius:var(--r);
  padding:32px 22px; text-decoration:none !important; transition:transform .25s var(--ease), border-color .25s var(--ease); }
.vbx-stat:hover{ transform:translateY(-4px); border-color:var(--o); }
.vbx-stat__ico{ width:54px; height:54px; border-radius:50%; background:rgba(242,84,27,.16); color:var(--o);
  display:flex; align-items:center; justify-content:center; font-size:23px; margin-bottom:8px; }
.vbx-stat__num{ font-family:var(--disp); font-weight:800; font-size:clamp(2.2rem,4vw,3rem); color:#fff; line-height:1; }
.vbx-stat__label{ font-family:var(--sans); font-weight:600; font-size:13px; letter-spacing:.14em;
  text-transform:uppercase; color:rgba(255,255,255,.6); }

/* =================== HOW IT WORKS =================== */
.vbx-how{ background:var(--canvas); padding:clamp(60px,8vw,100px) 0; }
.vbx-how + .vbx-how{ padding-top:0; }
.vbx-how__head{ text-align:center; margin-bottom:46px; }
.vbx-steps{ display:grid; grid-template-columns:repeat(5,1fr); gap:16px; }
.vbx-step{ position:relative; background:var(--card); border:1px solid var(--line); border-radius:var(--r);
  padding:26px 20px; text-align:center; transition:transform .28s var(--ease), box-shadow .28s var(--ease); }
.vbx-step:hover{ transform:translateY(-5px); box-shadow:0 22px 40px -22px rgba(23,19,15,.35); }
.vbx-step__n{ position:absolute; top:14px; right:16px; font-family:var(--disp); font-weight:800;
  font-size:30px; color:var(--sand); line-height:1; }
.vbx-step__ico{ width:58px; height:58px; border-radius:16px; background:#FFE9DF; color:var(--o);
  display:flex; align-items:center; justify-content:center; font-size:24px; margin:0 auto 16px; }
.vbx-step h5{ font-family:var(--disp); font-weight:700; font-size:16px; color:var(--ink); margin:0 0 8px; text-transform:capitalize; }
.vbx-step p{ font-family:var(--sans); font-size:13px; color:var(--muted); line-height:1.5; margin:0; }
.vbx-how__divider{ text-align:center; padding:30px 0; }
.vbx-how__divider span{ font-family:var(--disp); font-weight:600; font-size:clamp(1.1rem,2vw,1.4rem); color:var(--ink); }

/* =================== CTA (buyers / suppliers) =================== */
.vbx-cta{ display:grid; grid-template-columns:1fr 1fr; }
.vbx-cta__panel{ position:relative; overflow:hidden; padding:clamp(56px,7vw,96px) clamp(28px,5vw,72px); color:#fff; }
.vbx-cta__panel--buyer{ background:var(--ink); }
.vbx-cta__panel--supplier{ background:linear-gradient(135deg,var(--o) 0%,var(--o2) 100%); }
.vbx-cta__panel::after{ content:""; position:absolute; right:-50px; top:-50px; width:200px; height:200px;
  border:2px solid rgba(255,255,255,.1); border-radius:30px; transform:rotate(18deg); }
.vbx-cta__inner{ position:relative; z-index:2; max-width:420px; margin:0 auto; }
.vbx-cta__tag{ font-family:var(--sans); font-weight:700; font-size:12.5px; letter-spacing:.18em;
  text-transform:uppercase; opacity:.7; margin:0 0 12px; }
.vbx-cta h3{ font-family:var(--disp); font-weight:800; font-size:clamp(1.6rem,3vw,2.3rem); line-height:1.1; margin:0 0 14px; color:#fff !important; }
.vbx-cta p{ font-family:var(--sans); font-size:15px; line-height:1.6; opacity:.86; margin:0 0 26px; }

/* =================== LATEST JOBS (home.php) =================== */
.vbx-jobs{ background:var(--canvas); padding:clamp(60px,8vw,100px) 0; }
.vbx-jobs__head{ text-align:center; margin-bottom:44px; }
.vbx-jobs__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.vbx-jobcard{ background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:24px;
  display:flex; flex-direction:column; gap:14px; transition:transform .28s var(--ease), box-shadow .28s var(--ease), border-color .28s var(--ease); }
.vbx-jobcard:hover{ transform:translateY(-5px); border-color:var(--o); box-shadow:0 24px 44px -22px rgba(23,19,15,.4); }
.vbx-jobcard__title a{ font-family:var(--disp); font-weight:700; font-size:18px; color:var(--ink) !important; text-decoration:none; line-height:1.25; }
.vbx-jobcard__title a:hover{ color:var(--o) !important; }
.vbx-jobcard__meta{ display:flex; gap:16px; flex-wrap:wrap; font-size:12.5px; color:var(--muted); }
.vbx-jobcard__meta i{ color:var(--o); margin-right:5px; }
.vbx-jobcard__desc{ font-size:14px; color:var(--body); line-height:1.55; margin:0; }
.vbx-jobcard__tags{ display:flex; gap:8px; flex-wrap:wrap; }
.vbx-jobcard__tags a{ font-size:12px; font-weight:600; color:var(--o2) !important; background:#FFE9DF;
  border-radius:999px; padding:4px 12px; text-decoration:none; }
.vbx-jobcard__foot{ display:flex; align-items:center; justify-content:space-between; gap:12px;
  margin-top:auto; padding-top:16px; border-top:1px solid var(--line); }
.vbx-jobcard__amt{ font-family:var(--disp); font-weight:800; font-size:20px; color:var(--ink); }
.vbx-jobs__all{ text-align:center; margin-top:42px; }

/* =================== responsive =================== */
@media (max-width:991px){
  .vbx-grid{ grid-template-columns:repeat(2,1fr); }
  .vbx-steps{ grid-template-columns:repeat(2,1fr); }
  .vbx-jobs__grid{ grid-template-columns:repeat(2,1fr); }
  .vbx-cta{ grid-template-columns:1fr; }
}
@media (max-width:600px){
  .vbx-hero{ padding:140px 0 80px; }
  .vbx-grid{ grid-template-columns:1fr 1fr; gap:12px; }
  .vbx-stats__grid{ grid-template-columns:1fr; }
  .vbx-steps{ grid-template-columns:1fr; }
  .vbx-jobs__grid{ grid-template-columns:1fr; }
}

/* =====================================================================
   LIVE HERO — animated glow + rotating word slider
   ===================================================================== */
.vbx-hero::before { animation: vbxGlow 7s ease-in-out infinite alternate; }
@keyframes vbxGlow { 0% { opacity:.8; } 100% { opacity:1; transform:scale(1.06); } }
.vbx-hero::after { animation: vbxDrift 30s linear infinite; }
@keyframes vbxDrift { 0% { background-position:0 0; } 100% { background-position:26px 26px; } }

/* rotating headline word (JS swap, box fits current word -> no gap) */
.vbx-rotate { display:inline-block; vertical-align:bottom; }
.vbx-rotate__w { display:inline-block; color:var(--o); transition:opacity .28s ease, transform .28s ease; }
/* gentle float on the eyebrow + subtle pulse on primary CTA */
.vbx-hero__eyebrow { animation: vbxUp .7s var(--ease) .05s forwards, vbxFloat 5s ease-in-out 1s infinite; }
@keyframes vbxFloat { 0%,100% { transform:translateY(0);} 50% { transform:translateY(-5px);} }
.vbx-hero .vbx-btn--primary { animation: vbxUp .7s var(--ease) .3s forwards, vbxPulse 3.5s ease-in-out 1.5s infinite; }
@keyframes vbxPulse { 0%,100% { box-shadow:0 12px 26px -10px rgba(242,84,27,.6);} 50% { box-shadow:0 14px 40px -8px rgba(242,84,27,.85);} }
@media (prefers-reduced-motion: reduce){ .vbx-rotate__list,.vbx-hero::before,.vbx-hero::after,.vbx-hero__eyebrow,.vbx-hero .vbx-btn--primary{ animation:none !important; } }
