/**
 * PixelSwarm shared UI: chamfered carbon control (landing menu button look).
 *
 * - .ps-carbon-btn — default gray carbon face (use with Bootstrap .btn on index/app).
 * - .ps-carbon-btn--primary — Hive red fill (with .btn.btn-primary).
 * - .ps-carbon-btn--pizza — orange HivePizza CTA (index).
 * - .ps-carbon-btn--vivid — brighter saturated red (use with --primary, e.g. paint submit).
 * - data-ps-press-sfx — click / Enter / Space sound (pixelswarm-ui.js + initPressSfx).
 *   Themed faces use ::before — use <button type="submit">, not <input type="submit"> (no ::before in WebKit).
 */
.ps-carbon-btn {
  --ps-chamfer: 7px;
  position: relative;
  z-index: 0;
  display: inline-block;
  isolation: isolate;
  padding: 0.5rem 0.8rem 0.52rem 0.88rem;
  color: rgba(214, 220, 230, 0.94);
  text-decoration: none;
  font-family: var(--font-recursive, ui-sans-serif, system-ui, sans-serif);
  font-variation-settings: "slnt" 0, "wght" 520, "CASL" 0, "CRSV" 0, "MONO" 0.12;
  font-weight: 400;
  font-size: 1.06rem;
  letter-spacing: 0.01em;
  transform: translateY(0);
  transform-origin: 50% 100%;
  transition: transform 0.14s cubic-bezier(0.33, 1, 0.68, 1);
  border: none;
  background: transparent;
  cursor: pointer;
  box-sizing: border-box;
  text-align: left;
}

.ps-carbon-btn::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  clip-path: polygon(
    var(--ps-chamfer) 0%,
    calc(100% - var(--ps-chamfer)) 0%,
    100% var(--ps-chamfer),
    100% calc(100% - var(--ps-chamfer)),
    calc(100% - var(--ps-chamfer)) 100%,
    var(--ps-chamfer) 100%,
    0% calc(100% - var(--ps-chamfer)),
    0% var(--ps-chamfer)
  );
  background-color: #0a0b0d;
  background-image:
    linear-gradient(128deg, rgba(255, 255, 255, 0.05) 0%, transparent 42%),
    repeating-linear-gradient(
      -56deg,
      transparent,
      transparent 2px,
      rgba(0, 0, 0, 0.28) 2px,
      rgba(0, 0, 0, 0.28) 4px
    ),
    repeating-linear-gradient(
      34deg,
      transparent,
      transparent 2px,
      rgba(255, 255, 255, 0.022) 2px,
      rgba(255, 255, 255, 0.022) 4px
    ),
    linear-gradient(175deg, rgba(38, 40, 48, 0.95) 0%, rgba(8, 8, 10, 0.98) 55%, rgba(5, 5, 6, 1) 100%);
  background-blend-mode: normal, multiply, screen, normal;
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.75),
    0 0 0 2px rgba(48, 52, 58, 0.45),
    inset 0 0 0 1px rgba(195, 205, 218, 0.11),
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    inset 0 -2px 6px rgba(0, 0, 0, 0.42),
    inset 2px 0 0 rgba(255, 255, 255, 0.05),
    inset -2px 0 0 rgba(0, 0, 0, 0.38),
    0 3px 0 rgba(0, 0, 0, 0.55),
    0 5px 14px rgba(0, 0, 0, 0.35);
  transition: box-shadow 0.1s ease;
}

.ps-carbon-btn:active {
  transform: translateY(4px);
  transition-duration: 0.05s;
}

.ps-carbon-btn:active::before {
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.9),
    0 0 0 2px rgba(28, 30, 34, 0.75),
    inset 0 4px 12px rgba(0, 0, 0, 0.65),
    inset 0 2px 4px rgba(0, 0, 0, 0.45),
    inset 0 0 0 1px rgba(120, 135, 155, 0.06),
    inset 2px 2px 4px rgba(0, 0, 0, 0.35),
    inset -2px -2px 3px rgba(255, 255, 255, 0.04),
    0 1px 0 rgba(0, 0, 0, 0.35),
    0 2px 5px rgba(0, 0, 0, 0.2);
}

.ps-carbon-btn:focus {
  outline: none;
}

