/* ============================================================
   callCarlos Knowledge Base
   Mobile-first, BEM-style classes, isolated from Elementor.
   Selectors use .kb prefix everywhere so theme rules cannot reach
   our elements.
   ============================================================ */

/* === DESIGN TOKENS === */
.kb {
  --cc-charcoal:  #2D2C2D;
  --cc-grey:      #6b6b6b;
  --cc-grey-2:    #9a9a9a;
  --cc-cream:     #F1EDE9;
  --cc-off:       #F7F5F3;
  --cc-gold:      #FDC40D;
  --cc-amber:     #F8B12B;
  --cc-green:     #49A76F;
  --cc-green-dk:  #3d8a5c;
  --cc-blue:      #49A1CC;
  --cc-blue-dk:   #3b85ab;
  --cc-coral:     #C4505E;
  --cc-red:       #C4505E;

  --r-sm: 8px;
  --r-md: 12px;
  --r-lg: 18px;

  --shadow-sm: 0 1px 2px rgba(45,44,45,.04), 0 6px 16px rgba(45,44,45,.06);
  --shadow-md: 0 1px 2px rgba(45,44,45,.06), 0 16px 32px rgba(45,44,45,.10);

  --font-body: 'Fira Sans', system-ui, -apple-system, sans-serif;
  --font-display: 'Fira Sans Condensed', 'Fira Sans', system-ui, sans-serif;
  --font-accent: 'Caveat', cursive;

  /* override Elementor globals within our scope so they can't tint our buttons */
  --e-global-color-primary: var(--cc-charcoal);
  --e-global-color-secondary: var(--cc-charcoal);
  --e-global-color-accent: var(--cc-gold);
  --e-global-color-text: var(--cc-charcoal);

  /* default accent (overridden per card via .kb__card--garden etc) */
  --kb-accent:      var(--cc-green);
  --kb-accent-dk:   var(--cc-green-dk);
  --kb-accent-soft: rgba(73,167,111,.12);

  font-family: var(--font-body);
  color: var(--cc-charcoal);
  line-height: 1.55;
  box-sizing: border-box;
}

.kb,
.kb *,
.kb *::before,
.kb *::after {
  box-sizing: border-box;
}

/* === RESET ELEMENTOR REACH ===
   Inside .kb we use ONLY our own classes. Reset bare elements
   so theme rules can't leak in. */
.kb button,
.kb a,
.kb h1,
.kb h2,
.kb h3,
.kb h4,
.kb p,
.kb ol,
.kb ul,
.kb li,
.kb span,
.kb div,
.kb article,
.kb section,
.kb header,
.kb aside,
.kb nav,
.kb input {
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  text-decoration: none;
  text-transform: none;
  letter-spacing: normal;
  text-shadow: none;
  box-shadow: none;
  list-style: none;
  line-height: inherit;
}

.kb button {
  cursor: pointer;
  text-align: inherit;
}

.kb svg {
  width: auto;
  height: auto;
  max-width: 100%;
  display: inline-block;
  vertical-align: middle;
  flex-shrink: 0;
}

/* === WRAPPER VARIANTS ===
   .kb--hub      full hub page (with hero, filters, content, cta)
   .kb--compact  embedded service-page section
   ============================================================ */

/* ============================================================
   HERO (hub only)
   ============================================================ */
.kb .kb__hero {
  position: relative;
  padding: 56px 20px 48px;
  background:
    radial-gradient(circle at 15% 20%, rgba(73,167,111,.08), transparent 50%),
    radial-gradient(circle at 85% 80%, rgba(73,161,204,.08), transparent 50%),
    var(--cc-off);
  border-radius: 0;
}

.kb .kb__hero-inner {
  max-width: 880px;
  margin: 0 auto;
  text-align: center;
}

.kb .kb__hero-eyebrow {
  display: inline-block;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 12px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--cc-charcoal);
  background: var(--cc-gold);
  padding: 6px 14px;
  border-radius: 999px;
  margin-bottom: 20px;
}

.kb .kb__hero-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(32px, 8vw, 56px);
  line-height: 1.05;
  letter-spacing: -.5px;
  margin: 0 0 16px;
}

