/* ============================================================
   CREWTHAT — PUBLIC SITE (landing / welcome / auth)
   ------------------------------------------------------------
   Marketing + gate surfaces. Builds on the app token system in
   theme.css (--ct-bg, --ct-red, --ct-green, --ct-amber, --ct-blue …)
   so the public face matches the dashboards. Mobile-first: AV crews
   live on phones in racks, so everything stacks clean at 380px.
   ============================================================ */

:root {
  --pub-max: 1180px;
  --pub-gold: #ffb020;     /* stage-light gold accent */
  --pub-ink: var(--ct-white);
  --pub-dim: var(--ct-gray);
}

* { box-sizing: border-box; }

body.pub {
  margin: 0;
  background: var(--ct-bg-deep, #0d0d0d);
  color: var(--ct-off-white, #e8e8e8);
  font-family: Inter, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  -webkit-font-smoothing: antialiased;
  line-height: 1.55;
}

.pub a { color: inherit; }
.pub-wrap { max-width: var(--pub-max); margin: 0 auto; padding: 0 20px; }

/* ---------- top bar ---------- */
.pub-nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(13,13,13,0.82);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--ct-border, #2a2a2a);
}
.pub-nav-inner {
  max-width: var(--pub-max); margin: 0 auto;
  display: flex; align-items: center; gap: 16px;
  padding: 12px 20px;
}
.pub-brand {
  display: flex; align-items: center; gap: 10px;
  font-family: 'Bebas Neue', sans-serif; font-size: 26px; letter-spacing: 1px;
  text-decoration: none; color: var(--pub-ink);
}
.pub-brand .dot { width: 11px; height: 11px; border-radius: 50%; background: var(--ct-red); box-shadow: 0 0 12px var(--ct-red); }
.pub-nav-links { margin-left: auto; display: flex; align-items: center; gap: 8px; }
.pub-nav-links a { text-decoration: none; font-size: 14px; font-weight: 500; color: var(--pub-dim); padding: 8px 12px; border-radius: 8px; }
.pub-nav-links a:hover { color: var(--pub-ink); }
.pub-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font: 600 14px/1 Inter, sans-serif; text-decoration: none; cursor: pointer;
  padding: 11px 18px; border-radius: 10px; border: 1px solid transparent; transition: .15s;
}
.pub-btn.primary { background: var(--ct-red); color: #fff; }
.pub-btn.primary:hover { background: var(--ct-red-hover, #e02222); }
.pub-btn.ghost { background: transparent; border-color: var(--ct-border-hi, #3a3a3a); color: var(--pub-ink); }
.pub-btn.ghost:hover { border-color: var(--pub-gold); color: var(--pub-gold); }
.pub-btn.block { width: 100%; padding: 14px; font-size: 15px; }

/* ---------- hero / coming-soon banner ---------- */
.pub-hero {
  position: relative; overflow: hidden;
  padding: 64px 0 52px;
  border-bottom: 1px solid var(--ct-border, #2a2a2a);
}
.pub-hero::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 55% 45% at 18% 25%, rgba(204,31,31,0.16), transparent 60%),
    radial-gradient(ellipse 50% 45% at 84% 70%, rgba(255,176,32,0.10), transparent 60%);
}
.pub-hero::after {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 46px 46px;
  mask-image: radial-gradient(ellipse at 50% 0%, black 10%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse at 50% 0%, black 10%, transparent 75%);
}
.pub-hero .pub-wrap { position: relative; z-index: 1; }
.pub-eyebrow {
  display: inline-flex; align-items: center; gap: 9px;
  font: 700 12px/1 'JetBrains Mono', monospace; letter-spacing: .14em; text-transform: uppercase;
  color: var(--pub-gold);
  background: rgba(255,176,32,0.08); border: 1px solid rgba(255,176,32,0.28);
  padding: 8px 14px; border-radius: 999px; margin-bottom: 22px;
}
.pub-eyebrow .live-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--ct-green); box-shadow: 0 0 8px var(--ct-green); animation: pubPulse 1.8s infinite; }
@keyframes pubPulse { 0%,100% { opacity: 1 } 50% { opacity: .35 } }

.pub-hero h1 {
  font-family: 'Bebas Neue', sans-serif; font-weight: 400;
  font-size: clamp(40px, 8vw, 76px); line-height: 0.96; letter-spacing: 0.5px;
  margin: 0 0 18px; color: var(--pub-ink);
}
.pub-hero h1 .accent { color: var(--ct-red); }
.pub-hero .lede {
  font-size: clamp(16px, 2.4vw, 21px); color: var(--ct-off-white);
  max-width: 720px; margin: 0 0 14px;
}
.pub-hero .lede strong { color: var(--pub-gold); font-weight: 700; }
.pub-hero .sub {
  font-size: 15px; color: var(--pub-dim); max-width: 640px; margin: 0 0 30px;
}
.pub-hero-cta { display: flex; flex-wrap: wrap; gap: 12px; }

/* ---------- stat strip ---------- */
.pub-stats {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px;
  margin-top: 40px;
}
.pub-stat {
  background: var(--ct-bg-card, #1a1a1a); border: 1px solid var(--ct-border, #2a2a2a);
  border-radius: 14px; padding: 18px 16px; text-align: center;
}
.pub-stat .n { font-family: 'JetBrains Mono', monospace; font-size: 30px; font-weight: 700; color: var(--pub-ink); }
.pub-stat .n.green { color: var(--ct-green); }
.pub-stat .n.gold  { color: var(--pub-gold); }
.pub-stat .n.blue  { color: var(--ct-blue); }
.pub-stat .l { font-size: 12px; color: var(--pub-dim); text-transform: uppercase; letter-spacing: .08em; margin-top: 4px; }

/* ---------- section scaffolding ---------- */
.pub-section { padding: 56px 0; }
.pub-section-head { margin-bottom: 30px; }
.pub-section-head .kicker {
  font: 700 12px/1 'JetBrains Mono', monospace; letter-spacing: .14em; text-transform: uppercase;
  color: var(--ct-red); margin-bottom: 10px;
}
.pub-section-head h2 {
  font-family: 'Bebas Neue', sans-serif; font-weight: 400;
  font-size: clamp(30px, 5vw, 46px); line-height: 1; margin: 0 0 8px; color: var(--pub-ink);
}
.pub-section-head p { color: var(--pub-dim); margin: 0; max-width: 640px; font-size: 15px; }

/* ---------- request form + most-requested ---------- */
.pub-request {
  display: grid; grid-template-columns: 1.5fr 1fr; gap: 26px; align-items: start;
}
.pub-card {
  background: var(--ct-bg-card, #1a1a1a); border: 1px solid var(--ct-border, #2a2a2a);
  border-radius: 16px; padding: 26px;
}
.pub-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.pub-field { margin-bottom: 14px; }
.pub-field label {
  display: block; font-size: 12px; font-weight: 600; color: var(--pub-dim);
  text-transform: uppercase; letter-spacing: .06em; margin-bottom: 6px;
}
.pub-field input, .pub-field textarea, .pub-field select {
  width: 100%; background: var(--ct-bg-input, #141414); color: var(--pub-ink);
  border: 1px solid var(--ct-border, #2a2a2a); border-radius: 10px;
  padding: 12px 13px; font: 400 15px/1.4 Inter, sans-serif; outline: none;
}
.pub-field input:focus, .pub-field textarea:focus, .pub-field select:focus { border-color: var(--ct-red); }
.pub-field textarea { resize: vertical; min-height: 84px; }

.mr-card h3 { font-family: 'Bebas Neue', sans-serif; font-weight: 400; font-size: 24px; margin: 0 0 4px; color: var(--pub-ink); }
.mr-card .mr-note { color: var(--pub-dim); font-size: 13px; margin: 0 0 14px; }
.mr-list { list-style: none; margin: 0; padding: 0; }
.mr-row { display: flex; align-items: center; gap: 12px; padding: 10px 0; border-top: 1px solid var(--ct-border, #2a2a2a); }
.mr-row:first-child { border-top: none; }
.mr-rank { font-family: 'JetBrains Mono', monospace; font-size: 13px; color: var(--pub-dim); width: 18px; }
.mr-name { flex: 1; font-size: 14px; color: var(--ct-off-white); }
.mr-votes { font-family: 'JetBrains Mono', monospace; font-size: 13px; color: var(--ct-green); }
.mr-empty { color: var(--pub-dim); font-size: 14px; padding: 12px 0; list-style: none; }

/* ---------- catalog ---------- */
.cat-group { margin-bottom: 38px; }
.cat-group-head { display: flex; align-items: baseline; gap: 12px; margin-bottom: 16px; }
.cat-group-head h3 { font-family: 'Bebas Neue', sans-serif; font-weight: 400; font-size: 28px; margin: 0; color: var(--pub-ink); }
.cat-group-count { font: 700 13px/1 'JetBrains Mono', monospace; color: var(--pub-dim); background: var(--ct-bg-card); border: 1px solid var(--ct-border); border-radius: 999px; padding: 4px 10px; }
.cat-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; }

.cat-tile {
  background: var(--ct-bg-card, #1a1a1a); border: 1px solid var(--ct-border, #2a2a2a);
  border-radius: 14px; padding: 18px; display: flex; flex-direction: column;
  transition: transform .15s, border-color .15s;
}
.cat-tile:hover { transform: translateY(-2px); border-color: var(--ct-border-hi, #3a3a3a); }
.cat-tile.is-live:hover  { border-color: rgba(46,204,113,0.5); }
.cat-tile.is-soon:hover  { border-color: rgba(243,156,18,0.5); }
.cat-tile.is-road:hover  { border-color: rgba(58,158,232,0.5); }
.cat-tile-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.cat-icon { font-size: 26px; line-height: 1; }
.cat-pill {
  font: 700 10px/1 'JetBrains Mono', monospace; letter-spacing: .08em;
  padding: 5px 9px; border-radius: 999px; color: #0d0d0d;
}
.cat-pill.is-live { background: var(--ct-green, #2ecc71); }
.cat-pill.is-soon { background: var(--pub-gold); }
.cat-pill.is-road { background: var(--ct-blue, #3a9ee8); color: #fff; }
.cat-name { font-size: 16px; font-weight: 700; margin: 0 0 6px; color: var(--pub-ink); }
.cat-desc { font-size: 13.5px; color: var(--pub-dim); margin: 0 0 16px; flex: 1; }
.cat-tile-foot { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.cat-sub { font: 600 11px/1 'JetBrains Mono', monospace; color: var(--pub-dim); text-transform: uppercase; letter-spacing: .05em; }

.cat-cta {
  font: 600 13px/1 Inter, sans-serif; text-decoration: none; cursor: pointer;
  padding: 8px 13px; border-radius: 9px; border: 1px solid var(--ct-border-hi, #3a3a3a);
  background: transparent; color: var(--pub-ink); white-space: nowrap;
}
.cat-tile.is-live .cat-cta { border-color: rgba(46,204,113,0.45); color: var(--ct-green); }
.cat-tile.is-live .cat-cta:hover { background: rgba(46,204,113,0.12); }
.cat-tile.is-soon .cat-cta:hover { border-color: var(--pub-gold); color: var(--pub-gold); }
.cat-cta.is-locked { cursor: default; color: var(--pub-dim); border-style: dashed; }
.cat-vote { display: inline-flex; align-items: center; gap: 7px; }
.cat-vote .vote-arrow { color: var(--ct-blue); font-size: 11px; }
.cat-vote .vote-n { font-family: 'JetBrains Mono', monospace; color: var(--pub-dim); font-size: 12px; }
.cat-vote.voted { border-color: var(--ct-blue); color: var(--ct-blue); }

/* ---------- generic content card (auth pages) ---------- */
.pub-center { min-height: calc(100vh - 64px); display: flex; align-items: center; justify-content: center; padding: 40px 20px; }
.pub-panel { width: 100%; max-width: 440px; }
.pub-panel h1 { font-family: 'Bebas Neue', sans-serif; font-weight: 400; font-size: 40px; margin: 0 0 6px; color: var(--pub-ink); }
.pub-panel .muted { color: var(--pub-dim); font-size: 14px; margin: 0 0 22px; }
.pub-msg { padding: 12px 14px; border-radius: 10px; font-size: 14px; margin-bottom: 14px; }
.pub-msg.err  { background: rgba(204,31,31,0.12); border: 1px solid rgba(204,31,31,0.4); color: #ffbcbc; }
.pub-msg.ok   { background: rgba(46,204,113,0.12); border: 1px solid rgba(46,204,113,0.4); color: #b7f3cf; }
.pub-msg.info { background: rgba(255,176,32,0.10); border: 1px solid rgba(255,176,32,0.3); color: #ffe0a8; }
.pub-fineprint { font-size: 12px; color: var(--pub-dim); margin-top: 16px; text-align: center; }
.pub-fineprint a { color: var(--pub-gold); text-decoration: none; }

/* ---------- footer ---------- */
.pub-footer { border-top: 1px solid var(--ct-border, #2a2a2a); padding: 38px 0; margin-top: 20px; color: var(--pub-dim); }
.pub-footer-inner { display: flex; flex-wrap: wrap; gap: 18px; align-items: center; justify-content: space-between; }
.pub-footer a { color: var(--pub-dim); text-decoration: none; font-size: 13px; margin-right: 16px; }
.pub-footer a:hover { color: var(--pub-ink); }
.pub-footer .ver { font-family: 'JetBrains Mono', monospace; font-size: 12px; }

/* ---------- toast ---------- */
#ct-toasts { position: fixed; bottom: 20px; left: 50%; transform: translateX(-50%); z-index: 9999; display: flex; flex-direction: column; gap: 8px; align-items: center; width: calc(100% - 40px); max-width: 460px; }
.ct-toast { width: 100%; background: #161616; border: 1px solid var(--ct-green); color: var(--pub-ink); padding: 13px 16px; border-radius: 11px; font-size: 14px; box-shadow: 0 16px 40px -12px rgba(0,0,0,0.7); opacity: 0; transform: translateY(12px); transition: .26s; }
.ct-toast.show { opacity: 1; transform: translateY(0); }
.ct-toast.err { border-color: var(--ct-red); }

/* ---------- responsive ---------- */
@media (max-width: 820px) {
  .pub-request { grid-template-columns: 1fr; }
  .pub-stats { grid-template-columns: 1fr; }
  .pub-form-row { grid-template-columns: 1fr; }
  .pub-nav-links a:not(.pub-btn) { display: none; }
}

/* ============================================================
   SERVICES SUITE — catalog grid, plan cards, admin toggles
   ============================================================ */
.svc-toolbar { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; margin-bottom: 26px; }
.svc-search {
  flex: 1; min-width: 220px; background: var(--ct-bg-input, #141414); color: var(--pub-ink);
  border: 1px solid var(--ct-border, #2a2a2a); border-radius: 10px; padding: 12px 14px;
  font: 400 15px/1 Inter, sans-serif; outline: none;
}
.svc-search:focus { border-color: var(--ct-red); }
.svc-filters { display: flex; flex-wrap: wrap; gap: 7px; }
.svc-chip {
  font: 600 12px/1 Inter, sans-serif; cursor: pointer; padding: 9px 13px; border-radius: 999px;
  background: transparent; border: 1px solid var(--ct-border-hi, #3a3a3a); color: var(--pub-dim);
}
.svc-chip:hover { color: var(--pub-ink); }
.svc-chip.active { background: var(--ct-red); border-color: var(--ct-red); color: #fff; }

.svc-domain { margin-bottom: 38px; }
.svc-domain-head { display: flex; align-items: center; gap: 11px; margin-bottom: 16px; }
.svc-domain-icon { font-size: 22px; }
.svc-domain-head h3 { font-family: 'Bebas Neue', sans-serif; font-weight: 400; font-size: 28px; margin: 0; color: var(--pub-ink); }
.svc-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(270px, 1fr)); gap: 14px; }

.svc-tile {
  background: var(--ct-bg-card, #1a1a1a); border: 1px solid var(--ct-border, #2a2a2a);
  border-radius: 13px; padding: 16px; display: flex; flex-direction: column;
  transition: transform .14s, border-color .14s;
}
.svc-tile:hover { transform: translateY(-2px); border-color: var(--ct-border-hi, #3a3a3a); }
.svc-tile-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.svc-tier { font: 700 10px/1 'JetBrains Mono', monospace; letter-spacing: .04em; padding: 4px 8px; border-radius: 6px; border: 1px solid transparent; }
.svc-tier.tier-core { color: var(--ct-green); border-color: rgba(46,204,113,0.4); }
.svc-tier.tier-pro  { color: var(--pub-gold); border-color: rgba(255,176,32,0.4); }
.svc-tier.tier-ent  { color: var(--ct-blue); border-color: rgba(58,158,232,0.4); }
.svc-tier.tier-add  { color: #ff8a7a; border-color: rgba(204,31,31,0.4); }
.svc-name { font-size: 15px; font-weight: 700; margin: 0 0 5px; color: var(--pub-ink); }
.svc-desc { font-size: 13px; color: var(--pub-dim); margin: 0 0 12px; flex: 1; line-height: 1.45; }
.svc-meta { margin-bottom: 10px; }
.svc-cat { font: 600 10px/1 'JetBrains Mono', monospace; color: var(--pub-dim); text-transform: uppercase; letter-spacing: .05em; }
.svc-foot { display: flex; align-items: center; justify-content: space-between; gap: 8px; border-top: 1px solid var(--ct-border, #2a2a2a); padding-top: 10px; }
.svc-sec { font-size: 11px; color: var(--pub-dim); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.svc-empty { text-align: center; color: var(--pub-dim); padding: 40px; }

/* plan cards */
.plan-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 16px; }
.plan-card { background: var(--ct-bg-card, #1a1a1a); border: 1px solid var(--ct-border, #2a2a2a); border-radius: 16px; padding: 24px; display: flex; flex-direction: column; }
.plan-card.accent-green { border-top: 3px solid var(--ct-green); }
.plan-card.accent-gold  { border-top: 3px solid var(--pub-gold); }
.plan-card.accent-blue  { border-top: 3px solid var(--ct-blue); }
.plan-card.accent-red   { border-top: 3px solid var(--ct-red); }
.plan-name { font-family: 'Bebas Neue', sans-serif; font-size: 30px; color: var(--pub-ink); }
.plan-count { font: 700 13px/1 'JetBrains Mono', monospace; color: var(--pub-gold); margin: 2px 0 12px; }
.plan-blurb { font-size: 14px; color: var(--pub-dim); flex: 1; margin: 0 0 18px; line-height: 1.5; }

/* admin per-shop toggles */
.adm-svc-group { margin-bottom: 22px; }
.adm-svc-group-head { font: 700 12px/1 'JetBrains Mono', monospace; letter-spacing: .08em; text-transform: uppercase; color: #888; margin-bottom: 10px; }
.adm-svc-group-head span { color: #555; margin-left: 6px; }
.adm-svc-row { display: flex; align-items: center; gap: 14px; padding: 11px 12px; background: #0d0d0d; border: 1px solid #2a2a2a; margin-bottom: 7px; border-radius: 8px; }
.adm-svc-info { flex: 1; min-width: 0; }
.adm-svc-name { color: #fff; font-size: 14px; font-weight: 700; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.adm-svc-desc { color: #888; font-size: 12px; margin-top: 3px; }
.adm-incl { font: 600 9px/1 'JetBrains Mono', monospace; color: #2ecc71; text-transform: uppercase; letter-spacing: .06em; }
.adm-addon { font: 600 9px/1 'JetBrains Mono', monospace; color: #ff8a7a; text-transform: uppercase; letter-spacing: .06em; }
.adm-up { font: 600 9px/1 'JetBrains Mono', monospace; color: #888; text-transform: uppercase; letter-spacing: .06em; }
.adm-toggle { flex: 0 0 auto; width: 46px; height: 26px; border-radius: 999px; border: 1px solid #3a3a3a; background: #222; position: relative; cursor: pointer; transition: .16s; }
.adm-toggle .adm-knob { position: absolute; top: 2px; left: 2px; width: 20px; height: 20px; border-radius: 50%; background: #777; transition: .16s; }
.adm-toggle.on { background: rgba(46,204,113,0.25); border-color: #2ecc71; }
.adm-toggle.on .adm-knob { left: 22px; background: #2ecc71; }

.svc-chip-sep { width: 1px; align-self: stretch; background: var(--ct-border, #2a2a2a); margin: 0 2px; }
.svc-count { font: 600 12px/1 'JetBrains Mono', monospace; color: var(--pub-dim); margin-bottom: 14px; text-transform: uppercase; letter-spacing: .05em; }
.svc-more-wrap { text-align: center; margin-top: 26px; }
.adm-svc-tools { display: flex; gap: 10px; align-items: center; margin-bottom: 14px; }
.adm-svc-search { flex: 1; background: #141414; border: 1px solid #2a2a2a; color: #e8e8e8; font-size: 13px; padding: 9px 11px; outline: none; border-radius: 8px; }
.adm-svc-search:focus { border-color: #cc1f1f; }
.adm-more { text-align: center; margin-top: 14px; }

/* ---------- coming-soon countdown + stats + vote ---------- */
.countdown { display: flex; gap: 10px; margin: 6px 0 16px; flex-wrap: wrap; }
.cd-cell { background: var(--ct-bg-card, #1a1a1a); border: 1px solid var(--ct-border, #2a2a2a);
  border-radius: 12px; padding: 10px 14px; min-width: 70px; text-align: center; }
.cd-n { display: block; font-family: 'JetBrains Mono', monospace; font-size: 30px; font-weight: 700; color: var(--pub-ink); line-height: 1; }
.cd-l { display: block; font-size: 10px; text-transform: uppercase; letter-spacing: .12em; color: var(--pub-dim); margin-top: 5px; }
.cd-live { font-family: 'Bebas Neue', sans-serif; font-size: 30px; color: var(--ct-green); }
.cs-stats { font-size: 14px; color: var(--pub-dim); margin: 0 0 22px; }
.cs-stats strong { color: var(--pub-gold); font-family: 'JetBrains Mono', monospace; }
.mr-vote { background: transparent; border: 1px solid var(--ct-border-hi, #3a3a3a); color: var(--ct-green);
  font-family: 'JetBrains Mono', monospace; font-size: 12px; padding: 5px 10px; border-radius: 8px; cursor: pointer; white-space: nowrap; }
.mr-vote:hover { border-color: var(--ct-green); }
.mr-vote.voted { background: rgba(46,204,113,0.12); border-color: var(--ct-green); }
.mr-vote:disabled { opacity: .6; cursor: default; }

/* ---------- signup password meter + divider ---------- */
.pw-meter { height: 6px; background: var(--ct-bg-input, #141414); border: 1px solid var(--ct-border, #2a2a2a); border-radius: 999px; margin-top: 8px; overflow: hidden; }
.pw-meter > span { display: block; height: 100%; width: 0; background: #cc1f1f; transition: width .2s, background .2s; }
.pw-hint { font-size: 12px; color: var(--pub-dim, #888); margin-top: 6px; }
.su-or { display: flex; align-items: center; gap: 12px; margin: 14px 0; color: var(--pub-dim, #888); font-size: 12px; text-transform: uppercase; letter-spacing: .1em; }
.su-or::before, .su-or::after { content: ''; flex: 1; height: 1px; background: var(--ct-border, #2a2a2a); }

/* service chip count badges */
.svc-chip-n { display:inline-block; margin-left:6px; padding:1px 7px; border-radius:999px; font:700 10px/1.6 'JetBrains Mono',monospace;
  background:rgba(255,255,255,0.08); color:var(--pub-dim,#9ba0a8); }
.svc-chip.active .svc-chip-n { background:rgba(0,0,0,0.25); color:#fff; }

/* ---------- NEW badge + New chip + Featured strip (3Fs pass 1) ---------- */
.svc-tile { position: relative; }
.svc-new { position: absolute; top: -7px; right: 12px; z-index: 2;
  font: 800 9px/1 'JetBrains Mono', monospace; letter-spacing: .1em; color: #0d0d0d;
  background: var(--grad-gold, linear-gradient(135deg,#ffcf6e,#ffb020)); padding: 4px 8px; border-radius: 6px;
  box-shadow: 0 4px 14px -3px rgba(255,176,32,.6); }
.svc-chip.svc-chip-new { border-color: rgba(255,176,32,.4); color: var(--pub-gold,#ffb020); }
.svc-chip.svc-chip-new.active { background: var(--pub-gold,#ffb020); border-color: var(--pub-gold,#ffb020); color: #0d0d0d; }
.svc-tile.is-featured { border-color: rgba(255,176,32,.4); box-shadow: var(--elev-2, 0 10px 28px -10px rgba(0,0,0,.65)), 0 0 0 1px rgba(255,176,32,.25); }

.svc-featured { margin-bottom: 40px; }
.svc-feature-head { display: flex; align-items: center; gap: 9px; font-family: 'Bebas Neue', sans-serif; font-size: 26px;
  color: var(--pub-ink, #f7f7f7); margin-bottom: 16px; }
.svc-feature-kicker { color: var(--pub-gold, #ffb020); font-size: 18px; }
.svc-feature-strip { display: grid; grid-auto-flow: column; grid-auto-columns: minmax(280px, 1fr); gap: 16px;
  overflow-x: auto; padding-bottom: 10px; scroll-snap-type: x mandatory; }
.svc-feature-strip .svc-tile { scroll-snap-align: start; }
.svc-feature-strip::-webkit-scrollbar { height: 8px; }
.svc-feature-strip::-webkit-scrollbar-thumb { background: var(--ct-border-hi,#3a3a3a); border-radius: 999px; }
@media (max-width: 600px){ .svc-feature-strip { grid-auto-columns: 84%; } }

/* count-up stat numbers */
.pub-stat .n { transition: none; }

/* ---------- trust band (3Fs pass 3) ---------- */
.pub-trust { border-top: 1px solid var(--ct-border,#2a2a2a); border-bottom: 1px solid var(--ct-border,#2a2a2a); background: rgba(255,255,255,0.014); }
.pub-trust-inner { display: flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: 14px; padding: 15px 20px; font-size: 13px; color: var(--pub-dim,#9ba0a8); }
.pub-trust-item strong { color: var(--pub-gold,#ffb020); font-family: 'JetBrains Mono', monospace; }
.pub-trust-dot { width: 4px; height: 4px; border-radius: 50%; background: var(--ct-border-hi,#3a3a3a); }
@media (max-width: 620px){ .pub-trust-dot { display: none; } .pub-trust-inner { gap: 8px 16px; } }