.ps-carbon-btn:focus-visible::before {
  box-shadow:
    0 0 0 1px #8aa8bc,
    0 0 0 3px rgba(138, 168, 188, 0.22),
    inset 0 0 0 1px rgba(200, 212, 225, 0.2),
    inset 0 1px 0 rgba(255, 255, 255, 0.14),
    inset 0 -2px 6px rgba(0, 0, 0, 0.42),
    inset 2px 0 0 rgba(255, 255, 255, 0.05),
    inset -2px 0 0 rgba(0, 0, 0, 0.38),
    0 3px 0 rgba(0, 0, 0, 0.55),
    0 5px 14px rgba(0, 0, 0, 0.35);
}

.ps-carbon-btn:focus-visible:active {
  transform: translateY(4px);
  transition-duration: 0.05s;
}

.ps-carbon-btn:focus-visible:active::before {
  box-shadow:
    0 0 0 1px #8aa8bc,
    0 0 0 3px rgba(138, 168, 188, 0.18),
    inset 0 4px 12px rgba(0, 0, 0, 0.65),
    inset 0 2px 4px rgba(0, 0, 0, 0.45),
    inset 0 0 0 1px rgba(120, 135, 155, 0.06),
    inset 2px 2px 4px rgba(0, 0, 0, 0.35),
    inset -2px -2px 3px rgba(255, 255, 255, 0.04),
    0 1px 0 rgba(0, 0, 0, 0.35),
    0 2px 5px rgba(0, 0, 0, 0.2);
}

/* Block layout inside menu lists */
.menu-panel .ps-carbon-btn {
  display: block;
  width: 100%;
}

/* Centered CTAs inside cards (swarm picker) */
.card .btn.ps-carbon-btn {
  text-align: center;
}

/* ---- Bootstrap 3: strip default chrome when using carbon face ---- */
a.btn.ps-carbon-btn,
button.btn.ps-carbon-btn,
input.btn.ps-carbon-btn {
  background: transparent !important;
  background-image: none !important;
  border: none !important;
  box-shadow: none !important;
  text-shadow: none !important;
  filter: none !important;
  border-radius: 0 !important;
}

input.btn.ps-carbon-btn {
  appearance: none;
  -webkit-appearance: none;
}

.btn.ps-carbon-btn:hover,
a.btn.ps-carbon-btn:hover {
  filter: none !important;
}

/* Kill Bootstrap / page-level .btn hover fills so ::before chamfer stays visible */
a.btn.ps-carbon-btn:hover,
a.btn.ps-carbon-btn:focus,
button.btn.ps-carbon-btn:hover,
button.btn.ps-carbon-btn:focus,
input.btn.ps-carbon-btn:hover,
input.btn.ps-carbon-btn:focus {
  background: transparent !important;
  background-image: none !important;
  border: none !important;
  box-shadow: none !important;
}

.ps-carbon-btn--primary:hover,
.ps-carbon-btn--primary:focus {
  color: rgba(255, 252, 252, 1);
}

.ps-carbon-btn--primary:hover::before,
.ps-carbon-btn--primary:focus::before {
  filter: brightness(1.07);
}

.ps-carbon-btn--pizza:hover,
.ps-carbon-btn--pizza:focus {
  /* Stronger than page-level `a:hover` (e.g. index) so label stays dark on orange */
  color: #100400;
  text-decoration: none;
}

.ps-carbon-btn--pizza:hover::before,
.ps-carbon-btn--pizza:focus::before {
  filter: brightness(1.06);
}

.btn-sm.ps-carbon-btn {
  --ps-chamfer: 4px;
  padding: 0.38rem 0.72rem 0.42rem 0.78rem;
  font-size: 0.88rem;
}

/* Smaller controls: thinner rim, less inset / drop shadow (default face is heavy on tiny hit targets) */
.btn-sm.ps-carbon-btn::before {
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.62),
    inset 0 0 0 1px rgba(195, 205, 218, 0.07),
    inset 0 1px 0 rgba(255, 255, 255, 0.07),
    inset 0 -1px 3px rgba(0, 0, 0, 0.32),
    inset 1px 0 0 rgba(255, 255, 255, 0.035),
    inset -1px 0 0 rgba(0, 0, 0, 0.28),
    0 1px 0 rgba(0, 0, 0, 0.42),
    0 2px 6px rgba(0, 0, 0, 0.22);
}

.btn-sm.ps-carbon-btn:active {
  transform: translateY(2px);
}

.btn-sm.ps-carbon-btn:active::before {
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.78),
    inset 0 2px 5px rgba(0, 0, 0, 0.5),
    inset 0 1px 2px rgba(0, 0, 0, 0.38),
    inset 0 0 0 1px rgba(120, 135, 155, 0.05),
    inset 1px 1px 2px rgba(0, 0, 0, 0.28),
    inset -1px -1px 2px rgba(255, 255, 255, 0.03),
    0 1px 0 rgba(0, 0, 0, 0.28),
    0 1px 3px rgba(0, 0, 0, 0.16);
}