.kb .kb__hero-title em {
  font-style: normal;
  font-family: var(--font-accent);
  color: var(--cc-gold);
  font-weight: 700;
  font-size: 1.05em;
}

.kb .kb__hero-lede {
  font-size: 16px;
  color: var(--cc-grey);
  max-width: 620px;
  margin: 0 auto 28px;
  line-height: 1.55;
}

.kb .kb__search {
  position: relative;
  max-width: 560px;
  margin: 0 auto 32px;
}

.kb .kb__search-input {
  width: 100%;
  padding: 14px 16px 14px 44px;
  font-family: var(--font-body);
  font-size: 15px;
  color: var(--cc-charcoal);
  background: #fff;
  border: 1px solid var(--cc-cream);
  border-radius: var(--r-md);
  outline: none;
  transition: border-color .2s, box-shadow .2s;
}

.kb .kb__search-input:focus {
  border-color: var(--cc-gold);
  box-shadow: 0 0 0 3px rgba(253,196,13,.18);
}

.kb .kb__search-input::placeholder {
  color: var(--cc-grey-2);
}

.kb .kb__search-icon {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--cc-grey-2);
  pointer-events: none;
}

.kb .kb__search-icon svg {
  width: 18px;
  height: 18px;
}

.kb .kb__stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  max-width: 560px;
  margin: 0 auto;
}

.kb .kb__stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.kb .kb__stat-num {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 28px;
  line-height: 1;
  color: var(--cc-charcoal);
}

.kb .kb__stat-plus {
  color: var(--cc-gold);
}

.kb .kb__stat-label {
  font-size: 12px;
  color: var(--cc-grey);
  margin-top: 4px;
  text-transform: uppercase;
  letter-spacing: 1px;
}

@media (min-width: 640px) {
  .kb .kb__hero { padding: 80px 32px 64px; }
  .kb .kb__hero-lede { font-size: 18px; }
  .kb .kb__stats { grid-template-columns: repeat(4, 1fr); gap: 24px; max-width: 720px; }
  .kb .kb__stat-num { font-size: 36px; }
}

/* ============================================================
   FILTER CHIPS
   ============================================================ */
.kb .kb__filters {
  position: sticky;
  top: 0;
  z-index: 5;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--cc-cream);
}

.kb .kb__filters-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 12px 16px;
  display: flex;
  gap: 8px;
  overflow-x: auto;
  scrollbar-width: none;
}

.kb .kb__filters-inner::-webkit-scrollbar { display: none; }

.kb .kb__chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  background: #fff;
  border: 1px solid var(--cc-cream);
  border-radius: 999px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 13px;
  color: var(--cc-charcoal);
  white-space: nowrap;
  transition: background .2s, border-color .2s, color .2s, transform .15s;
}

.kb .kb__chip:hover { border-color: var(--cc-charcoal); }

.kb .kb__chip--active,
.kb .kb__chip--active:hover {
  background: var(--cc-charcoal);
  border-color: var(--cc-charcoal);
  color: #fff;
}

.kb .kb__chip-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--cc-grey);
}

.kb .kb__chip--garden  .kb__chip-dot { background: var(--cc-green); }
.kb .kb__chip--pool    .kb__chip-dot { background: var(--cc-blue); }
.kb .kb__chip--repairs .kb__chip-dot { background: var(--cc-amber); }
.kb .kb__chip--admin   .kb__chip-dot { background: var(--cc-coral); }

.kb .kb__chip-count {
  font-size: 11px;
  font-weight: 500;
  color: var(--cc-grey);
  padding: 2px 6px;
  background: var(--cc-off);
  border-radius: 4px;
}

.kb .kb__chip--active .kb__chip-count {
  background: rgba(255,255,255,.15);
  color: rgba(255,255,255,.85);
}

.kb .kb__chip--dimmed {
  opacity: .45;
  pointer-events: none;
}

@media (min-width: 640px) {
  .kb .kb__filters-inner { padding: 16px 24px; gap: 10px; }
  .kb .kb__chip { padding: 10px 16px; font-size: 14px; }
}

/* ============================================================
   CONTENT (hub: section after section)
   ============================================================ */
.kb .kb__content {
  padding: 32px 16px 48px;
}

