/* CMP Header widget — site chrome (cmp-hd-* namespace). */
.cmp-hd-header {
  --cmp-hd-bg: var(--header-bg);
  --cmp-hd-border: var(--border-hair);
  position: relative;
  width: 100%;
  z-index: 50;
  background: var(--cmp-hd-bg);
  border-bottom: 1px solid var(--cmp-hd-border);
  backdrop-filter: blur(12px) saturate(1.1);
  -webkit-backdrop-filter: blur(12px) saturate(1.1);
}
.cmp-hd-header--sticky { position: sticky; top: 0; }
.cmp-hd-header--transparent:not(.cmp-hd--scrolled) {
  background: transparent;
  border-bottom-color: transparent;
  backdrop-filter: none;
}

.cmp-hd-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  height: var(--header-h, 72px);
}

/* logo */
.cmp-hd-logo { display: inline-flex; align-items: center; gap: 0.45rem; }
.cmp-hd-logo__img, .cmp-hd-logo .custom-logo { height: 40px; width: auto; object-fit: contain; }
.cmp-hd-logo__text { font-family: var(--font-display); font-weight: 800; font-size: 1.12rem; letter-spacing: -0.02em; color: var(--ink); white-space: nowrap; }
.cmp-hd-logo__dot { color: var(--amber); }

/* center nav */
.cmp-hd-nav { display: none; }
@media (min-width: 1024px) { .cmp-hd-nav { display: block; } }
.cmp-hd-menu { display: flex; align-items: center; gap: 1.5rem; list-style: none; margin: 0; padding: 0; }
.cmp-hd-menu a {
  position: relative;
  font-size: 0.92rem;
  color: var(--body);
  transition: color var(--dur-fast) var(--ease-standard);
}
.cmp-hd-menu a::after {
  content: ""; position: absolute; left: 0; bottom: -6px; height: 1.5px; width: 0;
  background: var(--amber); transition: width var(--dur-fast) var(--ease-out);
}
.cmp-hd-menu a:hover, .cmp-hd-menu .current-menu-item > a { color: var(--ink); }
.cmp-hd-menu a:hover::after, .cmp-hd-menu .current-menu-item > a::after { width: 100%; }

/* right cluster */
.cmp-hd-actions { display: flex; align-items: center; gap: 0.65rem; }

/* live fleet pill */
.cmp-hd-pill {
  display: none; align-items: center; gap: 0.5rem;
  border: 1px solid var(--border-hair); border-radius: var(--r-pill);
  padding: 0.35rem 0.7rem 0.35rem 0.6rem; transition: border-color var(--dur-fast);
}
.cmp-hd-pill:hover { border-color: var(--green); }
@media (min-width: 640px) { .cmp-hd-pill { display: inline-flex; } }
.cmp-hd-pill__dot { position: relative; display: inline-flex; width: 0.5rem; height: 0.5rem; }
.cmp-hd-pill__ping { position: absolute; inset: 0; border-radius: 50%; background: var(--green); opacity: 0.6; animation: cmpPing 1.6s cubic-bezier(0,0,0.2,1) infinite; }
.cmp-hd-pill__core { position: relative; width: 0.5rem; height: 0.5rem; border-radius: 50%; background: var(--green); }
@keyframes cmpPing { 75%, 100% { transform: scale(2.2); opacity: 0; } }
.cmp-hd-pill__count { font-family: var(--font-mono); font-size: 0.72rem; font-variant-numeric: tabular-nums; color: var(--ink); }
.cmp-hd-pill__total { color: var(--muted); }
.cmp-hd-pill__label { font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted); }

/* theme toggle (reuses .cmp-theme-toggle from main.css) */
.cmp-hd-toggle { }

/* cart */
.cmp-hd-cart { position: relative; display: inline-grid; place-items: center; width: 36px; height: 36px; color: var(--ink); }
.cmp-hd-cart__icon svg { width: 18px; height: 18px; }
.cmp-hd-cart-count {
  position: absolute; top: -2px; right: -2px; min-width: 16px; height: 16px; padding: 0 4px;
  display: grid; place-items: center; border-radius: 999px;
  background: var(--amber); color: var(--on-amber);
  font-family: var(--font-mono); font-size: 0.6rem; font-weight: 700; line-height: 1;
}
.cmp-hd-cart-count.is-empty { display: none; }

/* CTA */
.cmp-hd-cta { display: none; }
@media (min-width: 640px) { .cmp-hd-cta { display: inline-flex; } }
.cmp-hd-cta .cmp-btn { white-space: nowrap; }

/* hamburger */
.cmp-hd-burger { display: inline-grid; place-items: center; width: 36px; height: 36px; border: 0; background: transparent; color: var(--ink); cursor: pointer; }
@media (min-width: 1024px) { .cmp-hd-burger { display: none; } }
.cmp-hd-burger__box { position: relative; display: block; width: 20px; height: 14px; }
.cmp-hd-burger__line { position: absolute; left: 0; height: 2px; width: 20px; background: currentColor; transition: transform var(--dur-fast), opacity var(--dur-fast); }
.cmp-hd-burger__line:nth-child(1) { top: 0; }
.cmp-hd-burger__line:nth-child(2) { top: 6px; }
.cmp-hd-burger__line:nth-child(3) { top: 12px; }

/* ── mobile drawer ── */
.cmp-hd-drawer {
  position: fixed; inset: 0; z-index: 60;
  background: var(--canvas);
  transform: translateX(100%);
  transition: transform var(--dur-base) var(--ease-out);
  overflow-y: auto;
  visibility: hidden;
}
.cmp-hd-drawer.is-open { transform: translateX(0); visibility: visible; }
@media (min-width: 1024px) { .cmp-hd-drawer { display: none; } }
.cmp-hd-drawer__inner { display: flex; flex-direction: column; min-height: 100dvh; }
.cmp-hd-drawer__top { display: flex; align-items: center; justify-content: space-between; padding: 1rem var(--gutter); border-bottom: 1px solid var(--border-hair); }
.cmp-hd-drawer__close { width: 36px; height: 36px; border: 0; background: transparent; color: var(--ink); font-size: 1.4rem; cursor: pointer; }
.cmp-hd-drawer__nav { padding: 0.5rem var(--gutter); }
.cmp-hd-drawer__menu { list-style: none; margin: 0; padding: 0; }
.cmp-hd-drawer__menu li { border-bottom: 1px solid var(--border-hair); }
.cmp-hd-drawer__menu a { display: block; padding: 0.95rem 0; font-family: var(--font-display); font-weight: 600; font-size: 1.05rem; color: var(--ink); }
.cmp-hd-drawer__menu a:hover { color: var(--amber-text); }
.cmp-hd-drawer__cta { margin: 1rem var(--gutter); }
.cmp-hd-drawer__fleet { display: flex; align-items: center; justify-content: space-between; margin: 0 var(--gutter) 1rem; padding: 0.75rem 0.9rem; border: 1px solid var(--border-hair); border-radius: var(--r-sm); }
.cmp-hd-drawer__footer { margin-top: auto; padding: 1.25rem var(--gutter); border-top: 1px solid var(--border-hair); }
.cmp-hd-drawer__email { font-family: var(--font-mono); font-size: 0.8rem; color: var(--ink); }
.cmp-hd-hairline { height: 1px; background: var(--border-hair); }
