:root {
  color-scheme: dark;
  --bg: #090a0f;
  --bg-soft: #0e1320;
  --panel: rgba(18, 21, 31, 0.88);
  --panel-strong: rgba(13, 15, 24, 0.96);
  --panel-accent: rgba(28, 21, 40, 0.96);
  --line: rgba(255, 255, 255, 0.08);
  --line-strong: rgba(67, 125, 255, 0.42);
  --text: #f8fbff;
  --muted: #9ea7bc;
  --blue: #2e7dff;
  --purple: #a13dff;
  --red: #ff4d67;
  --green: #22d96f;
  --green-strong: #0da95c;
  --shadow: 0 28px 90px rgba(0, 0, 0, 0.36);
  --max-width: 1240px;
  --radius: 28px;
}

* {
  box-sizing: border-box;
}

[hidden] {
  display: none !important;
}

html {
  scroll-behavior: auto;
}

body {
  margin: 0;
  min-height: 100vh;
  background:
    radial-gradient(circle at top left, rgba(30, 82, 255, 0.16), transparent 28%),
    radial-gradient(circle at bottom right, rgba(161, 61, 255, 0.18), transparent 24%),
    linear-gradient(180deg, rgba(6, 9, 17, 0.92), rgba(7, 8, 13, 0.98)),
    url("./assets/tool_background.png") center top / cover no-repeat fixed,
    var(--bg);
  color: var(--text);
  font: 16px/1.55 "Barlow", "Segoe UI", sans-serif;
  overflow-x: hidden;
}

body::before,
body::after {
  content: "";
  position: fixed;
  z-index: -1;
  width: 42vw;
  height: 42vw;
  border-radius: 50%;
  filter: blur(88px);
  opacity: 0.28;
  pointer-events: none;
}

body::before {
  top: -14vw;
  left: -10vw;
  background: rgba(46, 125, 255, 0.34);
}

body::after {
  right: -10vw;
  bottom: -18vw;
  background: rgba(161, 61, 255, 0.28);
}

body.policy-page {
  background:
    radial-gradient(circle at top left, rgba(46, 125, 255, 0.16), transparent 28%),
    radial-gradient(circle at bottom right, rgba(255, 126, 46, 0.14), transparent 24%),
    linear-gradient(180deg, rgba(6, 9, 17, 0.96), rgba(7, 8, 13, 0.98)),
    var(--bg);
}

a,
button,
input,
select,
textarea {
  font: inherit;
}

a {
  color: inherit;
  text-decoration: none;
}

button {
  border: 0;
}

.site-shell {
  min-height: 100vh;
}

.policy-shell {
  width: min(920px, calc(100vw - 32px));
  margin: 0 auto;
  padding: 48px 0;
}

.policy-card {
  padding: clamp(24px, 5vw, 48px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 28px;
  background:
    linear-gradient(145deg, rgba(16, 23, 37, 0.94), rgba(10, 12, 20, 0.96)),
    rgba(10, 12, 20, 0.96);
  box-shadow: var(--shadow);
}

.policy-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 28px;
  color: #ffffff;
  font-weight: 900;
  letter-spacing: 0.08em;
}

.policy-brand img {
  width: 42px;
  height: 42px;
  border-radius: 50%;
}

.policy-card h1 {
  margin: 8px 0 8px;
  font-family: "Barlow Condensed", "Barlow", sans-serif;
  font-size: clamp(42px, 8vw, 72px);
  line-height: 0.95;
  text-transform: uppercase;
}

.policy-updated {
  margin: 0 0 28px;
  color: var(--muted);
  font-weight: 700;
}

.policy-section {
  padding: 22px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.policy-section h2 {
  margin: 0 0 10px;
  color: #ffffff;
  font-size: clamp(20px, 3vw, 26px);
  line-height: 1.2;
}

.policy-section p {
  margin: 0;
  color: #b9c2d1;
  line-height: 1.75;
}

.policy-section p + p {
  margin-top: 12px;
}

.policy-section a {
  color: #ffd66b;
  font-weight: 800;
}

.policy-actions {
  margin-top: 10px;
}

#home,
#products,
#listen,
#pricing,
#order,
#toy-clearance,
#downloads,
#contact {
  scroll-margin-top: 104px;
}

.topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(20px);
  background: rgba(7, 9, 15, 0.72);
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.topbar-inner {
  width: min(var(--max-width), calc(100vw - 32px));
  margin: 0 auto;
  min-height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.brand-mark {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: "Orbitron", sans-serif;
  font-size: 22px;
  font-style: italic;
  font-weight: 900;
  letter-spacing: 1.3px;
  text-transform: uppercase;
  white-space: nowrap;
}

.brand-logo {
  width: 40px;
  height: 40px;
  flex: 0 0 auto;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.9);
  background: #ffffff;
  object-fit: cover;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.32);
}

.topnav {
  display: flex;
  flex: 1 1 auto;
  min-width: 0;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  overflow-x: auto;
  padding: 6px 0;
  -ms-overflow-style: none;
  scrollbar-width: none;
}

.topnav::-webkit-scrollbar {
  display: none;
}

.topnav a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  min-height: 36px;
  padding: 0 11px;
  border: 1px solid transparent;
  border-radius: 999px;
  color: #b2bad0;
  font-size: 15px;
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
  transition: color 160ms ease, background 160ms ease, border-color 160ms ease;
}

.topnav a.is-active {
  color: #ffffff;
  border-color: rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.06);
}

.topnav a.is-active::after {
  content: "";
  position: absolute;
  left: 11px;
  right: 11px;
  bottom: 2px;
  display: block;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, #2e7dff, #ff4d67);
}

.topnav a {
  position: relative;
}

.floating-cta {
  position: fixed;
  right: max(18px, calc((100vw - var(--max-width)) / 2 + 18px));
  bottom: 22px;
  z-index: 80;
  display: grid;
  grid-template-columns: auto auto;
  gap: 10px;
  padding: 8px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 24px;
  background: rgba(7, 9, 15, 0.78);
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.42);
  backdrop-filter: blur(18px);
}

body.tabs-ready .floating-cta {
  display: none;
}

body.tabs-ready[data-active-tab="listen"] .floating-cta,
body.tabs-ready[data-active-tab="pricing"] .floating-cta {
  display: grid;
}

.floating-cta-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 20px;
  border-radius: 18px;
  color: #ffffff;
  font-weight: 900;
  white-space: nowrap;
  cursor: pointer;
}

.zalo-button {
  background: linear-gradient(135deg, #0b74ff, #18a7ff);
}

.order-button {
  background: linear-gradient(135deg, #ff7a1a, #ff3d14);
}

.shop-cta,
.primary-button,
.ghost-button,
.accent-button,
.secondary-button,
.platform-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 56px;
  padding: 0 28px;
  border-radius: 20px;
  font-weight: 800;
}

.shop-cta {
  background: linear-gradient(135deg, #ff5a00, #ff3000);
  color: #ffffff;
  min-height: 52px;
  padding: 0 26px;
}

main {
  width: min(var(--max-width), calc(100vw - 32px));
  margin: 0 auto;
  padding: 32px 0 64px;
}

.tabs-ready main > .tab-panel {
  display: none;
}

.tabs-ready main > .tab-panel.is-active-tab {
  display: block;
}

.hero-section {
  padding-top: 28px;
}

.hero-panel,
.surface-card,
.platform-card {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: linear-gradient(160deg, rgba(15, 18, 28, 0.94), rgba(10, 12, 19, 0.96));
  box-shadow: var(--shadow);
}

.hero-panel::before,
.surface-card::before,
.platform-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background:
    linear-gradient(130deg, rgba(46, 125, 255, 0.1), transparent 35%),
    linear-gradient(315deg, rgba(161, 61, 255, 0.1), transparent 42%);
  pointer-events: none;
}

.hero-panel {
  padding: 40px 44px 46px;
}

.hero-bg-video {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  opacity: 0.5;
  object-fit: cover;
  pointer-events: none;
}

.hero-panel::before {
  z-index: 1;
  background:
    linear-gradient(90deg, rgba(9, 12, 20, 0.9), rgba(9, 12, 20, 0.5) 54%, rgba(16, 10, 28, 0.82)),
    linear-gradient(130deg, rgba(46, 125, 255, 0.12), transparent 35%),
    linear-gradient(315deg, rgba(161, 61, 255, 0.12), transparent 42%);
}

.hero-panel > :not(.hero-bg-video) {
  position: relative;
  z-index: 2;
}

.release-pill,
.preset-counter,
.micro-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.04);
}

.release-pill {
  padding: 10px 18px;
  color: #ebf2ff;
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0.4px;
  text-transform: uppercase;
}

.hero-layout {
  margin-top: 34px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 36px;
  align-items: center;
}

.eyebrow,
.micro-label {
  margin: 0;
  color: #9ebcff;
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 1.2px;
  text-transform: uppercase;
}

.hero-copy h1,
.section-heading h2 {
  margin: 0;
  line-height: 0.92;
  text-transform: uppercase;
  text-wrap: balance;
  overflow-wrap: anywhere;
}

.hero-copy h1 {
  margin-top: 18px;
  font-family: "Orbitron", sans-serif;
  font-size: clamp(52px, 9vw, 104px);
  font-style: italic;
  font-weight: 900;
  letter-spacing: 1px;
}

.hero-copy h1 span,
.hero-stage-title span,
.section-heading h2 span {
  color: transparent;
  background: linear-gradient(135deg, #2e7dff 0%, #8f46ff 48%, #ff4d67 100%);
  -webkit-background-clip: text;
  background-clip: text;
}

.hero-text,
.section-copy,
.platform-card p,
.panel-note,
.guide-list,
.contact-list p {
  color: var(--muted);
}

.hero-text {
  max-width: 700px;
  margin: 22px 0 0;
  font-size: clamp(19px, 1.8vw, 24px);
  line-height: 1.45;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-top: 28px;
}

.primary-button {
  background: #ffffff;
  color: #0a0d14;
}

.ghost-button,
.secondary-button {
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.04);
  color: #ffffff;
}

.accent-button {
  background: linear-gradient(135deg, #2e7dff, #8f46ff);
  color: #ffffff;
}

.hero-meta {
  margin: 18px 0 0;
  color: #d6ddf0;
  font-size: 14px;
}

.hero-stage {
  padding: 24px 24px 22px;
  border-radius: 28px;
  border: 1px solid rgba(92, 128, 255, 0.24);
  background:
    linear-gradient(160deg, rgba(14, 20, 36, 0.98), rgba(12, 11, 22, 0.98)),
    rgba(255, 255, 255, 0.02);
}

.hero-stage-logo {
  display: block;
  width: 90px;
  height: 90px;
  margin-bottom: 18px;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.92);
  background: #ffffff;
  object-fit: cover;
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.38);
}

.hero-stage-caption {
  margin: 0;
  color: #bcd1ff;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 2px;
  text-transform: uppercase;
}

.hero-stage-title {
  margin-top: 18px;
  font-family: "Orbitron", sans-serif;
  font-size: clamp(30px, 3.5vw, 48px);
  font-style: italic;
  font-weight: 900;
  line-height: 0.95;
  text-transform: uppercase;
}

.hero-stage-streak {
  height: 5px;
  margin-top: 24px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(46, 125, 255, 0.92), rgba(161, 61, 255, 0.88), rgba(255, 77, 103, 0.88));
  box-shadow: 0 0 32px rgba(86, 99, 255, 0.34);
}

.hero-stage-note {
  margin: 16px 0 0;
  color: #d6d9e4;
  font-size: 15px;
  letter-spacing: 1px;
  text-transform: uppercase;
}

.product-story-section {
  margin-top: 32px;
}

.product-story-heading {
  margin-bottom: 18px;
}

.product-story-heading h2 {
  max-width: 13ch;
}

.product-story-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 18px;
  align-items: stretch;
}

.product-media-card {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.09);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.035);
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.26);
}

.product-media-card img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

.product-media-main img {
  height: 100%;
  min-height: 470px;
}

