/* ============================================================
   JIBSER Website Blocks — marketing helper layer
   Built on top of ds-tokens.css (brand tokens + Poppins @font-face).
   Everything is scoped under .wb so it never touches the canvas chrome.
   ============================================================ */

.wb, .wb * { box-sizing: border-box; }
.wb {
  font-family: var(--ff-sans);
  color: var(--jib-navy);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  line-height: 1.5;
  background: var(--jib-white);
}
.wb img { display: block; max-width: 100%; }
.wb a { color: inherit; text-decoration: none; }
.wb p { margin: 0; }
.wb h1, .wb h2, .wb h3, .wb h4 { margin: 0; font-weight: var(--fw-semibold); letter-spacing: -0.01em; }

/* ---------- layout ---------- */
.wb-wrap { max-width: 1120px; margin: 0 auto; padding-left: 40px; padding-right: 40px; }
.wb-eyebrow {
  font-size: 13px; font-weight: var(--fw-semibold); letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--jib-orange);
}
.wb-kicker {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: var(--fw-medium); letter-spacing: 0.04em;
  color: var(--jib-gray-500);
}

/* ---------- buttons ---------- */
.wb-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--ff-sans); font-weight: var(--fw-semibold); font-size: 15px;
  line-height: 1; padding: 13px 22px; border-radius: var(--r-lg);
  border: 1px solid transparent; cursor: pointer; white-space: nowrap;
  transition: background var(--dur-base) var(--ease-out-soft),
              color var(--dur-base) var(--ease-out-soft),
              border-color var(--dur-base) var(--ease-out-soft),
              transform var(--dur-fast) var(--ease-out-soft);
}
.wb-btn:active { transform: translateY(1px); }
.wb-btn--primary { background: var(--jib-orange); color: #fff; }
.wb-btn--primary:hover { background: #ED560F; }
.wb-btn--dark { background: var(--jib-navy); color: #fff; }
.wb-btn--dark:hover { background: #1A1356; }
.wb-btn--ghost { background: transparent; color: var(--jib-navy); border-color: var(--jib-gray-300); }
.wb-btn--ghost:hover { border-color: var(--jib-navy); background: var(--jib-gray-50); }
.wb-btn--white { background: #fff; color: var(--jib-navy); }
.wb-btn--white:hover { background: var(--jib-gray-100); }
.wb-btn--ghost-light { background: transparent; color: #fff; border-color: rgba(255,255,255,0.4); }
.wb-btn--ghost-light:hover { border-color: #fff; background: rgba(255,255,255,0.08); }
.wb-btn--sm { padding: 9px 16px; font-size: 14px; }
.wb-btn--lg { padding: 15px 28px; font-size: 16px; }

.wb-link {
  display: inline-flex; align-items: center; gap: 7px;
  font-weight: var(--fw-semibold); font-size: 15px; color: var(--jib-orange);
  transition: gap var(--dur-base) var(--ease-out-soft);
}
.wb-link:hover { gap: 11px; }
.wb-link--navy { color: var(--jib-navy); }
.wb-link--blue { color: var(--jib-blue); }

/* ---------- chips / badges ---------- */
.wb-chip {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: 14px; font-weight: var(--fw-medium); padding: 8px 16px;
  border-radius: var(--r-full); cursor: pointer; border: 1px solid transparent;
  color: var(--jib-gray-600); background: transparent;
  transition: all var(--dur-base) var(--ease-out-soft);
}
.wb-chip:hover { background: var(--jib-gray-50); }
.wb-chip[data-active="true"] { background: var(--jib-orange); color: #fff; }

.wb-tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; font-weight: var(--fw-semibold); letter-spacing: 0.02em;
  padding: 5px 11px; border-radius: var(--r-md);
  background: var(--jib-blue-50); color: #fff;
}

/* ---------- surfaces ---------- */
.wb-card {
  background: #fff; border: 1px solid var(--border-default);
  border-radius: var(--r-xl); box-shadow: var(--shadow-md);
}

/* image-slot default look inside blocks */
.wb image-slot { background: var(--jib-gray-100); }

/* ---------- check list ---------- */
.wb-checks { list-style: none; margin: 0; padding: 0; display: grid; gap: 18px; }
.wb-checks li { display: flex; align-items: flex-start; gap: 14px; font-size: 16px; color: var(--jib-navy); }
.wb-check-ico {
  flex: none; width: 24px; height: 24px; border-radius: var(--r-full);
  background: var(--jib-success-bg); color: var(--jib-success);
  display: grid; place-items: center; margin-top: 1px;
}

/* ---------- scrollers ---------- */
.wb-scroller { display: flex; gap: 20px; overflow-x: auto; scroll-snap-type: x mandatory;
  padding-bottom: 8px; scrollbar-width: thin; }
.wb-scroller > * { scroll-snap-align: start; flex: none; }
.wb-scroller::-webkit-scrollbar { height: 6px; }
.wb-scroller::-webkit-scrollbar-thumb { background: var(--jib-gray-300); border-radius: 99px; }

/* utility wordmark logos (logo cloud) */
.wb-wordmark { font-weight: 700; font-size: 22px; letter-spacing: 0.02em; color: var(--jib-gray-400);
  font-family: var(--ff-sans); transition: color var(--dur-base) var(--ease-out-soft); }
.wb-wordmark:hover { color: var(--jib-gray-600); }