.kb .kb__content-inner {
  max-width: 1100px;
  margin: 0 auto;
}

.kb .kb__section {
  margin-bottom: 48px;
  scroll-margin-top: 80px;
}

.kb .kb__section:last-child {
  margin-bottom: 0;
}

.kb .kb__section-head {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 24px;
}

.kb .kb__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--kb-accent-dk);
}

.kb .kb__eyebrow-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--kb-accent);
  display: inline-block;
}

.kb .kb__section--garden  { --kb-accent: var(--cc-green); --kb-accent-dk: var(--cc-green-dk); --kb-accent-soft: rgba(73,167,111,.12); }
.kb .kb__section--pool    { --kb-accent: var(--cc-blue);  --kb-accent-dk: var(--cc-blue-dk);  --kb-accent-soft: rgba(73,161,204,.12); }
.kb .kb__section--repairs { --kb-accent: var(--cc-amber); --kb-accent-dk: #b07a00;            --kb-accent-soft: rgba(248,177,43,.18); }
.kb .kb__section--admin   { --kb-accent: var(--cc-coral); --kb-accent-dk: var(--cc-coral);    --kb-accent-soft: rgba(196,80,94,.12); }

.kb .kb__section-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(24px, 5vw, 32px);
  line-height: 1.15;
  margin: 8px 0 4px;
  color: var(--cc-charcoal);
}

.kb .kb__section-sub {
  font-size: 15px;
  color: var(--cc-grey);
  max-width: 520px;
  margin: 0;
}

.kb .kb__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 14px;
  color: var(--cc-charcoal);
  align-self: flex-start;
  transition: color .2s, gap .2s;
}

.kb .kb__link:hover {
  color: var(--kb-accent-dk);
  gap: 10px;
}

.kb .kb__link-arrow {
  display: inline-flex;
}

.kb .kb__link-arrow svg {
  width: 16px;
  height: 16px;
}

@media (min-width: 768px) {
  .kb .kb__content { padding: 48px 32px 64px; }
  .kb .kb__section { margin-bottom: 64px; }
  .kb .kb__section-head {
    flex-direction: row;
    align-items: flex-end;
    justify-content: space-between;
    gap: 32px;
  }
  .kb .kb__section-head-text { flex: 1; min-width: 0; }
  .kb .kb__link { align-self: flex-end; }
}

/* ============================================================
   CARD LIST
   ============================================================ */
.kb .kb__list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* ============================================================
   CARD (.kb__card)
   ============================================================ */
.kb .kb__card {
  background: #fff;
  border: 1px solid var(--cc-cream);
  border-radius: var(--r-md);
  overflow: hidden;
  transition: box-shadow .2s, border-color .2s;
}

.kb .kb__card:hover { box-shadow: var(--shadow-sm); }

.kb .kb__card--open { box-shadow: var(--shadow-md); }

.kb .kb__card--garden  { --kb-accent: var(--cc-green); --kb-accent-dk: var(--cc-green-dk); --kb-accent-soft: rgba(73,167,111,.12); }
.kb .kb__card--pool    { --kb-accent: var(--cc-blue);  --kb-accent-dk: var(--cc-blue-dk);  --kb-accent-soft: rgba(73,161,204,.12); }
.kb .kb__card--repairs { --kb-accent: var(--cc-amber); --kb-accent-dk: #b07a00;            --kb-accent-soft: rgba(248,177,43,.18); }
.kb .kb__card--admin   { --kb-accent: var(--cc-coral); --kb-accent-dk: var(--cc-coral);    --kb-accent-soft: rgba(196,80,94,.12); }

/* HEAD: clickable button */
.kb .kb__card .kb__head {
  display: flex;
  align-items: center;
  gap: 14px;
  width: 100%;
  min-width: 0;
  padding: 16px;
  background: #fff;
  text-align: left;
  font-family: inherit;
  transition: background .2s;
}

.kb .kb__card .kb__head:hover,
.kb .kb__card .kb__head:focus,
.kb .kb__card .kb__head:focus-visible {
  background: var(--cc-off);
  outline: none;
}

.kb .kb__card--open .kb__head {
  background: var(--cc-off);
  border-bottom: 1px solid var(--cc-cream);
}

/* ICON */
.kb .kb__icon {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--kb-accent-soft);
  color: var(--kb-accent-dk);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.kb .kb__icon svg {
  width: 20px;
  height: 20px;
}

/* HEAD TEXT */
.kb .kb__head-text {
  flex: 1 1 auto;
  min-width: 0;
  max-width: 100%;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.kb .kb__title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 16px;
  line-height: 1.3;
  color: var(--cc-charcoal);
  margin: 0;
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
  overflow-wrap: break-word;
  word-wrap: break-word;
  hyphens: auto;
}

.kb .kb__meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 12px;
  color: var(--cc-grey);
}