.product-card-caption {
  position: absolute;
  left: 16px;
  right: 16px;
  bottom: 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 8px;
  background: rgba(7, 9, 15, 0.82);
  color: #ffffff;
  backdrop-filter: blur(12px);
}

.product-card-caption span {
  color: #9ebcff;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.product-card-caption strong {
  font-size: 16px;
  text-align: right;
}

.product-story-points {
  display: grid;
  gap: 12px;
}

.product-story-points article {
  min-height: 0;
  padding: 18px;
  border: 1px solid rgba(255, 255, 255, 0.09);
  border-radius: 8px;
  background: linear-gradient(145deg, rgba(13, 18, 30, 0.88), rgba(20, 13, 29, 0.88));
}

.product-story-points span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 30px;
  border-radius: 8px;
  background: rgba(255, 101, 42, 0.16);
  color: #ff9b70;
  font-size: 13px;
  font-weight: 900;
}

.product-story-points strong {
  display: block;
  margin-top: 12px;
  color: #ffffff;
  font-size: 22px;
  line-height: 1.1;
}

.product-story-points p {
  margin: 9px 0 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.45;
}

.product-gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-top: 16px;
}

.product-gallery-grid .product-media-card {
  display: grid;
}

.product-gallery-grid strong {
  min-height: 48px;
  display: flex;
  align-items: center;
  padding: 0 12px;
  color: #ffffff;
  font-size: 15px;
  line-height: 1.1;
}

.preset-counter {
  padding: 10px 16px;
  color: #dce6ff;
  font-size: 14px;
  font-weight: 700;
}

.products-section,
.listen-section,
.toy-section,
.platform-section {
  margin-top: 44px;
}

.product-list-grid {
  display: grid;
  grid-template-columns: minmax(0, 520px);
  gap: 18px;
}

.product-subtabs {
  width: min(640px, 100%);
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 0 0 18px;
  padding: 6px;
  border: 1px solid rgba(159, 179, 216, 0.16);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.04);
}

.product-subtab {
  min-width: 0;
  min-height: 46px;
  padding: 0 16px;
  border-radius: 7px;
  color: #aebbd1;
  background: transparent;
  font-size: 14px;
  font-weight: 900;
  cursor: pointer;
  transition: color 140ms ease, background 140ms ease, box-shadow 140ms ease;
}

.product-subtab.is-active {
  color: #ffffff;
  background: linear-gradient(135deg, rgba(255, 101, 42, 0.28), rgba(46, 125, 255, 0.16));
  box-shadow: inset 0 -2px 0 #ff6d2d, inset 0 -3px 0 #2e7dff;
}

.product-catalog-card {
  display: grid;
  grid-template-columns: 210px minmax(0, 1fr);
  gap: 18px;
  padding: 16px;
  border-radius: 16px;
  cursor: pointer;
  transition:
    border-color 160ms ease,
    transform 160ms ease,
    box-shadow 160ms ease;
}

.product-catalog-card:hover,
.product-catalog-card:focus-visible {
  border-color: rgba(255, 110, 80, 0.56);
  box-shadow: 0 22px 68px rgba(255, 83, 28, 0.12), var(--shadow);
  transform: translateY(-2px);
  outline: none;
}

.product-catalog-media {
  position: relative;
  overflow: hidden;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.04);
}

.product-catalog-media img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 210px;
  object-fit: cover;
}

.product-badge {
  position: absolute;
  left: 10px;
  top: 10px;
  min-height: 30px;
  display: inline-flex;
  align-items: center;
  padding: 0 10px;
  border-radius: 8px;
  background: linear-gradient(135deg, #ff6d2d, #ff3d14);
  color: #ffffff;
  font-size: 13px;
  font-weight: 900;
}

.product-catalog-body {
  display: grid;
  align-content: center;
  gap: 12px;
  min-width: 0;
}

.product-catalog-body h3 {
  margin: 0;
  color: #ffffff;
  font-family: "Barlow Condensed", "Barlow", sans-serif;
  font-size: 32px;
  line-height: 1;
  text-transform: uppercase;
}

.product-catalog-body p {
  margin: 0;
  color: var(--muted);
  line-height: 1.5;
}

.product-spec-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.product-spec-row span {
  min-height: 30px;
  display: inline-flex;
  align-items: center;
  padding: 0 10px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.06);
  color: #d8e2f8;
  font-size: 13px;
  font-weight: 800;
}

.product-card-action {
  width: fit-content;
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  padding: 0 16px;
  border-radius: 8px;
  background: rgba(255, 101, 42, 0.16);
  color: #ffffff;
  font-weight: 900;
}

.product-detail-panel {
  margin-top: 24px;
  padding: 24px;
  scroll-margin-top: 104px;
}

.product-detail-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 420px;
  gap: 24px;
  align-items: center;
}

.product-detail-copy h2 {
  margin: 10px 0 0;
  max-width: 12ch;
  font-family: "Barlow Condensed", "Barlow", sans-serif;
  font-size: clamp(36px, 5vw, 66px);
  font-style: italic;
  line-height: 0.94;
  text-transform: uppercase;
}

.product-detail-lead {
  max-width: 720px;
  margin: 18px 0 0;
  color: var(--muted);
  font-size: 18px;
  line-height: 1.55;
}

.product-detail-actions {
  margin-top: 22px;
}

.product-detail-main-image,
.product-use-image {
  overflow: hidden;
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.09);
  background: rgba(255, 255, 255, 0.04);
}

.product-detail-main-image img,
.product-use-image img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

.product-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 24px;
}

.product-detail-card {
  display: grid;
  grid-template-columns: 150px minmax(0, 1fr);
  gap: 14px;
  padding: 14px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.035);
}

.product-detail-card img {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 8px;
  object-fit: cover;
}

.product-detail-card h3,
.product-use-copy h3 {
  margin: 0;
  color: #ffffff;
  font-family: "Barlow Condensed", "Barlow", sans-serif;
  font-size: 28px;
  line-height: 1;
  text-transform: uppercase;
}

.product-detail-card p {
  margin: 8px 0 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.45;
}

.product-use-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 18px;
  margin-top: 24px;
  align-items: stretch;
}

.product-use-copy {
  padding: 20px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  background: linear-gradient(145deg, rgba(13, 18, 30, 0.88), rgba(20, 13, 29, 0.88));
}

.product-use-copy h3 {
  margin-top: 8px;
}

.product-steps {
  margin: 16px 0 0;
  padding-left: 20px;
  color: #d4dbea;
}

.product-steps li + li {
  margin-top: 9px;
}

.product-note-box {
  margin-top: 18px;
  padding: 16px 18px;
  border: 1px solid rgba(255, 110, 80, 0.24);
  border-radius: 8px;
  background: rgba(255, 101, 42, 0.08);
}

.product-note-box strong {
  color: #ffffff;
  font-size: 18px;
}

.product-note-box p {
  margin: 8px 0 0;
  color: #d7deef;
}

.product-image-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 18px;
}

.product-image-strip img {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  object-fit: cover;
}

.section-heading {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 420px;
  gap: 24px;
  align-items: start;
  margin-bottom: 24px;
}

.section-heading h2 {
  font-family: "Barlow Condensed", "Barlow", sans-serif;
  font-size: clamp(32px, 4.5vw, 58px);
  font-style: italic;
  font-weight: 900;
  letter-spacing: 0.6px;
  max-width: 10ch;
}

.section-copy {
  margin: 0;
  font-size: 16px;
  line-height: 1.6;
  padding-top: 12px;
}

.listen-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 380px;
  gap: 24px;
}

.listen-panel,
.side-card {
  padding: 24px;
}

.listen-panel-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 20px;
  align-items: end;
  margin-bottom: 22px;
}

.listen-panel-header h3,
.section-head-compact h3,
.platform-card h3 {
  margin: 8px 0 0;
  font-family: "Barlow Condensed", "Barlow", sans-serif;
  font-size: 28px;
  line-height: 1.04;
  letter-spacing: 0.2px;
}

.section-head-compact {
  margin-bottom: 16px;
}

.preset-block {
  display: grid;
  justify-items: end;
  gap: 10px;
}

.compact-field {
  margin: 0;
}

.field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.field span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

select,
input,
textarea {
  width: 100%;
  min-height: 52px;
  padding: 12px 15px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.03);
  color: #ffffff;
  outline: none;
}

select,
select option,
select optgroup {
  color: #111111;
  background: #ffffff;
}

select.sound-select,
select#presetSelect,
select#flashPresetSelect,
select#extraRequestPrice {
  color: #ffffff;
  background: rgba(255, 255, 255, 0.03);
}

select:focus,
input:focus,
textarea:focus {
  border-color: rgba(46, 125, 255, 0.6);
  box-shadow: 0 0 0 4px rgba(46, 125, 255, 0.14);
}

textarea {
  min-height: 148px;
  resize: vertical;
}

.sound-rows {
  display: grid;
  gap: 12px;
}

.sound-row {
  display: grid;
  grid-template-columns: 200px minmax(0, 1fr) 142px;
  gap: 12px;
  align-items: center;
  padding: 14px 16px;
  border-radius: 20px;
  border: 1px solid rgba(255, 255, 255, 0.07);
  background: rgba(255, 255, 255, 0.025);
}

.sound-label {
  display: flex;
  gap: 4px;
  align-items: center;
  min-width: 0;
}

.sound-label-text {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.sound-label-title {
  color: #ffffff;
  font-size: 16px;
  font-weight: 800;
  line-height: 1.05;
}

.sound-label-subtitle {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.2;
}

.sound-select-wrap {
  position: relative;
}

.sound-select {
  min-height: 50px;
  padding-right: 46px;
}

.control-button,
.preview-button {
  width: 100%;
}

.preview-button {
  background: linear-gradient(135deg, var(--green-strong), var(--green));
  color: #f7fff9;
  border-radius: 18px;
  min-height: 50px;
  font-weight: 900;
  box-shadow: 0 0 24px rgba(34, 217, 111, 0.16);
}

.preview-button.is-playing,
.stop-button {
  background: linear-gradient(135deg, #822033, var(--red));
  color: #ffffff;
  box-shadow: 0 0 28px rgba(255, 77, 103, 0.22);
}

.listen-sidebar {
  display: grid;
  gap: 18px;
}

.sound-sections {
  display: grid;
  gap: 14px;
}

.sound-section-card {
  display: grid;
  gap: 12px;
  padding: 14px;
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.025);
}

.sound-section-card h4 {
  margin: 0;
  color: #f4d46f;
  font-family: "Barlow", sans-serif;
  font-size: 14px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.sound-card-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.sound-card-slot {
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 10px;
  padding: 12px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.18);
}

.sound-card-slot .sound-label {
  gap: 10px;
}

.sound-card-slot .preview-button,
.sound-card-slot .control-button {
  min-height: 44px;
}

.sound-card-badge {
  flex: 0 0 auto;
  display: inline-grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border-radius: 8px;
  border: 1px solid rgba(46, 125, 255, 0.38);
  background: rgba(46, 125, 255, 0.15);
  color: #dce8ff;
  font-size: 12px;
  font-weight: 900;
}

body.tabs-ready[data-active-tab="pricing"] #listen .listen-layout,
body.tabs-ready[data-active-tab="contact"] #listen .listen-layout {
  grid-template-columns: minmax(0, 560px);
  justify-content: center;
}

body.tabs-ready[data-active-tab="pricing"] #listen .listen-panel,
body.tabs-ready[data-active-tab="pricing"] #listen #order,
body.tabs-ready[data-active-tab="pricing"] #listen #contact,
body.tabs-ready[data-active-tab="contact"] #listen .listen-panel,
body.tabs-ready[data-active-tab="contact"] #listen #pricing,
body.tabs-ready[data-active-tab="contact"] #listen #order {
  display: none;
}

body.tabs-ready[data-active-tab="pricing"] #listen .listen-sidebar,
body.tabs-ready[data-active-tab="contact"] #listen .listen-sidebar {
  width: 100%;
}