.btn-sm.ps-carbon-btn:focus-visible::before {
  box-shadow:
    0 0 0 1px #8aa8bc,
    0 0 0 2px rgba(138, 168, 188, 0.16),
    inset 0 0 0 1px rgba(200, 212, 225, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.07),
    inset 0 -1px 3px rgba(0, 0, 0, 0.32),
    inset 1px 0 0 rgba(255, 255, 255, 0.035),
    inset -1px 0 0 rgba(0, 0, 0, 0.28),
    0 1px 0 rgba(0, 0, 0, 0.42),
    0 2px 6px rgba(0, 0, 0, 0.22);
}

.btn-sm.ps-carbon-btn:focus-visible:active {
  transform: translateY(2px);
}

.btn-sm.ps-carbon-btn:focus-visible:active::before {
  box-shadow:
    0 0 0 1px #8aa8bc,
    0 0 0 2px rgba(138, 168, 188, 0.12),
    inset 0 2px 5px rgba(0, 0, 0, 0.5),
    inset 0 1px 2px rgba(0, 0, 0, 0.38),
    inset 0 0 0 1px rgba(120, 135, 155, 0.05),
    inset 1px 1px 2px rgba(0, 0, 0, 0.28),
    inset -1px -1px 2px rgba(255, 255, 255, 0.03),
    0 1px 0 rgba(0, 0, 0, 0.28),
    0 1px 3px rgba(0, 0, 0, 0.16);
}

/* Hive red CTA (app primary) */
.ps-carbon-btn--primary {
  color: rgba(255, 248, 250, 0.98);
  font-variation-settings: "slnt" 0, "wght" 540, "CASL" 0, "CRSV" 0, "MONO" 0.08;
}

.ps-carbon-btn--primary::before {
  background-color: #3a060e;
  background-image:
    linear-gradient(145deg, rgba(255, 255, 255, 0.14) 0%, transparent 40%),
    repeating-linear-gradient(
      -56deg,
      transparent,
      transparent 2px,
      rgba(0, 0, 0, 0.12) 2px,
      rgba(0, 0, 0, 0.12) 4px
    ),
    linear-gradient(180deg, #e91e47 0%, #b00e2e 52%, #6a0818 100%);
  background-blend-mode: normal, multiply, normal;
}

/* Hotter primary face — pair with .ps-carbon-btn--primary */
.ps-carbon-btn--vivid {
  color: #fff;
  font-variation-settings: "slnt" 0, "wght" 560, "CASL" 0.1, "CRSV" 0, "MONO" 0.06;
  text-shadow: 0 1px 0 rgba(0, 0, 0, 0.35);
}

.ps-carbon-btn--vivid.ps-carbon-btn--primary::before {
  background-color: #5c0820;
  background-image:
    linear-gradient(155deg, rgba(255, 255, 255, 0.26) 0%, rgba(255, 180, 200, 0.12) 22%, transparent 46%),
    repeating-linear-gradient(
      -56deg,
      transparent,
      transparent 2px,
      rgba(0, 0, 0, 0.08) 2px,
      rgba(0, 0, 0, 0.08) 4px
    ),
    linear-gradient(185deg, #ff5c85 0%, #f01e52 38%, #c40a32 72%, #7a061f 100%);
  background-blend-mode: normal, multiply, normal;
}

.ps-carbon-btn--vivid.ps-carbon-btn--primary:hover::before,
.ps-carbon-btn--vivid.ps-carbon-btn--primary:focus::before {
  filter: brightness(1.08) saturate(1.12);
}

/* HivePizza orange CTA (index) */
.ps-carbon-btn--pizza {
  color: #1a0a00;
  font-variation-settings: "slnt" 0, "wght" 560, "CASL" 0, "CRSV" 0, "MONO" 0.06;
}

.ps-carbon-btn--pizza::before {
  background-color: #a03802;
  background-image:
    linear-gradient(145deg, rgba(255, 240, 220, 0.35) 0%, transparent 42%),
    repeating-linear-gradient(
      -56deg,
      transparent,
      transparent 2px,
      rgba(0, 0, 0, 0.1) 2px,
      rgba(0, 0, 0, 0.1) 4px
    ),
    linear-gradient(135deg, #ff9f5e 0%, #e85d04 48%, #a04002 100%);
  background-blend-mode: normal, multiply, normal;
}