.kb .kb__urgency {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-weight: 500;
}

.kb .kb__pulse {
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--cc-red);
}

.kb .kb__urgency--high  .kb__pulse { background: var(--cc-red);   animation: kbPulse 2s infinite; }
.kb .kb__urgency--med   .kb__pulse { background: var(--cc-amber); }
.kb .kb__urgency--low   .kb__pulse { background: var(--cc-green); }

.kb .kb__dot { color: var(--cc-grey-2); }

@keyframes kbPulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: .4; transform: scale(1.3); }
}

/* TOGGLE */
.kb .kb__card .kb__toggle {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--cc-off);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--cc-charcoal);
  transition: background .2s, transform .25s;
}

.kb .kb__card--open .kb__toggle {
  background: var(--cc-charcoal);
  color: #fff;
  transform: rotate(45deg);
}

.kb .kb__toggle svg {
  width: 14px;
  height: 14px;
}

@media (min-width: 640px) {
  .kb .kb__card .kb__head { padding: 20px 24px; gap: 18px; }
  .kb .kb__icon { width: 44px; height: 44px; }
  .kb .kb__icon svg { width: 22px; height: 22px; }
  .kb .kb__title { font-size: 18px; }
  .kb .kb__meta { font-size: 13px; }
}

/* ============================================================
   BODY (revealed when open)
   ============================================================ */
.kb .kb__card .kb__body {
  display: none;
  padding: 20px 16px 24px;
}

.kb .kb__card--open .kb__body {
  display: block;
  animation: kbFadeIn .3s ease;
}

.kb .kb__card .kb__body[hidden] { display: none; }
.kb .kb__card--open .kb__body[hidden] { display: block; }

@keyframes kbFadeIn {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

.kb .kb__body-grid {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

@media (min-width: 768px) {
  .kb .kb__card .kb__body { padding: 24px 28px 28px; }
  .kb .kb__body-grid {
    flex-direction: row;
    gap: 28px;
  }
  .kb .kb__answer { flex: 1.6; min-width: 0; }
  .kb .kb__aside  { flex: 1; min-width: 0; }
}

/* ANSWER */
.kb .kb__answer {
  font-size: 15px;
  color: rgba(45,44,45,.9);
}

.kb .kb__intro p {
  margin: 0 0 12px;
}

.kb .kb__intro p:last-child {
  margin-bottom: 0;
}

.kb .kb__intro strong {
  font-weight: 600;
  color: var(--cc-charcoal);
}

.kb .kb__subhead {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--cc-grey);
  margin: 20px 0 10px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.kb .kb__subhead::before {
  content: "";
  display: inline-block;
  width: 14px;
  height: 2px;
  background: var(--cc-gold);
  flex-shrink: 0;
}

.kb .kb__steps {
  background: var(--cc-off);
  border-radius: var(--r-sm);
  padding: 12px 16px;
  display: flex;
  flex-direction: column;
  gap: 0;
  counter-reset: kbstep;
}

.kb .kb__step {
  position: relative;
  padding: 10px 0 10px 36px;
  font-size: 14.5px;
  line-height: 1.5;
  border-bottom: 1px dashed rgba(45,44,45,.08);
  counter-increment: kbstep;
}

.kb .kb__step:last-child {
  border-bottom: none;
}

.kb .kb__step::before {
  content: counter(kbstep);
  position: absolute;
  left: 0;
  top: 11px;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--kb-accent-soft);
  color: var(--kb-accent-dk);
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.kb .kb__honest {
  margin-top: 16px;
  padding: 12px 14px;
  background: rgba(253, 196, 13, 0.12);
  border-left: 3px solid var(--cc-gold);
  border-radius: 4px;
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--cc-charcoal);
}

.kb .kb__honest strong {
  font-weight: 600;
}

/* ASIDE (right column, "Or just, have X stop by")
   Original callCarlos design, off-cream with gold decorative blob,
   handwritten Caveat tag, white pill meta items, charcoal-to-gold CTA. */
.kb .kb__aside {
  position: relative;
  overflow: hidden;
  background: var(--cc-off);
  border-radius: var(--r-md);
  padding: 22px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.kb .kb__aside::before {
  content: "";
  position: absolute;
  top: -30px;
  right: -30px;
  width: 120px;
  height: 120px;
  background: rgba(253, 196, 13, 0.15);
  border-radius: 50%;
  pointer-events: none;
}

/* All inner items need position:relative so they stack above the blob */
.kb .kb__aside > * { position: relative; }

.kb .kb__aside-tag {
  display: inline-block;
  font-family: var(--font-accent);
  font-size: 22px;
  font-weight: 700;
  color: var(--cc-gold);
  line-height: 1;
  margin-bottom: 2px;
  transform: rotate(-2deg);
  transform-origin: left center;
}

.kb .kb__aside-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 20px;
  line-height: 1.2;
  color: var(--cc-charcoal);
  margin: 0;
}

.kb .kb__aside-text {
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--cc-grey);
}