.segmented-control {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 18px;
}

.mode-chip {
  min-height: 48px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.04);
  color: #d3ddf4;
  font-weight: 800;
  cursor: pointer;
}

.mode-chip.is-active {
  background: linear-gradient(135deg, rgba(46, 125, 255, 0.24), rgba(161, 61, 255, 0.28));
  border-color: rgba(98, 145, 255, 0.48);
  color: #ffffff;
}

.price-list {
  display: grid;
  gap: 12px;
}

.price-item,
.price-option,
.price-total,
.price-deposit {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.03);
}

.price-option {
  cursor: pointer;
}

.price-option span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  line-height: 1.25;
}

.price-option strong {
  flex: 0 0 auto;
}

.price-option input {
  width: 18px;
  min-height: 18px;
  accent-color: var(--blue);
}

.price-field {
  margin: 0;
}

.price-summary {
  display: grid;
  gap: 10px;
  margin-top: 16px;
}

.price-summary-line {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 11px 14px;
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.07);
  background: rgba(255, 255, 255, 0.025);
}

.price-discount-line strong {
  color: #b6ffd1;
}

.price-total {
  margin-top: 16px;
  align-items: flex-start;
  border-color: rgba(98, 145, 255, 0.4);
  background: linear-gradient(135deg, rgba(20, 36, 92, 0.84), rgba(74, 37, 113, 0.72));
}

.price-total-copy {
  display: grid;
  gap: 4px;
}

.price-total-copy small {
  color: rgba(238, 243, 255, 0.82);
  font-size: 13px;
}

.price-total-copy s {
  opacity: 0.92;
}

.price-total strong {
  font-size: 26px;
  line-height: 1;
}

.price-deposit strong {
  color: #d6ffe3;
}

.shipping-note {
  margin: 12px 2px 0;
  color: #d8ffe4;
  font-size: 14px;
  font-weight: 700;
}

.action-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.contact-list {
  display: grid;
  gap: 8px;
  margin-bottom: 18px;
}

.contact-list p {
  margin: 0;
}

.shop-link {
  color: #c5d6ff;
}

.full-width {
  width: 100%;
}

.shop-button {
  margin-bottom: 18px;
}

.guide-list {
  margin: 0;
  padding-left: 18px;
}

.guide-list li + li {
  margin-top: 8px;
}

.toy-shop-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 380px;
  gap: 24px;
  align-items: start;
}

.toy-market-panel {
  padding: 24px;
}

.toy-market-toolbar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 18px;
  align-items: end;
  margin-bottom: 18px;
}

.toy-market-toolbar h3 {
  margin: 8px 0 6px;
  font-family: "Barlow Condensed", "Barlow", sans-serif;
  font-size: 30px;
  line-height: 1;
  text-transform: uppercase;
}

.toy-count-text {
  color: var(--muted);
  font-size: 14px;
}

.toy-search-field {
  margin: 0;
}

.toy-filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 18px;
}

.toy-filter-chip {
  min-height: 38px;
  padding: 0 14px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.04);
  color: #d5ddf0;
  font-size: 14px;
  font-weight: 800;
  cursor: pointer;
}

.toy-filter-chip.is-active {
  border-color: rgba(255, 110, 80, 0.52);
  background: rgba(255, 85, 43, 0.18);
  color: #ffffff;
}

.toy-product-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 14px;
}

.toy-product-card {
  display: grid;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.035);
}

.toy-product-card.is-sold {
  opacity: 0.72;
}

.toy-product-media {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.04);
}

.toy-product-media img,
.toy-cart-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.toy-image-placeholder {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  background:
    linear-gradient(135deg, rgba(255, 101, 68, 0.22), rgba(46, 125, 255, 0.18)),
    rgba(255, 255, 255, 0.04);
}

.toy-image-placeholder span {
  width: 54px;
  height: 54px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.12);
  color: #ffffff;
  font-size: 24px;
  font-weight: 900;
}

.toy-discount-badge,
.toy-sold-badge {
  position: absolute;
  top: 10px;
  min-height: 28px;
  display: inline-flex;
  align-items: center;
  padding: 0 9px;
  border-radius: 8px;
  color: #ffffff;
  font-size: 12px;
  font-weight: 900;
}

.toy-discount-badge {
  right: 10px;
  background: #ff3d14;
}

.toy-sold-badge {
  left: 10px;
  background: rgba(13, 15, 24, 0.86);
}

.toy-product-body {
  display: grid;
  gap: 10px;
  padding: 13px;
}

.toy-product-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.toy-product-meta span {
  min-height: 26px;
  display: inline-flex;
  align-items: center;
  padding: 0 8px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.06);
  color: #c7d2ea;
  font-size: 12px;
  font-weight: 800;
}

.toy-product-body h3 {
  margin: 0;
  color: #ffffff;
  font-size: 18px;
  line-height: 1.14;
}

.toy-product-body p {
  min-height: 44px;
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.45;
}

.toy-price-line {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 8px;
}

.toy-price-line strong {
  color: #ffffff;
  font-size: 22px;
  line-height: 1;
}

.toy-price-line s {
  color: #8f99ad;
  font-size: 14px;
}

.toy-review-link {
  color: #bdd1ff;
  font-size: 14px;
  font-weight: 800;
}

.toy-product-footer {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
}

.toy-stock-text {
  color: #aeb8cc;
  font-size: 13px;
  font-weight: 800;
}

.toy-add-button {
  min-height: 40px;
  padding: 0 12px;
  border-radius: 8px;
  background: linear-gradient(135deg, #ff6d2d, #ff3d14);
  color: #ffffff;
  font-size: 14px;
  font-weight: 900;
  cursor: pointer;
}

.toy-add-button:disabled,
.toy-cart-actions button:disabled,
.toy-checkout-card button:disabled {
  cursor: not-allowed;
  opacity: 0.48;
}

.toy-empty-state,
.toy-cart-empty {
  padding: 18px;
  border: 1px dashed rgba(255, 255, 255, 0.16);
  border-radius: 8px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.025);
}

.toy-empty-state {
  grid-column: 1 / -1;
}

.toy-cart-column {
  display: grid;
  gap: 18px;
}

.toy-cart-items {
  display: grid;
  gap: 10px;
}

.toy-cart-item {
  display: grid;
  grid-template-columns: 74px minmax(0, 1fr);
  gap: 10px;
  padding: 10px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.03);
}

.toy-cart-thumb {
  width: 74px;
  height: 74px;
  overflow: hidden;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.04);
}

.toy-cart-thumb .toy-image-placeholder span {
  width: 34px;
  height: 34px;
  font-size: 16px;
}

.toy-cart-info {
  min-width: 0;
  display: grid;
  gap: 6px;
}

.toy-cart-info strong {
  overflow: hidden;
  color: #ffffff;
  font-size: 15px;
  line-height: 1.18;
  text-overflow: ellipsis;
}

.toy-cart-info > span {
  color: #dce6ff;
  font-weight: 900;
}

.toy-qty-controls {
  display: flex;
  align-items: center;
  gap: 7px;
}

.toy-qty-controls button {
  min-width: 30px;
  min-height: 30px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.08);
  color: #ffffff;
  font-weight: 900;
  cursor: pointer;
}

.toy-qty-controls button:disabled {
  opacity: 0.42;
  cursor: not-allowed;
}

.toy-qty-controls span {
  min-width: 20px;
  color: #ffffff;
  text-align: center;
  font-weight: 900;
}

.toy-remove-button {
  margin-left: auto;
  padding: 0 10px;
  color: #ffb1bc;
}

.toy-cart-summary {
  display: grid;
  gap: 9px;
  margin-top: 14px;
}

.toy-cart-summary > div,
.toy-payment-box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 11px 13px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.03);
}

.toy-cart-summary span,
.toy-payment-box span,
.toy-payment-box small {
  color: var(--muted);
}

.toy-cart-summary strong,
.toy-payment-box strong {
  color: #ffffff;
}

.toy-deposit-line {
  border-color: rgba(255, 110, 80, 0.34) !important;
  background: rgba(255, 85, 43, 0.1) !important;
}

.toy-deposit-line strong {
  color: #ffd4c7;
}

.toy-cart-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 14px;
}

.toy-checkout-card .field + .field {
  margin-top: 10px;
}

.toy-payment-box {
  flex-direction: column;
  align-items: flex-start;
  margin: 12px 0;
}

.toy-payment-box strong {
  font-size: 18px;
}

.platform-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
}

.platform-card {
  padding: 28px;
}

.accent-platform {
  background: linear-gradient(160deg, rgba(18, 20, 33, 0.96), rgba(28, 16, 43, 0.98));
}

.platform-icon {
  width: 78px;
  height: 78px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 24px;
  font-family: "Orbitron", sans-serif;
  font-size: 20px;
  font-weight: 900;
}

.blue-icon {
  background: linear-gradient(135deg, rgba(46, 125, 255, 0.22), rgba(46, 125, 255, 0.74));
}

.purple-icon {
  background: linear-gradient(135deg, rgba(120, 50, 255, 0.28), rgba(161, 61, 255, 0.84));
}

.platform-card h3 {
  margin-top: 20px;
}

.platform-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px 16px;
  margin: 18px 0 24px;
  padding: 16px;
  border-radius: 20px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(4, 6, 12, 0.84);
}

.platform-meta span {
  color: #7f899f;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

.platform-meta strong {
  font-size: 16px;
}

.platform-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.platform-button {
  width: 100%;
  background: #ffffff;
  color: #090d14;
}

.outline-button {
  background: transparent;
  color: #ffffff;
  border: 1px solid rgba(255, 255, 255, 0.12);
}

.platform-button.is-disabled,
.platform-button:disabled {
  cursor: not-allowed;
  opacity: 0.52;
  color: #9ea7bc;
  background: rgba(255, 255, 255, 0.04);
}

.small-note {
  margin-top: 12px;
  font-size: 14px;
}

body.receipt-open {
  overflow: hidden;
}

.receipt-modal {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: none;
  padding: 22px;
}

.receipt-modal.is-open {
  display: grid;
  place-items: center;
}

.receipt-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.68);
  backdrop-filter: blur(12px);
}

.receipt-dialog {
  position: relative;
  z-index: 1;
  width: min(1120px, calc(100vw - 28px));
  max-height: calc(100vh - 28px);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 26px;
  background: rgba(10, 12, 18, 0.98);
  box-shadow: 0 30px 120px rgba(0, 0, 0, 0.58);
}

.receipt-toolbar,
.receipt-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 16px 18px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.receipt-toolbar h2 {
  margin: 8px 0 0;
  font-size: 24px;
}

.receipt-close-button {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
  color: #ffffff;
  font-size: 30px;
  line-height: 1;
  cursor: pointer;
}

.receipt-scroll {
  overflow: auto;
  padding: 18px;
  background: #dfe3eb;
}

.order-receipt {
  width: min(100%, 960px);
  margin: 0 auto;
  padding: 34px 32px 22px;
  background: #ffffff;
  color: #050505;
  border-radius: 2px;
  box-shadow: 0 14px 42px rgba(0, 0, 0, 0.18);
  font-family: "Barlow", "Segoe UI", sans-serif;
}

.receipt-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 26px;
}

.receipt-brand img {
  width: 238px;
  max-width: 48vw;
  height: auto;
  display: block;
}