.kb .kb__aside-text strong {
  font-weight: 600;
  color: var(--cc-charcoal);
}

.kb .kb__aside-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 4px;
}

.kb .kb__aside-meta-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: #fff;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 500;
  color: var(--cc-charcoal);
  border: 1px solid var(--cc-cream);
}

.kb .kb__aside-meta-item svg {
  width: 12px;
  height: 12px;
}

.kb .kb__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 18px;
  background: var(--cc-charcoal);
  color: #fff;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 14.5px;
  border-radius: var(--r-md);
  align-self: flex-start;
  margin-top: 6px;
  transition: background .2s, color .2s, transform .15s;
}

.kb .kb__cta:hover,
.kb .kb__cta:focus,
.kb .kb__cta:active {
  background: var(--cc-gold);
  color: var(--cc-charcoal);
  text-decoration: none;
}

.kb .kb__cta-arrow svg {
  width: 16px;
  height: 16px;
  transition: transform .2s;
}

.kb .kb__cta:hover .kb__cta-arrow svg { transform: translateX(3px); }

/* ============================================================
   BIG CTA at bottom of hub
   ============================================================ */
.kb .kb__bigcta {
  background: var(--cc-charcoal);
  color: #fff;
  padding: 56px 20px;
  text-align: center;
  border-radius: 0;
}

.kb .kb__bigcta-inner {
  max-width: 720px;
  margin: 0 auto;
}

.kb .kb__bigcta-kicker {
  font-family: var(--font-accent);
  font-size: 22px;
  color: var(--cc-gold);
  display: block;
  margin-bottom: 8px;
}

.kb .kb__bigcta-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(26px, 6vw, 40px);
  line-height: 1.15;
  margin: 0 0 16px;
  color: #fff;
}

.kb .kb__bigcta-title em {
  font-style: normal;
  font-family: var(--font-accent);
  color: var(--cc-gold);
  font-weight: 700;
  font-size: 1.1em;
}

.kb .kb__bigcta-text {
  font-size: 16px;
  color: rgba(255,255,255,.8);
  max-width: 560px;
  margin: 0 auto 28px;
  line-height: 1.55;
}

.kb .kb__bigcta-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}

@media (min-width: 640px) {
  .kb .kb__bigcta { padding: 80px 32px; }
}

/* ============================================================
   BUTTONS (shared between section footer + bigcta)
   ============================================================ */
.kb .kb__btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 20px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 14.5px;
  border-radius: var(--r-md);
  transition: background .2s, color .2s, border-color .2s, transform .15s;
}

.kb .kb__btn--primary {
  background: var(--cc-gold);
  color: var(--cc-charcoal);
}

.kb .kb__btn--primary:hover,
.kb .kb__btn--primary:focus,
.kb .kb__btn--primary:active {
  background: var(--cc-amber);
  color: var(--cc-charcoal);
  transform: translateY(-1px);
}