.receipt-brand span {
  display: block;
  width: 300px;
  max-width: 50vw;
  height: 4px;
  margin-top: 8px;
  background: linear-gradient(90deg, #ff6500, transparent);
}

.receipt-hero-art {
  width: 438px;
  min-width: 438px;
  height: 188px;
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
  overflow: visible;
}

.receipt-hero-art-image {
  width: 436px;
  max-width: 100%;
  height: auto;
  display: block;
}

.order-receipt h3 {
  margin: 28px 0 0;
  font-size: 42px;
  line-height: 1;
  font-weight: 900;
  text-transform: uppercase;
}

.order-receipt h1 {
  margin: 10px 0 0;
  color: #ff6500;
  font-size: 48px;
  line-height: 1.04;
  font-weight: 900;
  text-transform: uppercase;
}

.receipt-orange-line {
  height: 3px;
  margin: 22px 0 24px;
  background: linear-gradient(90deg, #111 0 28%, #ff6500 28% 100%);
}

.receipt-meta {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: 1px solid #c9c9c9;
  border-radius: 8px;
  overflow: hidden;
}

.receipt-meta div {
  display: grid;
  gap: 4px;
  min-height: 72px;
  padding: 14px 18px;
}

.receipt-meta div + div {
  border-left: 1px solid #d4d4d4;
}

.receipt-meta span {
  font-size: 16px;
  font-weight: 900;
  text-transform: uppercase;
}

.receipt-meta strong {
  color: #ff2500;
  font-size: 20px;
}

.receipt-address-line {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  margin-top: 12px;
  padding: 14px 18px;
  border: 1px solid #c9c9c9;
  border-radius: 8px;
}

.receipt-address-line span {
  flex: 0 0 auto;
  font-size: 16px;
  font-weight: 900;
  text-transform: uppercase;
}

.receipt-address-line strong {
  text-align: right;
  font-size: 18px;
  font-weight: 750;
  overflow-wrap: anywhere;
}

.receipt-box {
  margin-top: 24px;
}

.receipt-section-title {
  display: inline-flex;
  align-items: center;
  min-height: 52px;
  margin-bottom: -20px;
  position: relative;
  z-index: 2;
}

.receipt-section-title span {
  display: grid;
  place-items: center;
  width: 66px;
  height: 56px;
  border-radius: 10px;
  background: #ff6500;
  color: #ffffff;
  font-size: 36px;
  font-weight: 900;
}

.receipt-section-title strong {
  display: grid;
  align-items: center;
  min-height: 44px;
  padding: 0 24px;
  border-radius: 0 8px 8px 0;
  background: #111111;
  color: #ffffff;
  font-size: 26px;
  font-weight: 900;
  text-transform: uppercase;
}

.receipt-list,
.receipt-sound-grid {
  border: 2px solid #333333;
  border-radius: 10px;
  padding: 34px 18px 16px;
}

.receipt-row,
.receipt-sound-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  min-height: 44px;
  border-bottom: 1px solid #dddddd;
  font-size: 20px;
}

.receipt-row span,
.receipt-sound-row span {
  font-weight: 650;
}

.receipt-row strong,
.receipt-sound-row strong {
  text-align: right;
  font-weight: 800;
}

.receipt-red {
  color: #e90000;
}

.receipt-total-row {
  min-height: 68px;
  margin: 8px 0;
  padding: 0 18px;
  border: 2px solid #ff6500;
  border-radius: 10px;
  background: linear-gradient(90deg, #ffc232, #ffe77d);
}

.receipt-total-row span {
  font-size: 26px;
  font-weight: 900;
  text-transform: uppercase;
}

.receipt-total-row strong {
  font-size: 42px;
  line-height: 1;
}

.receipt-sound-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  column-gap: 42px;
}

.receipt-sound-row {
  min-width: 0;
}

.receipt-sound-row strong {
  overflow-wrap: anywhere;
}

.receipt-footer {
  margin-top: 18px;
  padding-top: 12px;
  border-top: 2px solid #ff6500;
  text-align: center;
  font-size: 18px;
  font-weight: 800;
}

.receipt-actions {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  border-bottom: 0;
}

.receipt-actions button {
  flex: 1;
}

.flash-section {
  width: min(var(--max-width), calc(100vw - 36px));
  margin: 0 auto;
  padding: 118px 0 90px;
}

.flash-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 0.42fr);
  gap: 24px;
  align-items: start;
}

.flash-sound-panel {
  padding: 24px;
}

.flash-panel {
  padding: 26px;
}

.flash-sidebar {
  display: grid;
  gap: 18px;
  position: sticky;
  top: 82px;
}

.flash-manual-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 20px;
  align-items: end;
  margin-bottom: 18px;
}

.flash-manual-header h3 {
  margin: 8px 0 0;
  font-family: "Barlow Condensed", "Barlow", sans-serif;
  font-size: 30px;
  line-height: 1.02;
  letter-spacing: 0;
}

.flash-sound-sections {
  margin-top: 16px;
}

.flash-main-column {
  display: grid;
  gap: 18px;
  min-width: 0;
}

.flash-subtabs {
  width: min(760px, 100%);
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 0 0 18px;
  padding: 6px;
  border: 1px solid rgba(159, 179, 216, 0.16);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.04);
}

.flash-subtab {
  min-width: 0;
  min-height: 46px;
  padding: 0 16px;
  border-radius: 7px;
  color: #aebbd1;
  background: transparent;
  font-size: 14px;
  font-weight: 900;
  cursor: pointer;
  transition: color 140ms ease, background 140ms ease, box-shadow 140ms ease;
}

.flash-subtab.is-active {
  color: #ffffff;
  background: linear-gradient(135deg, rgba(46, 125, 255, 0.28), rgba(255, 77, 149, 0.18));
  box-shadow: inset 0 -2px 0 #ff4d95, inset 0 -3px 0 #2e7dff;
}

.flash-section[data-active-flash-subtab="controller"] .flash-layout {
  grid-template-columns: minmax(0, 1fr);
}

.flash-section[data-active-flash-subtab="controller"] .flash-main-column {
  gap: 0;
}

.flash-controller-panel {
  padding: 24px;
}

.controller-test-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  margin-bottom: 16px;
}

.controller-test-header h3 {
  margin: 8px 0 0;
  font-family: "Barlow Condensed", "Barlow", sans-serif;
  font-size: 30px;
  line-height: 1.02;
  letter-spacing: 0;
}

.controller-test-actions {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

.controller-status-pill {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  max-width: 260px;
  padding: 0 13px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 999px;
  color: #d8e2f5;
  background: rgba(255, 255, 255, 0.06);
  font-size: 13px;
  font-weight: 900;
  overflow-wrap: anywhere;
}

.controller-status-pill[data-state="busy"] {
  border-color: rgba(79, 145, 255, 0.46);
  color: #d8e7ff;
  background: rgba(79, 145, 255, 0.14);
  box-shadow: 0 0 0 5px rgba(79, 145, 255, 0.08);
}

.controller-status-pill[data-state="good"] {
  border-color: rgba(34, 217, 111, 0.44);
  color: #b8ffd5;
  background: rgba(34, 217, 111, 0.11);
}

.controller-status-pill[data-state="warn"] {
  border-color: rgba(255, 216, 77, 0.5);
  color: #ffe68a;
  background: rgba(255, 216, 77, 0.12);
}

.controller-status-pill[data-state="bad"] {
  border-color: rgba(255, 77, 103, 0.46);
  color: #ffb8c2;
  background: rgba(255, 77, 103, 0.12);
}

.controller-profile-line {
  display: grid;
  grid-template-columns: 170px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  margin-bottom: 16px;
  padding: 11px 12px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.04);
}

.controller-profile-line span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.controller-profile-line strong {
  min-width: 0;
  color: #f4d46f;
  font-family: "Orbitron", "Barlow", sans-serif;
  font-size: 13px;
  letter-spacing: 0;
  overflow-wrap: anywhere;
}

.controller-test-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(300px, 0.75fr);
  gap: 16px;
  align-items: start;
}

.controller-metric-table {
  min-width: 0;
  display: grid;
  gap: 8px;
}

.controller-metric-head,
.controller-metric-row {
  display: grid;
  grid-template-columns: 108px minmax(130px, 1fr) 132px 76px;
  gap: 10px;
  align-items: center;
}

.controller-metric-head {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.controller-metric-row {
  min-height: 38px;
  padding: 8px 10px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.04);
}

.controller-metric-row > span:first-child {
  color: #f4d46f;
  font-size: 13px;
  font-weight: 900;
}

.controller-metric-row strong,
.controller-metric-row em {
  min-width: 0;
  overflow-wrap: anywhere;
  text-align: right;
  font-size: 13px;
  font-style: normal;
  font-weight: 900;
}

.controller-metric-row strong {
  color: #e8eef9;
}

.controller-metric-row em {
  color: #9fb0c8;
}

.controller-meter {
  position: relative;
  height: 12px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04);
}

.controller-meter::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 50%;
  width: 1px;
  background: rgba(255, 255, 255, 0.26);
  transform: translateX(-0.5px);
}

.controller-meter-fill {
  position: absolute;
  inset: 0 auto 0 0;
  width: 0%;
  border-radius: inherit;
  background: linear-gradient(90deg, #2e7dff, #22d96f);
  transition: left 120ms ease, width 120ms ease;
}

.controller-meter[data-centered="true"] .controller-meter-fill {
  left: 50%;
  width: 0%;
  background: linear-gradient(90deg, #ffb347, #4f91ff);
}

.controller-side-stack {
  display: grid;
  gap: 12px;
  min-width: 0;
}

.controller-summary-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.controller-summary-grid div,
.controller-event-grid div,
.controller-light-grid div {
  min-width: 0;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.04);
}

.controller-summary-grid div {
  padding: 11px 12px;
}

.controller-summary-grid span,
.controller-event-grid span,
.controller-light-grid span {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.controller-summary-grid strong {
  display: block;
  margin-top: 6px;
  color: #ffffff;
  font-family: "Orbitron", "Barlow", sans-serif;
  font-size: 14px;
  letter-spacing: 0;
  overflow-wrap: anywhere;
}

.controller-event-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.controller-event-grid div {
  padding: 10px 11px;
  transition: border-color 140ms ease, background 140ms ease;
}

.controller-event-grid strong,
.controller-light-grid strong {
  display: block;
  margin-top: 5px;
  color: #9fb0c8;
  font-size: 12px;
  font-weight: 900;
  overflow-wrap: anywhere;
}

.controller-event-grid div[data-active="true"] {
  border-color: rgba(34, 217, 111, 0.34);
  background: rgba(34, 217, 111, 0.09);
}

.controller-event-grid div[data-active="true"] strong {
  color: #b8ffd5;
}

.controller-light-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 10px;
  margin-top: 16px;
}

.controller-light-grid div {
  padding: 9px 10px;
}

.controller-light-grid div[data-active="true"] {
  border-color: rgba(241, 201, 77, 0.38);
  background: rgba(241, 201, 77, 0.1);
}

.controller-light-grid div[data-active="true"] strong {
  color: #ffe68a;
}

.controller-test-note {
  margin-top: 14px;
}

.flash-controller-panel.controller-console {
  --controller-orange: #ff9e2b;
  --controller-orange-soft: rgba(255, 158, 43, 0.22);
  --controller-blueprint: #9fb3d8;
  --controller-card: rgba(8, 16, 26, 0.82);
  --controller-card-strong: rgba(11, 20, 31, 0.94);
  --speed-percent: 0%;
  --rpm-percent: 0%;
  position: relative;
  overflow: hidden;
  padding: 18px;
  border-radius: 8px;
  border-color: rgba(82, 104, 138, 0.34);
  background:
    linear-gradient(135deg, rgba(10, 21, 34, 0.96), rgba(5, 11, 19, 0.98) 62%, rgba(13, 17, 27, 0.96)),
    rgba(7, 11, 18, 0.98);
  box-shadow: 0 24px 72px rgba(0, 0, 0, 0.44), inset 0 0 0 1px rgba(255, 255, 255, 0.03);
}

.flash-controller-panel.controller-console::after {
  content: "";
  position: absolute;
  top: 10px;
  right: 22px;
  width: 520px;
  height: 86px;
  pointer-events: none;
  opacity: 0.34;
  background:
    linear-gradient(45deg, transparent 0 46%, rgba(255, 158, 43, 0.42) 47% 49%, transparent 50%) 0 0 / 26px 18px repeat-x,
    linear-gradient(180deg, transparent 0 28px, rgba(79, 145, 255, 0.22) 29px 30px, transparent 31px),
    linear-gradient(180deg, transparent 0 64px, rgba(255, 158, 43, 0.2) 65px 66px, transparent 67px);
  clip-path: polygon(12% 0, 100% 0, 100% 100%, 46% 100%, 38% 66%, 0 66%, 0 24%);
}

.controller-console > * {
  position: relative;
  z-index: 1;
}

.controller-console-header {
  margin-bottom: 16px;
  padding: 4px 4px 0;
}

.controller-title-cluster {
  min-width: 0;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 22px;
  align-items: center;
}

.controller-mode-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 104px;
  min-height: 44px;
  padding: 0 18px;
  border: 1px solid rgba(255, 158, 43, 0.7);
  border-radius: 8px;
  color: var(--controller-orange);
  background: rgba(255, 158, 43, 0.08);
  box-shadow: inset 0 0 18px rgba(255, 158, 43, 0.08);
  font-family: "Orbitron", "Barlow", sans-serif;
  font-size: 16px;
  font-weight: 900;
  letter-spacing: 0;
}

.controller-title-cluster h3 {
  margin: 0;
  color: #f3f7ff;
  text-shadow: 0 0 20px rgba(159, 179, 216, 0.2);
}

.controller-console .controller-profile-line {
  width: min(100%, 620px);
  margin: 6px 0 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  display: flex;
  flex-wrap: wrap;
  gap: 10px 16px;
}

.controller-console .controller-profile-line span {
  color: var(--controller-blueprint);
  font-size: 12px;
  letter-spacing: 0;
}

.controller-console .controller-profile-line strong {
  color: var(--controller-orange);
  font-size: 14px;
}

.controller-console .controller-test-actions {
  gap: 14px;
}

.controller-console .controller-status-pill {
  min-height: 46px;
  min-width: 210px;
  justify-content: center;
  gap: 10px;
  border-radius: 999px;
  font-size: 14px;
  letter-spacing: 0;
}

.controller-console .controller-status-pill::before {
  content: "";
  width: 11px;
  height: 11px;
  flex: 0 0 auto;
  border-radius: 50%;
  background: currentColor;
  box-shadow: 0 0 18px currentColor;
}

.controller-console .controller-status-pill[data-state="good"] {
  color: #5cff83;
  border-color: rgba(34, 217, 111, 0.62);
  background: rgba(34, 217, 111, 0.13);
}

.controller-console .controller-status-pill[data-state="busy"] {
  color: #9fd0ff;
  border-color: rgba(79, 145, 255, 0.58);
  background: rgba(79, 145, 255, 0.14);
}

.controller-console .controller-status-pill[data-state="warn"] {
  color: #ffd64d;
  border-color: rgba(255, 214, 77, 0.68);
  background: rgba(255, 214, 77, 0.11);
}

.controller-console .controller-status-pill[data-state="bad"] {
  color: #ff7488;
  border-color: rgba(255, 77, 103, 0.6);
}

.controller-stop-button {
  min-height: 46px;
  border-radius: 8px;
  border: 1px solid rgba(159, 179, 216, 0.22);
  background: linear-gradient(180deg, rgba(32, 42, 59, 0.88), rgba(15, 20, 31, 0.94));
  color: #f5f8ff;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.03);
}

.controller-stop-button::before {
  content: "↯";
  margin-right: 8px;
  color: #ff4d67;
  font-weight: 900;
}

.controller-dashboard-grid {
  display: grid;
  grid-template-columns: 1.05fr 1.18fr 0.94fr 0.88fr;
  gap: 10px;
  margin-bottom: 14px;
}

.controller-gauge-card,
.controller-console-section {
  min-width: 0;
  border: 1px solid rgba(159, 179, 216, 0.18);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(14, 29, 45, 0.86), rgba(8, 14, 22, 0.94)),
    var(--controller-card);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.025), inset 0 -2px 0 rgba(255, 158, 43, 0.2);
}

.controller-gauge-card {
  position: relative;
  min-height: 148px;
  padding: 22px 26px;
  overflow: hidden;
}

.controller-gauge-card::before,
.controller-console-section::before {
  content: "";
  position: absolute;
  inset: 0 auto auto 0;
  width: 72px;
  height: 2px;
  background: linear-gradient(90deg, var(--controller-orange), transparent);
}