.kb .kb__btn--ghost {
  background: transparent;
  color: #fff;
  border: 1px solid rgba(255,255,255,.25);
}

.kb .kb__btn--ghost:hover,
.kb .kb__btn--ghost:focus,
.kb .kb__btn--ghost:active {
  border-color: #fff;
  background: rgba(255,255,255,.06);
  color: #fff;
}

/* When used in light contexts (compact section footer) */
.kb--compact .kb__btn--ghost {
  color: var(--cc-charcoal);
  border-color: var(--cc-charcoal);
}

.kb--compact .kb__btn--ghost:hover,
.kb--compact .kb__btn--ghost:focus,
.kb--compact .kb__btn--ghost:active {
  background: var(--cc-charcoal);
  color: #fff;
  border-color: var(--cc-charcoal);
}

.kb .kb__btn-icon {
  display: inline-flex;
}

.kb .kb__btn-icon svg {
  width: 16px;
  height: 16px;
}

/* ============================================================
   COMPACT VARIANT (embedded service-page section)
   ============================================================ */
.kb--compact {
  padding: 48px 16px;
  background: var(--cc-off);
  position: relative;
}

.kb--compact .kb__intro-row {
  max-width: 1100px;
  margin: 0 auto 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.kb--compact .kb__h2 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(28px, 6vw, 40px);
  line-height: 1.1;
  margin: 8px 0 0;
  color: var(--cc-charcoal);
}

.kb--compact .kb__h2 em {
  font-style: normal;
  font-family: var(--font-accent);
  color: var(--kb-accent);
  font-weight: 700;
  font-size: 1.1em;
}

.kb--compact .kb__sub {
  font-size: 15px;
  color: var(--cc-grey);
  max-width: 520px;
  margin: 8px 0 0;
}

.kb--compact .kb__list {
  max-width: 1100px;
  margin: 0 auto;
}

.kb--compact.kb--garden  { --kb-accent: var(--cc-green); --kb-accent-dk: var(--cc-green-dk); --kb-accent-soft: rgba(73,167,111,.12); }
.kb--compact.kb--pool    { --kb-accent: var(--cc-blue);  --kb-accent-dk: var(--cc-blue-dk);  --kb-accent-soft: rgba(73,161,204,.12); }
.kb--compact.kb--repairs { --kb-accent: var(--cc-amber); --kb-accent-dk: #b07a00;            --kb-accent-soft: rgba(248,177,43,.18); }
.kb--compact.kb--admin   { --kb-accent: var(--cc-coral); --kb-accent-dk: var(--cc-coral);    --kb-accent-soft: rgba(196,80,94,.12); }

.kb--compact .kb__footer {
  max-width: 1100px;
  margin: 32px auto 0;
  padding: 28px 24px;
  background: #fff;
  border-radius: var(--r-md);
  display: flex;
  flex-direction: column;
  gap: 20px;
  border: 1px solid var(--cc-cream);
}

.kb--compact .kb__footer-text {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.kb--compact .kb__footer-kicker {
  font-family: var(--font-accent);
  font-size: 22px;
  color: var(--kb-accent);
}

.kb--compact .kb__footer-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  line-height: 1.2;
  margin: 0;
  color: var(--cc-charcoal);
}

.kb--compact .kb__footer-sub {
  font-size: 14.5px;
  color: var(--cc-grey);
  margin: 4px 0 0;
}

.kb--compact .kb__footer-buttons {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

@media (min-width: 768px) {
  .kb--compact { padding: 80px 32px; }
  .kb--compact .kb__intro-row {
    flex-direction: row;
    align-items: flex-end;
    justify-content: space-between;
    gap: 32px;
    margin-bottom: 32px;
  }
  .kb--compact .kb__intro-text { flex: 1; min-width: 0; }
  .kb--compact .kb__footer {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
    padding: 32px 36px;
  }
  .kb--compact .kb__footer-text { flex: 1; }
}

/* Compact card overrides: more compact for service pages */
.kb--compact .kb__card .kb__head { padding: 14px 16px; }
@media (min-width: 640px) {
  .kb--compact .kb__card .kb__head { padding: 16px 20px; }
}