.controller-card-label,
.controller-console-section h4 {
  margin: 0;
  color: var(--controller-blueprint);
  font-family: "Barlow Condensed", "Barlow", sans-serif;
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.controller-card-label::before {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  margin-right: 9px;
  border-radius: 2px;
  background: currentColor;
  box-shadow: 0 0 14px rgba(159, 179, 216, 0.44);
  transform: rotate(45deg);
}

.controller-speed-layout {
  display: grid;
  grid-template-columns: 84px minmax(150px, 1fr);
  gap: 16px;
  align-items: end;
  margin-top: 18px;
}

.controller-big-readout strong,
.controller-rpm-readout,
.controller-gear-card strong,
.controller-engine-card strong {
  color: #ffffff;
  font-family: "Orbitron", "Barlow", sans-serif;
  font-weight: 900;
  letter-spacing: 0;
  text-shadow: 0 0 16px rgba(255, 255, 255, 0.14);
}

.controller-big-readout strong {
  display: block;
  font-size: 48px;
  line-height: 0.95;
}

.controller-big-readout span {
  display: block;
  margin-top: 6px;
  color: var(--controller-blueprint);
  font-size: 16px;
  font-weight: 800;
}

.controller-rpm-readout {
  display: block;
  margin-top: 18px;
  font-size: 50px;
  line-height: 0.9;
}

.controller-speed-bar-block {
  min-width: 0;
  align-self: end;
}

.controller-speed-scale,
.controller-rpm-scale {
  position: relative;
  height: 20px;
  overflow: hidden;
  border: 1px solid rgba(159, 179, 216, 0.2);
  border-radius: 3px;
  background:
    repeating-linear-gradient(90deg, rgba(159, 179, 216, 0.18) 0 2px, transparent 2px 16px),
    rgba(29, 39, 58, 0.76);
}

.controller-speed-scale {
  margin: 0 0 8px;
}

.controller-rpm-scale {
  margin: 12px 0 8px 52px;
}

.controller-speed-fill,
.controller-rpm-fill {
  display: block;
  height: 100%;
  transition: width 160ms ease;
}

.controller-speed-fill {
  width: var(--speed-percent);
  background: linear-gradient(90deg, rgba(32, 209, 179, 0.85), #ff9e2b 72%, #ff3333);
  box-shadow: 0 0 14px rgba(255, 158, 43, 0.42);
}

.controller-rpm-fill {
  width: var(--rpm-percent);
  background: linear-gradient(90deg, rgba(46, 125, 255, 0.72), #ff9e2b 74%, #ff3333);
  box-shadow: 0 0 14px rgba(255, 83, 55, 0.42);
}

.controller-speed-ticks,
.controller-rpm-ticks {
  display: grid;
  grid-template-columns: repeat(7, auto);
  gap: 12px;
  align-items: center;
  justify-content: space-between;
  color: #c7d4ec;
  font-size: 13px;
  font-weight: 800;
}

.controller-rpm-ticks {
  grid-template-columns: repeat(8, auto);
}

.controller-gear-card,
.controller-engine-card {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.controller-gear-card strong,
.controller-engine-card strong {
  margin-top: 22px;
  color: var(--controller-orange);
  font-size: clamp(24px, 2.4vw, 34px);
  line-height: 1;
  overflow-wrap: anywhere;
}

.controller-test-grid {
  grid-template-columns: minmax(0, 1.12fr) minmax(360px, 0.88fr);
  gap: 10px;
}

.controller-console-section {
  position: relative;
  padding: 20px 14px 14px;
}

.controller-console-section h4 {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 16px 4px;
}

.controller-console-section h4 span {
  color: var(--controller-orange);
  font-size: 21px;
  line-height: 1;
}

.controller-console .controller-metric-head,
.controller-console .controller-metric-row {
  grid-template-columns: 126px minmax(170px, 1fr) 118px 76px;
  gap: 12px;
}

.controller-console .controller-metric-head {
  padding: 0 20px 4px;
  color: var(--controller-blueprint);
  font-size: 12px;
}

.controller-console .controller-metric-row {
  min-height: 46px;
  padding: 8px 20px;
  border-color: rgba(159, 179, 216, 0.14);
  background: linear-gradient(180deg, rgba(18, 28, 43, 0.8), rgba(10, 17, 27, 0.88));
}

.controller-console .controller-metric-row > span:first-child {
  color: var(--controller-orange);
  font-size: 16px;
}

.controller-console .controller-metric-row strong {
  color: #f3f7ff;
  font-size: 14px;
}

.controller-console .controller-metric-row em {
  color: #c9d7ee;
  font-size: 14px;
}

.controller-console .controller-meter {
  height: 18px;
  border-radius: 8px;
  background:
    repeating-linear-gradient(90deg, rgba(159, 179, 216, 0.18) 0 1px, transparent 1px 18px),
    rgba(39, 51, 73, 0.78);
}

.controller-console .controller-meter::before {
  width: 2px;
  background: var(--controller-orange);
  box-shadow: 0 0 10px rgba(255, 158, 43, 0.6);
}

.controller-console .controller-meter-fill {
  background: linear-gradient(90deg, #16d6a5, #26e6bd);
  box-shadow: 0 0 12px rgba(38, 230, 189, 0.35);
}

.controller-console .controller-meter[data-centered="true"] .controller-meter-fill {
  background: linear-gradient(90deg, #2e7dff, var(--controller-orange));
}

.controller-console .controller-side-stack {
  display: block;
}

.controller-console .controller-event-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.controller-console .controller-event-grid div,
.controller-console .controller-light-grid div {
  position: relative;
  min-height: 78px;
  padding: 16px 14px 14px 78px;
  border-color: rgba(159, 179, 216, 0.16);
  background: linear-gradient(145deg, rgba(18, 29, 45, 0.84), rgba(10, 15, 24, 0.92));
  transition: border-color 140ms ease, background 140ms ease, box-shadow 140ms ease;
}

.controller-console .controller-event-grid div::before,
.controller-console .controller-light-grid div::before {
  content: attr(data-card-icon);
  position: absolute;
  left: 16px;
  top: 50%;
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  color: #b5c6eb;
  background: rgba(159, 179, 216, 0.08);
  box-shadow: inset 0 0 0 1px rgba(159, 179, 216, 0.12);
  transform: translateY(-50%);
  font-family: "Orbitron", "Barlow", sans-serif;
  font-size: 15px;
  font-weight: 900;
  text-transform: uppercase;
}

.controller-console .controller-event-grid div[data-card-icon="throttle"]::before { content: "GA"; }
.controller-console .controller-event-grid div[data-card-icon="brake"]::before { content: "BR"; }
.controller-console .controller-event-grid div[data-card-icon="reverse"]::before { content: "R"; }
.controller-console .controller-event-grid div[data-card-icon="horn"]::before { content: "CO"; }
.controller-console .controller-event-grid div[data-card-icon="indicator"]::before { content: "XI"; }
.controller-console .controller-event-grid div[data-card-icon="lights"]::before { content: "Đ"; }
.controller-console .controller-event-grid div[data-card-icon="siren"]::before { content: "ƯT"; }
.controller-console .controller-event-grid div[data-card-icon="engine"]::before { content: "EN"; }

.controller-console .controller-event-grid div[data-card-icon]::before,
.controller-console .controller-light-grid div[data-light-icon]::before {
  content: "";
  color: #b5c6eb;
  background: currentColor;
  mask: var(--controller-icon) center / 25px 25px no-repeat;
  -webkit-mask: var(--controller-icon) center / 25px 25px no-repeat;
}

.controller-console .controller-event-grid div[data-card-icon="throttle"] { --controller-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M15 3h3l-2 7 3 2-4 9H9l2-8-4-2 2-4h4l2-4Z'/%3E%3C/svg%3E"); }
.controller-console .controller-event-grid div[data-card-icon="brake"] { --controller-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M12 3a9 9 0 1 0 0 18v-3a6 6 0 1 1 0-12V3Zm0 4h2v7h-2V7Zm0 9h2v2h-2v-2Zm4-8 4-3v14l-4-3V8Z'/%3E%3C/svg%3E"); }
.controller-console .controller-event-grid div[data-card-icon="reverse"] { --controller-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M8 5h10v4h-8v3h5l-7 7-7-7h5V7a2 2 0 0 1 2-2Z'/%3E%3C/svg%3E"); }
.controller-console .controller-event-grid div[data-card-icon="horn"] { --controller-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M3 10h4l7-4v12l-7-4H3v-4Zm13-2c2 1 3 2 3 4s-1 3-3 4v-3c.6-.4 1-.7 1-1s-.4-.8-1-1V8Zm3-3c3 2 5 4 5 7s-2 5-5 7v-3c1.4-1.2 2-2.4 2-4s-.6-2.8-2-4V5Z'/%3E%3C/svg%3E"); }
.controller-console .controller-event-grid div[data-card-icon="indicator"] { --controller-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='m7 5 7 7-7 7v-5H1v-4h6V5Zm10 0v5h6v4h-6v5l-7-7 7-7Z'/%3E%3C/svg%3E"); }
.controller-console .controller-event-grid div[data-card-icon="lights"] { --controller-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M11 3a7 7 0 0 1 4 12.7V19H7v-3.3A7 7 0 0 1 11 3Zm-4 18h8v2H7v-2Zm11-13h5v2h-5V8Zm0 4h5v2h-5v-2Zm0 4h5v2h-5v-2Z'/%3E%3C/svg%3E"); }
.controller-console .controller-event-grid div[data-card-icon="siren"] { --controller-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M8 4h8l2 10H6L8 4Zm-3 12h14v4H5v-4Zm-4-7h4v3H1V9Zm18 0h4v3h-4V9ZM4 2l3 3-2 2-3-3 2-2Zm16 0 2 2-3 3-2-2 3-3Z'/%3E%3C/svg%3E"); }
.controller-console .controller-event-grid div[data-card-icon="engine"] { --controller-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M8 5h6v3h3l3 3v6h-3l-2 3H8l-2-3H3v-6h3V8h2V5Zm2 3v3H8v5h2l1 2h3l1-2h2v-4l-1-1h-4V8h-2Z'/%3E%3C/svg%3E"); }

.controller-console .controller-event-grid span,
.controller-console .controller-light-grid span {
  color: var(--controller-blueprint);
  font-size: 14px;
  letter-spacing: 0;
}

.controller-console .controller-event-grid strong,
.controller-console .controller-light-grid strong {
  margin-top: 3px;
  color: #9fb0c8;
  font-size: 15px;
  line-height: 1.15;
}

.controller-console .controller-event-grid div[data-active="true"],
.controller-console .controller-light-grid div[data-active="true"] {
  border-color: rgba(255, 158, 43, 0.56);
  background: linear-gradient(145deg, rgba(48, 35, 18, 0.9), rgba(16, 21, 30, 0.94));
  box-shadow: 0 0 0 1px rgba(255, 158, 43, 0.08), inset 0 -2px 0 rgba(255, 158, 43, 0.34);
}

.controller-console .controller-event-grid div[data-active="true"]::before,
.controller-console .controller-light-grid div[data-active="true"]::before {
  color: #14171d;
  background: var(--controller-orange);
  box-shadow: 0 0 18px rgba(255, 158, 43, 0.48);
}

.controller-console .controller-event-grid div[data-active="true"] strong,
.controller-console .controller-light-grid div[data-active="true"] strong {
  color: #ffd899;
}

.controller-lights-panel {
  margin-top: 14px;
}

.controller-console .controller-light-grid {
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 10px;
  margin-top: 0;
}

.controller-console .controller-light-grid div {
  min-height: 74px;
  padding-left: 72px;
}

.controller-console .controller-light-grid div::before {
  content: attr(data-light-icon);
}

.controller-console .controller-light-grid div[data-light-icon="headlight"]::before { content: "PHA"; }
.controller-console .controller-light-grid div[data-light-icon="taillight"]::before { content: "HẬU"; }
.controller-console .controller-light-grid div[data-light-icon="left"]::before { content: "←"; }
.controller-console .controller-light-grid div[data-light-icon="right"]::before { content: "→"; }
.controller-console .controller-light-grid div[data-light-icon="fog"]::before { content: "SM"; }
.controller-console .controller-light-grid div[data-light-icon="reverse"]::before { content: "R"; }
.controller-console .controller-light-grid div[data-light-icon="roof"]::before { content: "NÓC"; }
.controller-console .controller-light-grid div[data-light-icon="side"]::before { content: "HÔ"; }
.controller-console .controller-light-grid div[data-light-icon="beacon"]::before { content: "BC"; }
.controller-console .controller-light-grid div[data-light-icon="cabin"]::before { content: "CAB"; }
.controller-console .controller-light-grid div[data-light-icon="brake"]::before { content: "BR"; }

.controller-console .controller-light-grid div[data-light-icon="headlight"],
.controller-console .controller-light-grid div[data-light-icon="fog"] { --controller-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M4 7h8c4 0 7 2 7 5s-3 5-7 5H4V7Zm15 0h4v2h-4V7Zm0 4h4v2h-4v-2Zm0 4h4v2h-4v-2Z'/%3E%3C/svg%3E"); }
.controller-console .controller-light-grid div[data-light-icon="taillight"],
.controller-console .controller-light-grid div[data-light-icon="side"] { --controller-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M4 6h10a5 5 0 0 1 0 10H4V6Zm14 1h4v2h-4V7Zm0 4h4v2h-4v-2Zm0 4h4v2h-4v-2Z'/%3E%3C/svg%3E"); }
.controller-console .controller-light-grid div[data-light-icon="left"] { --controller-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M10 5 1 12l9 7v-5h13v-4H10V5Z'/%3E%3C/svg%3E"); }
.controller-console .controller-light-grid div[data-light-icon="right"] { --controller-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='m14 5 9 7-9 7v-5H1v-4h13V5Z'/%3E%3C/svg%3E"); }
.controller-console .controller-light-grid div[data-light-icon="reverse"] { --controller-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M7 5h10v4H9v3h5l-7 7-7-7h5V7a2 2 0 0 1 2-2Z'/%3E%3C/svg%3E"); }
.controller-console .controller-light-grid div[data-light-icon="roof"],
.controller-console .controller-light-grid div[data-light-icon="beacon"],
.controller-console .controller-light-grid div[data-light-icon="cabin"] { --controller-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M8 4h8l2 9H6l2-9Zm-3 11h14v5H5v-5ZM3 7h3v3H3V7Zm15 0h3v3h-3V7ZM11 1h2v3h-2V1Z'/%3E%3C/svg%3E"); }
.controller-console .controller-light-grid div[data-light-icon="brake"] { --controller-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M12 3a9 9 0 1 0 0 18v-3a6 6 0 1 1 0-12V3Zm0 4h2v7h-2V7Zm0 9h2v2h-2v-2Zm4-8 4-3v14l-4-3V8Z'/%3E%3C/svg%3E"); }

.controller-console .controller-light-grid div[data-light-icon]::before {
  content: "";
}

.controller-console .controller-test-note {
  margin-top: 10px;
  padding: 10px 14px;
  border: 1px solid rgba(159, 179, 216, 0.14);
  border-radius: 8px;
  background: rgba(159, 179, 216, 0.05);
}

.flash-badge {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 999px;
  color: #dfe7f8;
  background: rgba(255, 255, 255, 0.05);
  font-size: 13px;
  font-weight: 800;
  white-space: nowrap;
}

.flash-badge[data-state="good"] {
  border-color: rgba(34, 217, 111, 0.46);
  color: #b8ffd5;
  background: rgba(34, 217, 111, 0.1);
}

.flash-badge[data-state="warn"] {
  border-color: rgba(255, 194, 50, 0.42);
  color: #ffe5a0;
  background: rgba(255, 194, 50, 0.1);
}

.flash-state-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin: 18px 0;
}

.flash-state-item {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  min-width: 0;
  padding: 12px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.04);
  transition: border-color 180ms ease, background 180ms ease, box-shadow 180ms ease, transform 180ms ease;
}

.flash-state-dot {
  position: relative;
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: rgba(127, 138, 160, 0.2);
  color: #dfe8fb;
  box-shadow: 0 0 0 5px rgba(127, 138, 160, 0.08);
  font-size: 10px;
  font-weight: 950;
  letter-spacing: 0;
}

.flash-state-dot::before {
  content: "•";
}

.flash-state-item[data-step="connect"] .flash-state-dot::before {
  content: "COM";
  font-size: 8px;
}

.flash-state-item[data-step="verify"] .flash-state-dot::before {
  content: "✓";
  font-size: 15px;
}

.flash-state-item[data-step="flash"] .flash-state-dot::before {
  content: "FW";
  font-size: 9px;
}

.flash-state-item strong {
  display: block;
  color: #ffffff;
  font-size: 14px;
  font-weight: 900;
}

.flash-state-item small {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
  line-height: 1.42;
}

.flash-state-item[data-state="busy"] {
  border-color: rgba(46, 125, 255, 0.35);
  background: rgba(46, 125, 255, 0.1);
  box-shadow: 0 0 0 1px rgba(46, 125, 255, 0.08), 0 12px 28px rgba(46, 125, 255, 0.1);
}

.flash-state-item[data-step="flash"][data-state="busy"] {
  animation: flashBreathPanel 1700ms ease-in-out infinite;
}

.flash-state-item[data-state="busy"] .flash-state-dot {
  background: #4f91ff;
  box-shadow: 0 0 0 6px rgba(79, 145, 255, 0.15);
  animation: flashStateFloat 1100ms ease-in-out infinite;
}

.flash-state-item[data-state="busy"] .flash-state-dot::after {
  content: "";
  position: absolute;
  inset: -5px;
  border-radius: 50%;
  border: 2px solid rgba(79, 145, 255, 0.18);
  border-top-color: #b8d4ff;
  animation: flashStateSpin 800ms linear infinite;
}

.flash-state-item[data-state="good"] {
  border-color: rgba(34, 217, 111, 0.34);
  background: rgba(34, 217, 111, 0.09);
  box-shadow: 0 0 0 1px rgba(34, 217, 111, 0.08), 0 12px 28px rgba(34, 217, 111, 0.08);
}

.flash-state-item[data-state="good"] .flash-state-dot {
  background: #22d96f;
  box-shadow: 0 0 0 6px rgba(34, 217, 111, 0.13);
}

.flash-state-item[data-state="warn"] {
  border-color: rgba(255, 216, 77, 0.42);
  background: rgba(255, 216, 77, 0.1);
  box-shadow: 0 0 0 1px rgba(255, 216, 77, 0.08), 0 12px 28px rgba(255, 216, 77, 0.08);
}

.flash-state-item[data-state="warn"] .flash-state-dot {
  background: #ffd84d;
  box-shadow: 0 0 0 6px rgba(255, 216, 77, 0.15);
}

.flash-state-item[data-state="bad"] {
  border-color: rgba(255, 77, 103, 0.4);
  background: rgba(255, 77, 103, 0.1);
  box-shadow: 0 0 0 1px rgba(255, 77, 103, 0.08), 0 12px 28px rgba(255, 77, 103, 0.08);
}

.flash-state-item[data-state="bad"] .flash-state-dot {
  background: #ff4d67;
  box-shadow: 0 0 0 6px rgba(255, 77, 103, 0.13);
}

.flash-controls-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin: 18px 0;
}

.flash-action-row {
  margin-top: 14px;
}

.flash-live-notice {
  display: grid;
  grid-template-columns: 26px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  margin: 16px 0 0;
  padding: 13px 14px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.05);
}

.flash-live-notice[hidden] {
  display: none;
}

.flash-live-notice strong {
  display: block;
  color: #ffffff;
  font-size: 14px;
  font-weight: 900;
  letter-spacing: 0;
}

.flash-live-notice small {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
  line-height: 1.35;
}

.flash-live-dot {
  position: relative;
  width: 24px;
  height: 24px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: #d7dfef;
  box-shadow: 0 0 0 6px rgba(215, 223, 239, 0.1);
  color: #0d111b;
  font-size: 12px;
  font-weight: 950;
}

.flash-live-dot::before {
  content: "i";
}

.flash-live-notice[data-state="busy"] {
  border-color: rgba(46, 125, 255, 0.42);
  background: rgba(46, 125, 255, 0.12);
}

.flash-live-notice[data-phase="build"][data-state="busy"] {
  animation: flashBreathPanel 1700ms ease-in-out infinite;
}

.flash-live-notice[data-state="busy"] .flash-live-dot {
  background: #4f91ff;
  box-shadow: 0 0 0 6px rgba(79, 145, 255, 0.16);
  animation: flashLivePulse 950ms ease-in-out infinite;
}

.flash-live-notice[data-state="busy"] .flash-live-dot::before {
  content: "...";
  transform: translateY(-1px);
}

.flash-live-notice[data-state="good"] {
  border-color: rgba(34, 217, 111, 0.38);
  background: rgba(34, 217, 111, 0.11);
}

.flash-live-notice[data-state="good"] .flash-live-dot {
  background: #22d96f;
  box-shadow: 0 0 0 6px rgba(34, 217, 111, 0.14);
}

.flash-live-notice[data-state="good"] .flash-live-dot::before {
  content: "✓";
}

.flash-live-notice[data-state="warn"] {
  border-color: rgba(255, 216, 77, 0.46);
  background: rgba(255, 216, 77, 0.11);
}

.flash-live-notice[data-state="warn"] .flash-live-dot {
  background: #ffd84d;
  box-shadow: 0 0 0 6px rgba(255, 216, 77, 0.16);
  animation: flashLivePulse 1200ms ease-in-out infinite;
}

.flash-live-notice[data-state="warn"] .flash-live-dot::before {
  content: "!";
}

.flash-live-notice[data-state="bad"] {
  border-color: rgba(255, 77, 103, 0.42);
  background: rgba(255, 77, 103, 0.11);
}

.flash-live-notice[data-state="bad"] .flash-live-dot {
  background: #ff4d67;
  box-shadow: 0 0 0 6px rgba(255, 77, 103, 0.14);
}

.flash-live-notice[data-state="bad"] .flash-live-dot::before {
  content: "×";
}

.flash-toast {
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 240;
  width: min(380px, calc(100vw - 32px));
  padding: 14px 14px 12px;
  border: 1px solid rgba(159, 179, 216, 0.24);
  border-radius: 8px;
  background: rgba(10, 14, 24, 0.94);
  box-shadow: 0 22px 70px rgba(0, 0, 0, 0.42);
  backdrop-filter: blur(16px);
  animation: flashToastIn 180ms ease-out;
}

.flash-toast[hidden] {
  display: none;
}

.flash-toast-body {
  display: grid;
  grid-template-columns: 32px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  padding-right: 30px;
}

.flash-toast-icon {
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  color: #07111d;
  background: #d7dfef;
  box-shadow: 0 0 0 6px rgba(215, 223, 239, 0.1);
  font-size: 14px;
  font-weight: 950;
}

.flash-toast-icon::before {
  content: "i";
}

.flash-toast-copy strong {
  display: block;
  color: #ffffff;
  font-size: 14px;
  font-weight: 950;
  letter-spacing: 0;
}

.flash-toast-copy small {
  display: block;
  margin-top: 4px;
  color: #b9c6dc;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.35;
}

.flash-toast-close {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 7px;
  color: #dfe8fb;
  background: rgba(255, 255, 255, 0.05);
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
}

.flash-toast-progress {
  height: 8px;
  margin-top: 12px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.1);
}

.flash-toast-progress span {
  display: block;
  width: 0%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #2e7dff, #22d96f);
  transition: width 180ms ease;
}

.flash-toast-percent {
  margin-top: 6px;
  color: #dfe8fb;
  font-size: 12px;
  font-weight: 950;
  text-align: right;
}

.flash-toast[data-state="busy"] {
  border-color: rgba(46, 125, 255, 0.42);
}

.flash-toast[data-state="busy"] .flash-toast-icon {
  background: #4f91ff;
  box-shadow: 0 0 0 6px rgba(79, 145, 255, 0.16);
  animation: flashLivePulse 950ms ease-in-out infinite;
}

.flash-toast[data-state="busy"] .flash-toast-icon::before {
  content: "...";
  transform: translateY(-1px);
}

.flash-toast[data-state="good"] {
  border-color: rgba(34, 217, 111, 0.42);
}

.flash-toast[data-state="good"] .flash-toast-icon {
  background: #22d96f;
  box-shadow: 0 0 0 6px rgba(34, 217, 111, 0.14);
}

.flash-toast[data-state="good"] .flash-toast-icon::before {
  content: "✓";
}

.flash-toast[data-state="warn"] {
  border-color: rgba(255, 216, 77, 0.48);
}

.flash-toast[data-state="warn"] .flash-toast-icon {
  background: #ffd84d;
  box-shadow: 0 0 0 6px rgba(255, 216, 77, 0.16);
}

.flash-toast[data-state="warn"] .flash-toast-icon::before {
  content: "!";
}

.flash-toast[data-state="bad"] {
  border-color: rgba(255, 77, 103, 0.46);
}

.flash-toast[data-state="bad"] .flash-toast-icon {
  background: #ff4d67;
  box-shadow: 0 0 0 6px rgba(255, 77, 103, 0.14);
}

.flash-toast[data-state="bad"] .flash-toast-icon::before {
  content: "×";
}

@keyframes flashToastIn {
  from {
    opacity: 0;
    transform: translate3d(0, 12px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes flashLivePulse {
  0%,
  100% {
    transform: scale(0.88);
    opacity: 0.72;
  }
  50% {
    transform: scale(1.12);
    opacity: 1;
  }
}

@keyframes flashStateFloat {
  0%,
  100% {
    transform: translateY(0) scale(1);
  }
  50% {
    transform: translateY(-1px) scale(1.06);
  }
}

@keyframes flashStateSpin {
  to {
    transform: rotate(360deg);
  }
}

@keyframes flashBreathPanel {
  0%,
  100% {
    transform: scale(1);
    box-shadow: 0 0 0 1px rgba(46, 125, 255, 0.1), 0 10px 24px rgba(46, 125, 255, 0.08);
  }
  50% {
    transform: scale(1.015);
    box-shadow: 0 0 0 1px rgba(46, 125, 255, 0.22), 0 16px 34px rgba(46, 125, 255, 0.18);
  }
}

@keyframes flashBreathText {
  0%,
  100% {
    opacity: 0.72;
  }
  50% {
    opacity: 1;
  }
}

.flash-progress-shell {
  height: 10px;
  margin: 22px 0 14px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
}

.flash-progress-shell span {
  display: block;
  width: 0%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #2e7dff, #22d96f);
  transition: width 180ms ease;
}

.flash-progress-text {
  margin-top: -7px;
  color: #dfe8fb;
  font-size: 13px;
  font-weight: 900;
  text-align: right;
}

.flash-build-timer {
  margin-top: 6px;
  color: #d8e3ff;
  font-size: 13px;
  font-weight: 900;
  text-align: right;
}

.flash-build-timer[hidden] {
  display: none;
}

.flash-build-timer[data-state="warn"] {
  color: #ffe68a;
}

.flash-build-timer[data-state="busy"] {
  animation: flashBreathText 1350ms ease-in-out infinite;
}

.flash-build-timer[data-state="good"] {
  color: #b8ffd5;
}

.flash-build-timer[data-state="bad"] {
  color: #ffb8c2;
}

#flashStatusText[data-state="good"] {
  color: #b8ffd5;
}

#flashStatusText[data-state="bad"] {
  color: #ffb8c2;
}

#flashStatusText[data-state="busy"] {
  color: #d8e3ff;
}

#flashStatusText[data-state="warn"] {
  color: #ffe68a;
}

.flash-info-list {
  display: grid;
  gap: 12px;
  margin-top: 18px;
}

.flash-info-list div {
  display: grid;
  grid-template-columns: 118px minmax(0, 1fr);
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.flash-info-list span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
}

.flash-info-list strong {
  min-width: 0;
  overflow-wrap: anywhere;
  color: #ffffff;
  font-family: "Orbitron", "Barlow", sans-serif;
  font-size: 14px;
  letter-spacing: 0;
}

@media (max-width: 1180px) {
  .hero-layout,
  .section-heading,
  .product-story-layout,
  .product-detail-hero,
  .product-use-layout,
  .listen-layout,
  .toy-shop-layout,
  .flash-layout,
  .platform-grid {
    grid-template-columns: 1fr;
  }

  .listen-panel-header,
  .flash-manual-header,
  .controller-test-header,
  .controller-test-grid,
  .toy-market-toolbar {
    grid-template-columns: 1fr;
  }

  .flash-sidebar {
    position: static;
  }

  .preset-block {
    justify-items: stretch;
  }

  .controller-test-actions {
    justify-content: flex-start;
  }

  .controller-light-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .product-gallery-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  .site-shell {
    padding-bottom: 86px;
  }

  .flash-toast {
    right: 14px;
    bottom: 96px;
    width: calc(100vw - 28px);
  }

  .topbar {
    position: sticky;
    top: 0;
  }

  .topbar-inner {
    width: min(var(--max-width), calc(100vw - 16px));
    min-height: auto;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 8px 10px;
    padding: 9px 0 8px;
  }

  .brand-mark {
    width: auto;
    text-align: left;
    font-size: 22px;
    letter-spacing: 1.2px;
    gap: 8px;
  }

  .brand-logo {
    width: 38px;
    height: 38px;
  }

  .shop-cta {
    min-height: 42px;
    padding: 0 18px;
    border-radius: 16px;
    font-size: 15px;
  }

  .topnav {
    grid-column: 1 / -1;
    justify-content: flex-start;
    flex-wrap: nowrap;
    gap: 6px;
    overflow-x: auto;
    padding: 0 0 2px;
    -ms-overflow-style: none;
    scrollbar-width: none;
  }

  .topnav::-webkit-scrollbar {
    display: none;
  }

  .topnav a {
    flex: 0 0 auto;
    min-height: 34px;
    padding: 0 10px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
    font-size: 14px;
    line-height: 1;
    white-space: nowrap;
  }

  .floating-cta {
    left: 10px;
    right: 10px;
    bottom: 10px;
    grid-template-columns: 1fr 1fr;
    border-radius: 22px;
  }

  .floating-cta-button {
    min-height: 48px;
    padding: 0 12px;
    border-radius: 16px;
    font-size: 15px;
  }

  .flash-state-list,
  .flash-controls-grid,
  .sound-card-grid {
    grid-template-columns: 1fr;
  }

  .flash-info-list div {
    grid-template-columns: 1fr;
    gap: 4px;
  }

  .receipt-modal {
    padding: 10px;
  }

  .receipt-dialog {
    width: calc(100vw - 16px);
    max-height: calc(100vh - 16px);
    border-radius: 20px;
  }

  .receipt-toolbar,
  .receipt-actions {
    padding: 12px;
  }

  .receipt-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .receipt-scroll {
    padding: 10px;
  }

  .order-receipt {
    padding: 22px 18px 18px;
  }

  .receipt-head {
    display: grid;
  }

  .receipt-hero-art {
    display: none;
  }

  .receipt-brand img {
    width: 250px;
    max-width: 100%;
  }

  .order-receipt h3 {
    margin-top: 22px;
    font-size: 30px;
  }

  .order-receipt h1 {
    font-size: 34px;
  }

  .receipt-meta,
  .receipt-sound-grid {
    grid-template-columns: 1fr;
  }

  .receipt-address-line {
    display: grid;
  }

  .receipt-address-line strong {
    text-align: left;
  }

  .receipt-meta div + div {
    border-left: 0;
    border-top: 1px solid #d4d4d4;
  }

  .receipt-section-title span {
    width: 54px;
    height: 48px;
    font-size: 30px;
  }

  .receipt-section-title strong {
    min-height: 40px;
    padding: 0 14px;
    font-size: 19px;
  }

  .receipt-list,
  .receipt-sound-grid {
    padding: 30px 12px 12px;
  }

  .receipt-row,
  .receipt-sound-row {
    font-size: 17px;
  }

  .receipt-total-row span {
    font-size: 19px;
  }

  .receipt-total-row strong {
    font-size: 30px;
  }

  main {
    width: min(var(--max-width), calc(100vw - 18px));
    padding-top: 14px;
  }

  .hero-panel,
  .surface-card,
  .platform-card {
    border-radius: 22px;
  }

  .hero-panel {
    padding: 20px 18px 24px;
  }

  .release-pill {
    padding: 8px 14px;
    font-size: 12px;
  }

  .hero-layout {
    margin-top: 18px;
    gap: 18px;
  }

  .hero-copy h1 {
    font-size: clamp(42px, 13vw, 74px);
    line-height: 0.98;
  }

  .hero-text {
    margin-top: 14px;
    font-size: 16px;
    line-height: 1.5;
  }

  .hero-stage {
    padding: 18px;
    border-radius: 22px;
  }

  .hero-stage-title {
    font-size: 32px;
  }

  .hero-meta {
    margin-top: 14px;
    font-size: 13px;
  }

  .product-story-section {
    margin-top: 24px;
  }

  .product-gallery-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .product-detail-grid {
    grid-template-columns: 1fr;
  }

  .product-image-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .product-media-main img {
    min-height: 0;
  }

  .product-story-points {
    gap: 10px;
  }

  .hero-actions,
  .toolbar-actions,
  .platform-actions,
  .action-row {
    grid-template-columns: 1fr;
  }

  .hero-actions,
  .toolbar-actions {
    display: grid;
  }

  .products-section,
  .listen-section,
  .toy-section,
  .flash-section,
  .platform-section {
    margin-top: 42px;
  }

  .section-heading {
    gap: 12px;
    margin-bottom: 16px;
  }

  .section-heading h2 {
    max-width: none;
    font-size: clamp(30px, 10vw, 44px);
    line-height: 0.96;
  }

  .section-copy {
    padding-top: 0;
    font-size: 15px;
    line-height: 1.55;
  }

  .listen-layout,
  .toy-shop-layout {
    gap: 16px;
  }

  .listen-panel,
  .flash-sound-panel,
  .flash-controller-panel,
  .flash-panel,
  .toy-market-panel,
  .side-card {
    padding: 18px;
  }

  .listen-panel-header {
    gap: 14px;
    margin-bottom: 16px;
  }

  .flash-manual-header {
    gap: 14px;
    margin-bottom: 16px;
  }

  .listen-panel-header h3,
  .flash-manual-header h3,
  .controller-test-header h3,
  .toy-market-toolbar h3,
  .section-head-compact h3,
  .platform-card h3 {
    font-size: 24px;
  }

  .controller-profile-line,
  .controller-metric-head,
  .controller-metric-row {
    grid-template-columns: 1fr;
  }

  .controller-metric-head {
    display: none;
  }

  .controller-metric-row strong,
  .controller-metric-row em {
    text-align: left;
  }

  .controller-summary-grid,
  .controller-event-grid,
  .controller-light-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .preset-block {
    gap: 8px;
  }

  .preset-counter {
    padding: 9px 14px;
    font-size: 13px;
  }

  .sound-rows {
    gap: 10px;
  }

  .sound-row {
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 14px;
    border-radius: 18px;
  }

  .sound-label-title {
    font-size: 18px;
  }

  .sound-label-subtitle {
    font-size: 12px;
  }

  .sound-select,
  .preview-button,
  .mode-chip,
  select,
  input {
    min-height: 48px;
  }

  textarea {
    min-height: 128px;
  }

  .segmented-control {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .price-list {
    gap: 10px;
  }

  .price-item,
  .price-option,
  .price-summary-line,
  .price-total,
  .price-deposit {
    padding: 11px 12px;
    border-radius: 16px;
  }

  .price-total strong {
    font-size: 22px;
  }

  .field {
    gap: 6px;
  }

  .field span,
  .small-note,
  .panel-note {
    font-size: 13px;
  }

  .action-row {
    gap: 8px;
  }

  .contact-list {
    gap: 6px;
    margin-bottom: 14px;
  }

  .platform-meta {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px 12px;
    padding: 14px;
  }
}

@media (max-width: 560px) {
  #home,
  #products,
  #listen,
  #pricing,
  #order,
  #toy-clearance,
  #downloads,
  #contact {
    scroll-margin-top: 124px;
  }

  .topbar-inner {
    width: calc(100vw - 14px);
    padding-top: 10px;
    gap: 8px 10px;
  }

  .brand-mark {
    font-size: 20px;
    letter-spacing: 1px;
    gap: 8px;
  }

  .brand-logo {
    width: 36px;
    height: 36px;
  }

  .topnav {
    gap: 6px;
  }

  .topnav a {
    min-height: 32px;
    padding: 0 9px;
    font-size: 13px;
  }

  .shop-cta {
    min-height: 38px;
    padding: 0 14px;
    font-size: 14px;
  }

  main {
    width: calc(100vw - 12px);
    padding-top: 10px;
  }

  .hero-section {
    padding-top: 6px;
  }

  .hero-panel {
    padding: 16px 14px 18px;
  }

  .hero-copy h1 {
    font-size: 36px;
    letter-spacing: 0.4px;
  }

  .hero-text {
    font-size: 14px;
    margin-top: 10px;
  }

  .hero-actions {
    gap: 10px;
    margin-top: 18px;
  }

  .primary-button,
  .ghost-button,
  .accent-button,
  .secondary-button,
  .platform-button {
    min-height: 46px;
    padding: 0 16px;
    border-radius: 16px;
    font-size: 15px;
  }

  .hero-stage {
    display: none;
  }

  .product-story-heading {
    margin-bottom: 14px;
  }

  .product-story-layout {
    gap: 12px;
  }

  .product-gallery-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .product-story-points article {
    padding: 14px;
  }

  .product-story-points strong {
    font-size: 19px;
  }

  .product-story-points p {
    font-size: 14px;
  }

  .product-card-caption {
    position: static;
    margin: 0;
    border-radius: 0;
  }

  .product-list-grid {
    grid-template-columns: 1fr;
  }

  .product-catalog-card {
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 14px;
  }

  .product-catalog-media img {
    min-height: 0;
  }

  .product-catalog-body h3 {
    font-size: 27px;
  }

  .product-detail-panel {
    padding: 16px 14px;
    scroll-margin-top: 124px;
  }

  .product-detail-copy h2 {
    max-width: none;
    font-size: 34px;
  }

  .product-detail-lead {
    font-size: 15px;
  }

  .product-detail-grid,
  .product-image-strip {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .product-detail-card {
    grid-template-columns: 96px minmax(0, 1fr);
    padding: 12px;
  }

  .product-detail-card h3,
  .product-use-copy h3 {
    font-size: 22px;
  }

  .product-detail-card p {
    font-size: 14px;
  }

  .product-use-copy {
    padding: 14px;
  }

  .section-heading h2 {
    font-size: 28px;
  }

  .listen-panel,
  .flash-sound-panel,
  .flash-controller-panel,
  .flash-panel,
  .toy-market-panel,
  .side-card,
  .platform-card {
    padding: 16px 14px;
  }

  .platform-card p {
    font-size: 14px;
  }

  .listen-panel-header h3,
  .flash-manual-header h3,
  .controller-test-header h3,
  .toy-market-toolbar h3,
  .section-head-compact h3,
  .platform-card h3 {
    font-size: 22px;
  }

  .controller-test-actions,
  .controller-summary-grid,
  .controller-event-grid,
  .controller-light-grid {
    grid-template-columns: 1fr;
  }

  .controller-test-actions {
    display: grid;
    justify-content: stretch;
  }

  .controller-status-pill {
    max-width: none;
    justify-content: center;
  }

  .sound-row {
    padding: 12px;
  }

  .sound-label-title {
    font-size: 17px;
  }

  .sound-select,
  .preview-button,
  .mode-chip,
  select,
  input,
  textarea {
    border-radius: 16px;
  }

  .price-item,
  .price-option,
  .price-summary-line,
  .price-total,
  .price-deposit,
  .platform-meta {
    border-radius: 16px;
  }

  .price-total strong {
    font-size: 20px;
  }

  .platform-icon {
    width: 64px;
    height: 64px;
    border-radius: 20px;
    font-size: 16px;
  }

  .platform-meta {
    grid-template-columns: 1fr;
  }

  .toy-product-grid {
    grid-template-columns: 1fr;
  }

  .toy-market-toolbar {
    gap: 12px;
  }

  .toy-cart-actions {
    grid-template-columns: 1fr;
  }

  .toy-product-footer {
    grid-template-columns: 1fr;
  }

  .toy-add-button {
    width: 100%;
  }

  .receipt-toolbar h2 {
    font-size: 18px;
  }

  .receipt-close-button {
    width: 40px;
    height: 40px;
  }

  .order-receipt {
    padding: 18px 12px 14px;
  }

  .receipt-brand img {
    width: 210px;
  }

  .order-receipt h3 {
    font-size: 25px;
  }

  .order-receipt h1 {
    font-size: 28px;
  }

  .receipt-row,
  .receipt-sound-row {
    align-items: flex-start;
    gap: 8px;
    font-size: 15px;
  }

  .receipt-row strong,
  .receipt-sound-row strong {
    max-width: 54%;
  }

  .receipt-total-row {
    display: grid;
    justify-items: stretch;
  }

  .receipt-total-row strong {
    max-width: none;
    text-align: left;
    font-size: 28px;
  }
}

@media (max-width: 1180px) {
  .controller-dashboard-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .controller-console .controller-test-grid {
    grid-template-columns: 1fr;
  }

  .controller-console .controller-light-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  .flash-controller-panel.controller-console {
    padding: 14px;
  }

  .controller-title-cluster {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .controller-mode-badge {
    justify-self: start;
    min-height: 40px;
  }

  .controller-dashboard-grid,
  .controller-console .controller-event-grid,
  .controller-console .controller-light-grid {
    grid-template-columns: 1fr;
  }

  .controller-gauge-card {
    min-height: auto;
    padding: 18px;
  }

  .controller-speed-layout {
    grid-template-columns: 84px minmax(120px, 1fr);
  }

  .controller-console .controller-metric-row {
    grid-template-columns: 1fr;
    gap: 8px;
    align-items: start;
  }

  .controller-console .controller-metric-row strong,
  .controller-console .controller-metric-row em {
    text-align: left;
  }

  .controller-console .controller-metric-head {
    display: none;
  }
}

@media (max-width: 520px) {
  .section-heading h2 {
    max-width: 100%;
    font-size: 24px;
    line-height: 1.02;
    text-wrap: wrap;
    word-break: break-word;
  }

  .flash-subtabs {
    grid-template-columns: 1fr;
  }

  .product-subtabs {
    grid-template-columns: 1fr;
  }

  .flash-subtab {
    min-height: 42px;
    padding: 0 12px;
    font-size: 13px;
  }

  .product-subtab {
    min-height: 42px;
    padding: 0 12px;
    font-size: 13px;
  }

  .controller-console .controller-test-actions {
    display: grid;
    grid-template-columns: 1fr;
    justify-content: stretch;
  }

  .controller-console .controller-status-pill,
  .controller-stop-button {
    width: 100%;
  }

  .controller-speed-layout {
    grid-template-columns: 1fr;
  }

  .controller-speed-ticks,
  .controller-rpm-ticks {
    gap: 6px;
    font-size: 11px;
  }

  .controller-speed-scale,
  .controller-rpm-scale {
    margin-left: 0;
  }

  .controller-console .controller-event-grid div,
  .controller-console .controller-light-grid div {
    padding-left: 68px;
  }
}
