:root {
  --accent-1: #bc7fff;
  --accent-2: #4c8dff;
  --accent-3: #63ecff;
  --accent-ink: #fafdff;

  --text: #e9f3ff;
  --muted: #9eb5d4;
  --line: rgba(127, 165, 228, 0.3);
  --bg-1: #061427;
  --bg-2: #0c1d35;
  --bg-3: #132a45;

  --flow-1: #52a5ff;
  --flow-2: #c16eff;
  --flow-3: #67ebff;

  --glass-bg: linear-gradient(145deg, rgba(19, 36, 69, 0.64), rgba(7, 18, 36, 0.52));
  --glass-bg-soft: linear-gradient(145deg, rgba(38, 62, 102, 0.48), rgba(15, 30, 56, 0.4));
  --glass-border: 1px solid rgba(172, 206, 255, 0.27);
  --glass-shadow: 0 24px 46px rgba(2, 9, 20, 0.46), inset 0 1px 0 rgba(214, 238, 255, 0.16);

  --container: min(1140px, 92vw);
  --header-shell-width: min(calc(var(--container) + 3vw), 99vw);
  --radius-lg: 20px;
  --radius-md: 14px;
  --radius-sm: 10px;
  --section-pad: clamp(3rem, 6vw, 5.4rem);
  --control-pill-radius: 999px;
  --control-radius: 10px;

  --font-body: "Space Grotesk", "Segoe UI", sans-serif;
  --font-heading: "Space Grotesk", "Segoe UI", sans-serif;
  --font-mono: "IBM Plex Mono", monospace;
  --heading-letter-spacing: 0;
  --heading-transform: none;
  --ui-letter-spacing: 0;
  --ui-transform: none;

  --surface-blur: 18px;
  --surface-sat: 1.2;
  --ambient-opacity: 0.6;
  --grain-opacity: 0.18;
  --texture-opacity: 0.18;
  --texture-bg:
    linear-gradient(135deg, color-mix(in srgb, var(--accent-2) 12%, transparent), transparent 55%),
    radial-gradient(circle at 80% 10%, color-mix(in srgb, var(--accent-3) 12%, transparent), transparent 40%);
  --card-hover-lift: -3px;

  --focus: color-mix(in srgb, var(--accent-1) 58%, white 42%);
  --focus-ring-width: 2px;
  --focus-ring-style: solid;
  --focus-ring-offset: 1px;

  --surface-border-width: 1px;
  --surface-border-style: solid;
  --surface-filter: blur(var(--surface-blur)) saturate(var(--surface-sat));
  --surface-extra-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);

  --grid-gap-major: 0.9rem;
  --grid-gap-minor: 0.58rem;
  --panel-padding: 1rem;
  --card-padding: 0.9rem;
  --card-radius: var(--radius-md);

  --motion-fast: 180ms;
  --motion-base: 240ms;
  --motion-slow: 500ms;
  --motion-ease: cubic-bezier(0.22, 1, 0.36, 1);
  --motion-reveal-distance: 14px;

  --interactive-lift: -1px;
  --interactive-shadow: 0 12px 20px color-mix(in srgb, var(--accent-2) 18%, transparent);
  --interactive-shadow-strong:
    0 22px 34px color-mix(in srgb, var(--accent-2) 20%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

[hidden] {
  display: none !important;
}

body[data-mode="light"] {
  --text: #101f35;
  --muted: #4e6179;
  --line: rgba(120, 145, 173, 0.3);
  --bg-1: #ffffff;
  --bg-2: #f8fbff;
  --bg-3: #edf3fa;

  --flow-1: #b7ddff;
  --flow-2: #c8ecff;
  --flow-3: #d4e3ff;

  --glass-bg: linear-gradient(145deg, rgba(255, 255, 255, 0.95), rgba(243, 250, 255, 0.82));
  --glass-bg-soft: linear-gradient(145deg, rgba(255, 255, 255, 0.92), rgba(236, 246, 255, 0.76));
  --glass-border: 1px solid rgba(136, 163, 194, 0.3);
  --glass-shadow: 0 16px 36px rgba(64, 91, 123, 0.13), inset 0 1px 0 rgba(255, 255, 255, 0.96);
  --ambient-opacity: 0.44;
  --grain-opacity: 0.12;
  --texture-opacity: 0.14;
  --surface-extra-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.82);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  color: var(--text);
  font-family: var(--font-body);
  line-height: 1.6;
  background:
    radial-gradient(circle at 12% 8%, color-mix(in srgb, var(--flow-1) 32%, transparent), transparent 43%),
    radial-gradient(circle at 89% 6%, color-mix(in srgb, var(--flow-2) 24%, transparent), transparent 40%),
    radial-gradient(circle at 58% 100%, color-mix(in srgb, var(--flow-3) 21%, transparent), transparent 47%),
    linear-gradient(150deg, var(--bg-1), var(--bg-2) 52%, var(--bg-3));
  min-height: 100vh;
  overflow-x: hidden;
  transition: color var(--motion-base) var(--motion-ease), background var(--motion-slow) var(--motion-ease);
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  opacity: var(--texture-opacity);
  background: var(--texture-bg);
}

.grain,
.ambient {
  position: fixed;
  inset: 0;
  pointer-events: none;
}

.ambient {
  filter: blur(62px);
  opacity: var(--ambient-opacity);
  z-index: -3;
}

.ambient-a {
  background: radial-gradient(circle at 18% 20%, color-mix(in srgb, var(--flow-1) 42%, transparent), transparent 45%);
  animation: ambient-drift-a 18s ease-in-out infinite alternate;
}

.ambient-b {
  background: radial-gradient(circle at 82% 22%, color-mix(in srgb, var(--flow-2) 36%, transparent), transparent 42%);
  animation: ambient-drift-b 22s ease-in-out infinite alternate;
}

.ambient-c {
  background: radial-gradient(circle at 60% 88%, color-mix(in srgb, var(--flow-3) 34%, transparent), transparent 44%);
  animation: ambient-drift-c 24s ease-in-out infinite alternate;
}

.grain {
  z-index: -2;
  opacity: var(--grain-opacity);
  background-image: radial-gradient(rgba(255, 255, 255, 0.28) 0.5px, transparent 0.6px);
  background-size: 3px 3px;
}

@keyframes ambient-drift-a {
  0% {
    transform: translate3d(-2%, -1%, 0) scale(1);
  }
  100% {
    transform: translate3d(3%, 2%, 0) scale(1.08);
  }
}

@keyframes ambient-drift-b {
  0% {
    transform: translate3d(2%, -2%, 0) scale(1);
  }
  100% {
    transform: translate3d(-3%, 2%, 0) scale(1.1);
  }
}

@keyframes ambient-drift-c {
  0% {
    transform: translate3d(0, 2%, 0) scale(1);
  }
  100% {
    transform: translate3d(2%, -3%, 0) scale(1.07);
  }
}

img,
svg,
video {
  display: block;
  max-width: 100%;
}

a {
  color: inherit;
}

.skip-link {
  position: absolute;
  left: -9999px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.skip-link:focus {
  left: 1rem;
  top: 1rem;
  width: auto;
  height: auto;
  padding: 0.6rem 0.84rem;
  border-radius: 10px;
  background: #0a1119;
  color: #fff;
  z-index: 400;
}

.scroll-progress {
  position: fixed;
  inset: 0 0 auto;
  z-index: 230;
  height: 4px;
  background: color-mix(in srgb, var(--line) 62%, transparent);
}

.scroll-progress span {
  display: block;
  height: 100%;
  width: 0;
  background: linear-gradient(90deg, var(--accent-1), var(--accent-2), var(--accent-3));
  transition: width 0.15s linear;
}

.container {
  width: var(--container);
  margin: 0 auto;
}

.glass,
.panel,
.project-card,
.style-panel,
.site-header,
.mobile-nav,
.dialog-card,
.project-toolbar,
.empty-state,
.state-output,
.console,
.arch-node,
.output-card,
.chat-thread,
.concept-canvas,
.wall-entry,
.blog-card,
.back-to-top {
  border: var(--surface-border-width) var(--surface-border-style) color-mix(in srgb, var(--line) 84%, transparent);
  background: var(--glass-bg);
  box-shadow: var(--glass-shadow), var(--surface-extra-shadow);
  backdrop-filter: var(--surface-filter);
}

.glass-soft {
  border: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  background: var(--glass-bg-soft);
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 28%, transparent);
}

.section {
  padding: var(--section-pad) 0;
}

.eyebrow {
  margin: 0 0 0.5rem;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--accent-1) 78%, var(--text));
}

h1,
h2,
h3 {
  margin-top: 0;
  line-height: 1.18;
  font-family: var(--font-heading);
  letter-spacing: var(--heading-letter-spacing);
  text-transform: var(--heading-transform);
}

h1 {
  font-size: clamp(2rem, 5.2vw, 3.4rem);
  margin-bottom: 0.84rem;
}

h2 {
  font-size: clamp(1.44rem, 3.2vw, 2.18rem);
  margin-bottom: 0.82rem;
}

h3 {
  font-size: clamp(1.02rem, 2vw, 1.28rem);
  margin-bottom: 0.68rem;
}

p {
  margin: 0 0 1rem;
}

.tiny {
  font-size: 0.93rem;
  color: var(--muted);
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 220;
  border-radius: 0 0 16px 16px;
  margin: 0.1rem auto 0;
  width: var(--header-shell-width);
  max-width: var(--header-shell-width);
  overflow: visible;
}

.header-inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 1rem;
  min-height: 74px;
}

.brand {
  font-size: 1.08rem;
  font-weight: 700;
  text-decoration: none;
  color: color-mix(in srgb, var(--text) 90%, var(--accent-1));
  font-family: var(--font-heading);
}

.main-nav {
  justify-self: center;
  display: flex;
  flex-wrap: nowrap;
  gap: 0.34rem;
}

.main-nav a {
  text-decoration: none;
  font-weight: 640;
  font-size: 0.95rem;
  line-height: 1;
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--muted);
  padding: 0.45rem 0.78rem;
  border-radius: 999px;
  border: 1px solid transparent;
  text-transform: var(--ui-transform);
  letter-spacing: 0.01em;
  white-space: nowrap;
  transition:
    color var(--motion-fast) var(--motion-ease),
    border-color var(--motion-fast) var(--motion-ease),
    background-color var(--motion-fast) var(--motion-ease);
}

.header-actions .btn {
  font-size: 0.95rem;
  line-height: 1;
  min-height: 40px;
  padding: 0.45rem 1rem;
}

.main-nav a:hover,
.main-nav a.is-active {
  color: var(--text);
  border-color: color-mix(in srgb, var(--accent-2) 52%, transparent);
  background: color-mix(in srgb, var(--accent-2) 16%, transparent);
}

.header-actions {
  justify-self: end;
  display: flex;
  gap: var(--grid-gap-minor);
  align-items: center;
}

.menu-toggle {
  display: none;
  border-radius: 10px;
}

.mobile-nav {
  display: none;
  position: absolute;
  top: calc(100% + 0.34rem);
  right: 0.5rem;
  width: max-content;
  max-width: min(320px, calc(100vw - 1rem));
  margin: 0;
  border-radius: 14px;
  padding: 0.42rem;
  border-top: 0;
  z-index: 242;
}

.mobile-nav a {
  display: block;
  text-decoration: none;
  color: var(--text);
  font-size: 0.96rem;
  font-weight: 620;
  min-width: 178px;
  padding: 0.72rem 0.6rem;
  border-radius: 9px;
}

.mobile-nav a:hover {
  background: color-mix(in srgb, var(--accent-2) 13%, transparent);
}

.mobile-style-trigger {
  width: 42px;
  height: 42px;
  min-height: 42px;
  justify-content: center;
  margin-top: 0.35rem;
  margin-inline: auto;
  padding: 0;
}

.style-panel {
  position: fixed;
  right: max(0.5rem, calc((100vw - var(--header-shell-width)) / 2 + 0.46rem));
  top: 80px;
  width: min(336px, calc(100vw - 1rem));
  max-height: none;
  overflow: visible;
  z-index: 260;
  border-radius: 20px;
  padding: 0.54rem 0.58rem 0.64rem;
  display: grid;
  gap: 0.34rem;
  opacity: 1;
  transform: translateY(0) scale(1);
  filter: blur(0);
  transform-origin: top right;
  will-change: transform, opacity, filter;
  border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  background:
    radial-gradient(circle at 8% -18%, color-mix(in srgb, var(--accent-1) 14%, transparent), transparent 42%),
    radial-gradient(circle at 102% 110%, color-mix(in srgb, var(--accent-2) 14%, transparent), transparent 44%),
    linear-gradient(
      152deg,
      color-mix(in srgb, var(--bg-3) 48%, transparent),
      color-mix(in srgb, var(--bg-2) 68%, transparent) 54%,
      color-mix(in srgb, var(--bg-1) 64%, transparent)
    );
  box-shadow:
    0 18px 30px color-mix(in srgb, var(--bg-1) 40%, transparent),
    inset 0 1px 0 color-mix(in srgb, white 18%, transparent);
  backdrop-filter: blur(20px) saturate(1.12);
  transition:
    opacity var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease),
    filter var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease);
}

.style-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 1px solid color-mix(in srgb, white 16%, transparent);
  pointer-events: none;
  z-index: 1;
}

.style-panel::after {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: calc(20px - 1px);
  pointer-events: none;
  background: linear-gradient(
    180deg,
    color-mix(in srgb, white 10%, transparent),
    transparent 38%
  );
  opacity: 0.55;
  z-index: 1;
}

.style-panel > * {
  position: relative;
  z-index: 2;
}

.style-panel-head {
  position: absolute;
  top: -0.78rem;
  right: 0.34rem;
  display: inline-flex;
  margin: 0;
  padding: 0;
  z-index: 4;
}

.icon-btn.style-close-btn {
  width: 36px;
  height: 36px;
  min-height: 36px;
  min-width: 36px;
  padding: 0;
  border-radius: 999px;
  display: grid;
  place-items: center;
  font-size: 1.2rem;
  font-weight: 800;
  line-height: 1;
  margin: 0;
  border-color: color-mix(in srgb, var(--line) 76%, transparent);
  background: linear-gradient(
    145deg,
    color-mix(in srgb, var(--bg-3) 58%, transparent),
    color-mix(in srgb, var(--bg-2) 64%, transparent)
  );
  color: color-mix(in srgb, var(--text) 82%, white 18%);
}

.icon-btn.style-close-btn:hover {
  transform: none;
  border-color: color-mix(in srgb, var(--accent-1) 58%, transparent);
  background: color-mix(in srgb, var(--accent-1) 14%, transparent);
}

.style-panel.is-hidden {
  opacity: 0;
  filter: blur(3px);
  transform: translateY(-14px) scale(0.94) rotateX(8deg);
  pointer-events: none;
}

.style-panel.is-opening {
  animation: style-deck-in 260ms var(--motion-ease);
}

.style-panel.is-closing {
  animation: style-deck-out 260ms var(--motion-ease);
  pointer-events: none;
}

@keyframes style-deck-in {
  0% {
    opacity: 0;
    filter: blur(4px);
    transform: translateY(-14px) scale(0.94) rotateX(8deg);
  }
  100% {
    opacity: 1;
    filter: blur(0);
    transform: translateY(0) scale(1) rotateX(0deg);
  }
}

@keyframes style-deck-out {
  0% {
    opacity: 1;
    filter: blur(0);
    transform: translateY(0) scale(1) rotateX(0deg);
  }
  100% {
    opacity: 0;
    filter: blur(3px);
    transform: translateY(-14px) scale(0.94) rotateX(8deg);
  }
}

.style-group {
  display: grid;
  gap: 0.26rem;
  margin: 0;
  padding: 0;
}

.style-group + .style-group {
  margin-top: 0.1rem;
}

.style-group::before {
  content: none;
}

.style-group p {
  margin: 0 0 0.4rem;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--muted);
  font-weight: 700;
}

.chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--grid-gap-minor);
}

.style-segmented {
  padding: 0.14rem;
  border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  background: color-mix(in srgb, var(--bg-2) 32%, transparent);
  box-shadow: none;
}

.style-mode-row,
.style-lang-row {
  display: grid;
  width: 100%;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.2rem;
  align-items: stretch;
}

.style-mode-row {
  width: 100%;
}

.style-lang-row {
  width: 100%;
}

.chip-row-flags {
  justify-content: flex-start;
}

#stylePanel .chip {
  min-height: 40px;
  padding: 0.12rem 0.52rem;
  font-size: 0.86rem;
  font-weight: 700;
  border: 1px solid color-mix(in srgb, var(--line) 46%, transparent);
  background: color-mix(in srgb, var(--bg-2) 36%, transparent);
  box-shadow: none;
  border-radius: 12px;
  letter-spacing: 0.01em;
}

#stylePanel .style-mode-row .style-chip {
  font-size: 1.34rem;
  min-height: 40px;
  padding: 0.06rem 0.1rem;
}

#stylePanel .chip:hover {
  transform: none;
  border-color: color-mix(in srgb, var(--accent-2) 52%, transparent);
  background: color-mix(in srgb, var(--accent-2) 10%, transparent);
}

#stylePanel .style-chip.active {
  border-color: color-mix(in srgb, var(--accent-1) 72%, transparent);
  background: linear-gradient(
    145deg,
    color-mix(in srgb, var(--accent-1) 20%, transparent),
    color-mix(in srgb, var(--accent-2) 16%, transparent)
  );
  color: color-mix(in srgb, var(--text) 90%, white 10%);
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, white 18%, transparent),
    0 0 0 1px color-mix(in srgb, var(--accent-1) 22%, transparent);
}

.style-flag-chip {
  min-width: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1.1;
  min-height: 40px;
  font: 800 0.95rem/1 var(--font-mono);
  letter-spacing: 0.08em;
}

.style-family-row .chip {
  font-size: 0.76rem;
  padding: 0.42rem 0.66rem;
}

.theme-preset-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 0.52rem;
  justify-content: stretch;
  padding: 0.12rem 0.04rem 0.04rem;
  place-items: center;
}

.theme-preset {
  width: min(30px, 100%);
  height: auto;
  min-height: 0;
  aspect-ratio: 1 / 1;
  max-width: 30px;
  justify-self: center;
  padding: 0;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--line) 76%, transparent);
  background: linear-gradient(140deg, var(--sw-1), var(--sw-2) 55%, var(--sw-3));
  cursor: pointer;
  position: relative;
  box-shadow: 0 7px 13px color-mix(in srgb, var(--bg-1) 30%, transparent);
  transition:
    transform var(--motion-fast) var(--motion-ease),
    border-color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease);
}

.theme-preset::after {
  content: "";
  position: absolute;
  inset: 18% 18% 54% 18%;
  border-radius: 999px;
  background: color-mix(in srgb, white 54%, transparent);
  filter: blur(2px);
  opacity: 0.42;
  pointer-events: none;
}

.theme-preset:hover {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--accent-2) 60%, transparent);
  box-shadow: 0 10px 14px color-mix(in srgb, var(--bg-1) 34%, transparent);
}

.theme-preset.active {
  border-color: color-mix(in srgb, var(--accent-1) 82%, transparent);
  box-shadow:
    0 11px 16px color-mix(in srgb, var(--accent-1) 24%, transparent),
    0 0 0 2px color-mix(in srgb, var(--accent-1) 28%, transparent);
}

.theme-preset-pill.theme-preset-solid {
  background: linear-gradient(135deg, var(--sw-3), var(--sw-1) 56%, var(--sw-2));
}

/* Style Families: System + Expression */
body[data-theme-family="glassmorphism"] {
  --surface-filter: blur(calc(var(--surface-blur) + 6px)) saturate(1.34);
  --surface-border-width: 1px;
  --surface-border-style: solid;
  --surface-extra-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    0 18px 34px color-mix(in srgb, var(--bg-1) 46%, transparent);
  --grid-gap-major: 0.92rem;
  --grid-gap-minor: 0.56rem;
  --panel-padding: 1.02rem;
  --card-padding: 0.94rem;
  --motion-fast: 180ms;
  --motion-base: 260ms;
  --motion-ease: cubic-bezier(0.2, 0.86, 0.28, 1);
  --interactive-lift: -2px;
  --focus-ring-width: 3px;
  --focus-ring-style: solid;
}

body[data-theme-family="glassmorphism"] .site-header {
  background: linear-gradient(
    145deg,
    color-mix(in srgb, var(--bg-3) 46%, transparent),
    color-mix(in srgb, var(--bg-1) 58%, transparent)
  );
}

body[data-theme-family="pure-aqua"] {
  --surface-filter: blur(calc(var(--surface-blur) + 4px)) saturate(1.44);
  --surface-border-width: 1px;
  --surface-border-style: solid;
  --surface-extra-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--accent-2) 24%, transparent),
    0 0 36px color-mix(in srgb, var(--accent-2) 20%, transparent);
  --grid-gap-major: 0.98rem;
  --grid-gap-minor: 0.48rem;
  --panel-padding: 0.94rem;
  --card-padding: 0.88rem;
  --motion-fast: 160ms;
  --motion-base: 220ms;
  --motion-ease: cubic-bezier(0.18, 0.8, 0.24, 1);
  --interactive-lift: -2px;
  --focus-ring-width: 2px;
}

body[data-theme-family="pure-aqua"]::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  opacity: 0.24;
  background:
    repeating-linear-gradient(
      90deg,
      color-mix(in srgb, var(--accent-2) 16%, transparent) 0,
      color-mix(in srgb, var(--accent-2) 16%, transparent) 1px,
      transparent 1px,
      transparent 22px
    ),
    repeating-linear-gradient(
      180deg,
      color-mix(in srgb, var(--accent-3) 9%, transparent) 0,
      color-mix(in srgb, var(--accent-3) 9%, transparent) 1px,
      transparent 1px,
      transparent 18px
    );
}

body[data-theme-family="pure-aqua"] .btn-primary {
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--accent-2) 42%, transparent),
    0 0 28px color-mix(in srgb, var(--accent-2) 38%, transparent);
}

body[data-theme-family="pure-aqua"] .main-nav a,
body[data-theme-family="pure-aqua"] .chip {
  border-color: color-mix(in srgb, var(--accent-2) 46%, transparent);
}

body[data-theme-family="pure-aqua"] .project-card::after,
body[data-theme-family="pure-aqua"] .prototype-card::after,
body[data-theme-family="pure-aqua"] .blog-card::after,
body[data-theme-family="pure-aqua"] .stack-card::after,
body[data-theme-family="pure-aqua"] .wall-entry::after {
  background: linear-gradient(
    100deg,
    transparent 18%,
    color-mix(in srgb, var(--accent-2) 28%, transparent) 46%,
    transparent 76%
  );
}

body[data-theme-family="neumorphism"] {
  --surface-filter: none;
  --surface-border-width: 1px;
  --surface-border-style: solid;
  --ambient-opacity: 0.08;
  --grain-opacity: 0.03;
  --texture-opacity: 0.02;
  --texture-bg: linear-gradient(180deg, rgba(255, 255, 255, 0.03), transparent 70%);
  --surface-extra-shadow:
    8px 8px 18px color-mix(in srgb, var(--bg-1) 22%, transparent),
    -8px -8px 18px color-mix(in srgb, white 34%, transparent),
    inset 0 1px 0 color-mix(in srgb, white 30%, transparent);
  --grid-gap-major: 0.88rem;
  --grid-gap-minor: 0.5rem;
  --panel-padding: 1.12rem;
  --card-padding: 1.02rem;
  --motion-fast: 200ms;
  --motion-base: 260ms;
  --interactive-lift: 0px;
  --interactive-shadow:
    8px 8px 16px color-mix(in srgb, var(--bg-1) 20%, transparent),
    -8px -8px 16px color-mix(in srgb, white 30%, transparent);
  --interactive-shadow-strong:
    10px 10px 24px color-mix(in srgb, var(--bg-1) 24%, transparent),
    -10px -10px 24px color-mix(in srgb, white 36%, transparent);
  --focus-ring-width: 2px;
}

body[data-theme-family="neumorphism"] {
  background: linear-gradient(165deg, var(--bg-1), var(--bg-2) 58%, var(--bg-3));
}

body[data-theme-family="neumorphism"] .glass,
body[data-theme-family="neumorphism"] .panel,
body[data-theme-family="neumorphism"] .project-card,
body[data-theme-family="neumorphism"] .site-header,
body[data-theme-family="neumorphism"] .mobile-nav {
  border-color: color-mix(in srgb, var(--line) 42%, transparent);
  background: color-mix(in srgb, var(--bg-2) 98%, transparent);
}

body[data-theme-family="neumorphism"][data-mode="light"] .glass,
body[data-theme-family="neumorphism"][data-mode="light"] .panel,
body[data-theme-family="neumorphism"][data-mode="light"] .project-card,
body[data-theme-family="neumorphism"][data-mode="light"] .site-header,
body[data-theme-family="neumorphism"][data-mode="light"] .mobile-nav {
  box-shadow:
    12px 12px 24px rgba(176, 189, 208, 0.42),
    -12px -12px 24px rgba(255, 255, 255, 0.9),
    inset 0 1px 0 rgba(255, 255, 255, 0.95);
}

body[data-theme-family="neumorphism"][data-mode="dark"] .glass,
body[data-theme-family="neumorphism"][data-mode="dark"] .panel,
body[data-theme-family="neumorphism"][data-mode="dark"] .project-card,
body[data-theme-family="neumorphism"][data-mode="dark"] .site-header,
body[data-theme-family="neumorphism"][data-mode="dark"] .mobile-nav {
  box-shadow:
    12px 12px 24px rgba(6, 10, 16, 0.5),
    -12px -12px 24px rgba(61, 79, 106, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

body[data-theme-family="neumorphism"] .btn,
body[data-theme-family="neumorphism"] .chip,
body[data-theme-family="neumorphism"] .tab,
body[data-theme-family="neumorphism"] .icon-btn,
body[data-theme-family="neumorphism"] .menu-toggle {
  border-color: color-mix(in srgb, var(--line) 56%, transparent);
  background: color-mix(in srgb, var(--bg-2) 94%, transparent);
  box-shadow:
    5px 5px 12px color-mix(in srgb, var(--bg-1) 18%, transparent),
    -5px -5px 12px color-mix(in srgb, white 26%, transparent);
}

body[data-theme-family="neumorphism"] .btn:hover,
body[data-theme-family="neumorphism"] .chip:hover,
body[data-theme-family="neumorphism"] .tab:hover,
body[data-theme-family="neumorphism"] .icon-btn:hover,
body[data-theme-family="neumorphism"] .menu-toggle:hover {
  box-shadow:
    inset 4px 4px 10px color-mix(in srgb, var(--bg-1) 18%, transparent),
    inset -4px -4px 10px color-mix(in srgb, white 22%, transparent);
}

body[data-theme-family="neumorphism"] .btn-primary {
  background: color-mix(in srgb, var(--bg-2) 94%, transparent);
  border-color: color-mix(in srgb, var(--accent-1) 54%, transparent);
  color: color-mix(in srgb, var(--accent-1) 76%, var(--text));
  box-shadow:
    6px 6px 14px color-mix(in srgb, var(--bg-1) 20%, transparent),
    -6px -6px 14px color-mix(in srgb, white 30%, transparent),
    inset 0 0 0 1px color-mix(in srgb, var(--accent-1) 26%, transparent);
}

body[data-theme-family="neumorphism"] .btn-primary:hover {
  transform: translateY(0);
  box-shadow:
    inset 5px 5px 11px color-mix(in srgb, var(--bg-1) 22%, transparent),
    inset -5px -5px 11px color-mix(in srgb, white 24%, transparent),
    inset 0 0 0 1px color-mix(in srgb, var(--accent-1) 36%, transparent);
}

body[data-theme-family="neumorphism"] .chip.active,
body[data-theme-family="neumorphism"] .tab.active,
body[data-theme-family="neumorphism"] .style-chip.active {
  background: color-mix(in srgb, var(--bg-2) 94%, transparent);
  border-color: color-mix(in srgb, var(--accent-1) 54%, transparent);
  color: color-mix(in srgb, var(--accent-1) 72%, var(--text));
  box-shadow:
    inset 3px 3px 8px color-mix(in srgb, var(--bg-1) 18%, transparent),
    inset -3px -3px 8px color-mix(in srgb, white 22%, transparent);
}

body[data-theme-family="neumorphism"] .tag:not(.tech-tag),
body[data-theme-family="neumorphism"] .preview-pill,
body[data-theme-family="neumorphism"] .blog-meta,
body[data-theme-family="neumorphism"] .status-label,
body[data-theme-family="neumorphism"] .source-pill,
body[data-theme-family="neumorphism"] .journey-year {
  background: color-mix(in srgb, var(--bg-2) 95%, transparent);
  border-color: color-mix(in srgb, var(--accent-2) 50%, transparent);
  color: color-mix(in srgb, var(--accent-2) 68%, var(--text));
}

body[data-theme-family="brutalist"] {
  --surface-filter: none;
  --surface-border-width: 2px;
  --surface-border-style: solid;
  --surface-extra-shadow: none;
  --glass-shadow: 6px 6px 0 color-mix(in srgb, var(--bg-1) 48%, transparent);
  --grid-gap-major: 1rem;
  --grid-gap-minor: 0.38rem;
  --panel-padding: 0.82rem;
  --card-padding: 0.74rem;
  --card-radius: 2px;
  --motion-fast: 100ms;
  --motion-base: 140ms;
  --motion-slow: 180ms;
  --motion-ease: linear;
  --interactive-lift: -2px;
  --card-hover-lift: 0px;
  --interactive-shadow: 6px 6px 0 color-mix(in srgb, var(--bg-1) 50%, transparent);
  --interactive-shadow-strong: 8px 8px 0 color-mix(in srgb, var(--bg-1) 56%, transparent);
  --focus-ring-style: dashed;
  --focus-ring-width: 3px;
  --focus-ring-offset: 3px;
}

body[data-theme-family="brutalist"] .project-card::after,
body[data-theme-family="brutalist"] .prototype-card::after,
body[data-theme-family="brutalist"] .blog-card::after,
body[data-theme-family="brutalist"] .stack-card::after,
body[data-theme-family="brutalist"] .wall-entry::after {
  display: none;
}

body[data-theme-family="brutalist"] .btn,
body[data-theme-family="brutalist"] .chip,
body[data-theme-family="brutalist"] .tab,
body[data-theme-family="brutalist"] .icon-btn,
body[data-theme-family="brutalist"] .menu-toggle,
body[data-theme-family="brutalist"] .back-to-top {
  border-width: 2px;
  border-radius: 2px;
  text-transform: uppercase;
}

body[data-theme-family="brutalist"] .btn:hover,
body[data-theme-family="brutalist"] .chip:hover,
body[data-theme-family="brutalist"] .tab:hover,
body[data-theme-family="brutalist"] .icon-btn:hover,
body[data-theme-family="brutalist"] .menu-toggle:hover {
  transform: translate(-2px, -2px);
}

body[data-theme-family="skeuomorphism"] {
  --surface-filter: none;
  --surface-border-width: 1px;
  --surface-border-style: solid;
  --surface-extra-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.34),
    inset 0 -3px 8px color-mix(in srgb, var(--bg-1) 30%, transparent);
  --grid-gap-major: 0.94rem;
  --grid-gap-minor: 0.5rem;
  --panel-padding: 1rem;
  --card-padding: 0.92rem;
  --motion-fast: 180ms;
  --motion-base: 240ms;
  --interactive-lift: -2px;
  --interactive-shadow:
    0 8px 0 color-mix(in srgb, var(--bg-1) 36%, transparent),
    0 18px 30px color-mix(in srgb, var(--bg-1) 24%, transparent);
  --interactive-shadow-strong:
    0 10px 0 color-mix(in srgb, var(--bg-1) 40%, transparent),
    0 22px 36px color-mix(in srgb, var(--bg-1) 28%, transparent);
  --focus-ring-width: 2px;
  --focus-ring-offset: 3px;
}

body[data-theme-family="skeuomorphism"] .btn,
body[data-theme-family="skeuomorphism"] .chip,
body[data-theme-family="skeuomorphism"] .tab,
body[data-theme-family="skeuomorphism"] .icon-btn,
body[data-theme-family="skeuomorphism"] .menu-toggle {
  border-color: color-mix(in srgb, var(--line) 78%, transparent);
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--bg-3) 24%, white 76%),
    color-mix(in srgb, var(--bg-2) 70%, var(--bg-1))
  );
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.34),
    0 3px 0 color-mix(in srgb, var(--bg-1) 36%, transparent);
}

body[data-theme-family="skeuomorphism"] .btn:hover,
body[data-theme-family="skeuomorphism"] .chip:hover,
body[data-theme-family="skeuomorphism"] .tab:hover,
body[data-theme-family="skeuomorphism"] .icon-btn:hover,
body[data-theme-family="skeuomorphism"] .menu-toggle:hover {
  transform: translateY(1px);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.24),
    0 1px 0 color-mix(in srgb, var(--bg-1) 36%, transparent);
}

body[data-theme-family="gradient"] {
  --surface-filter: blur(calc(var(--surface-blur) + 2px)) saturate(1.34);
  --surface-border-width: 1px;
  --surface-border-style: solid;
  --surface-extra-shadow:
    0 18px 30px color-mix(in srgb, var(--accent-1) 18%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.16);
  --grid-gap-major: 0.96rem;
  --grid-gap-minor: 0.52rem;
  --panel-padding: 1rem;
  --card-padding: 0.94rem;
  --motion-fast: 180ms;
  --motion-base: 300ms;
  --motion-slow: 560ms;
  --motion-ease: cubic-bezier(0.22, 0.88, 0.18, 1);
  --interactive-lift: -3px;
  --focus-ring-width: 3px;
}

body[data-theme-family="gradient"] h1,
body[data-theme-family="gradient"] h2 {
  background: linear-gradient(120deg, var(--accent-1), var(--accent-2), var(--accent-3));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

body[data-theme-family="gradient"] .btn-primary {
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--accent-1) 42%, transparent),
    0 0 30px color-mix(in srgb, var(--accent-1) 34%, transparent);
}

body[data-theme-family="gradient"] .project-card::after,
body[data-theme-family="gradient"] .prototype-card::after,
body[data-theme-family="gradient"] .blog-card::after,
body[data-theme-family="gradient"] .stack-card::after,
body[data-theme-family="gradient"] .wall-entry::after {
  background: linear-gradient(
    120deg,
    transparent 10%,
    color-mix(in srgb, var(--accent-1) 28%, transparent) 42%,
    color-mix(in srgb, var(--accent-2) 28%, transparent) 58%,
    transparent 84%
  );
}

body[data-theme-family="material"] {
  --surface-filter: none;
  --surface-border-width: 1px;
  --surface-border-style: solid;
  --surface-extra-shadow: none;
  --glass-shadow:
    0 1px 2px color-mix(in srgb, var(--bg-1) 26%, transparent),
    0 8px 16px color-mix(in srgb, var(--bg-1) 18%, transparent);
  --grid-gap-major: 0.96rem;
  --grid-gap-minor: 0.5rem;
  --panel-padding: 1rem;
  --card-padding: 0.92rem;
  --motion-fast: 160ms;
  --motion-base: 220ms;
  --motion-ease: cubic-bezier(0.2, 0.8, 0.2, 1);
  --interactive-lift: -1px;
  --interactive-shadow:
    0 12px 18px color-mix(in srgb, var(--bg-1) 18%, transparent),
    0 2px 6px color-mix(in srgb, var(--bg-1) 16%, transparent);
  --interactive-shadow-strong:
    0 16px 28px color-mix(in srgb, var(--bg-1) 22%, transparent),
    0 4px 10px color-mix(in srgb, var(--bg-1) 18%, transparent);
  --focus-ring-width: 2px;
  --focus-ring-offset: 3px;
}

body[data-theme-family="material"] .glass,
body[data-theme-family="material"] .panel,
body[data-theme-family="material"] .project-card,
body[data-theme-family="material"] .blog-card,
body[data-theme-family="material"] .site-header {
  background: color-mix(in srgb, var(--bg-2) 88%, transparent);
}

body[data-theme-family="material"] .project-card::after,
body[data-theme-family="material"] .prototype-card::after,
body[data-theme-family="material"] .blog-card::after,
body[data-theme-family="material"] .stack-card::after,
body[data-theme-family="material"] .wall-entry::after {
  display: none;
}

body[data-theme-family="material"] .btn-primary {
  background: color-mix(in srgb, var(--accent-1) 72%, var(--accent-2));
}

body[data-theme-family="minimalist"] {
  --surface-filter: none;
  --surface-border-width: 1px;
  --surface-border-style: solid;
  --surface-extra-shadow: none;
  --glass-shadow: 0 2px 8px color-mix(in srgb, var(--bg-1) 12%, transparent);
  --grid-gap-major: 1.06rem;
  --grid-gap-minor: 0.48rem;
  --panel-padding: 1.1rem;
  --card-padding: 1rem;
  --motion-fast: 160ms;
  --motion-base: 220ms;
  --motion-slow: 420ms;
  --motion-ease: cubic-bezier(0.2, 0.8, 0.2, 1);
  --interactive-lift: 0px;
  --card-hover-lift: -1px;
  --interactive-shadow: 0 8px 16px color-mix(in srgb, var(--bg-1) 10%, transparent);
  --interactive-shadow-strong: 0 12px 20px color-mix(in srgb, var(--bg-1) 14%, transparent);
  --focus-ring-width: 2px;
  --focus-ring-offset: 2px;
  --ambient-opacity: 0.12;
  --grain-opacity: 0;
  --texture-opacity: 0.03;
}

body[data-theme-family="minimalist"] .project-card::after,
body[data-theme-family="minimalist"] .prototype-card::after,
body[data-theme-family="minimalist"] .blog-card::after,
body[data-theme-family="minimalist"] .stack-card::after,
body[data-theme-family="minimalist"] .wall-entry::after {
  display: none;
}

body[data-theme-family="minimalist"] .glass,
body[data-theme-family="minimalist"] .panel,
body[data-theme-family="minimalist"] .project-card,
body[data-theme-family="minimalist"] .blog-card,
body[data-theme-family="minimalist"] .site-header {
  background: color-mix(in srgb, var(--bg-2) 94%, transparent);
}

body[data-theme-family="minimalist"] .main-nav a,
body[data-theme-family="minimalist"] .chip,
body[data-theme-family="minimalist"] .btn {
  border-color: color-mix(in srgb, var(--line) 56%, transparent);
}

body[data-theme-family="immersive-3d"] {
  --surface-filter: blur(calc(var(--surface-blur) + 4px)) saturate(1.42);
  --surface-border-width: 1px;
  --surface-border-style: solid;
  --surface-extra-shadow:
    0 22px 38px color-mix(in srgb, var(--bg-1) 34%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.14);
  --grid-gap-major: 1rem;
  --grid-gap-minor: 0.54rem;
  --panel-padding: 1.04rem;
  --card-padding: 0.96rem;
  --motion-fast: 190ms;
  --motion-base: 330ms;
  --motion-slow: 620ms;
  --motion-ease: cubic-bezier(0.16, 1, 0.3, 1);
  --interactive-lift: -3px;
  --card-hover-lift: -6px;
  --focus-ring-width: 2px;
}

body[data-theme-family="immersive-3d"] main {
  perspective: 1100px;
}

body[data-theme-family="immersive-3d"] .panel,
body[data-theme-family="immersive-3d"] .dialog-card {
  transform-style: preserve-3d;
  transform: translateZ(0);
}

body[data-theme-family="immersive-3d"] .project-card,
body[data-theme-family="immersive-3d"] .prototype-card,
body[data-theme-family="immersive-3d"] .blog-card {
  transform-style: preserve-3d;
}

body[data-theme-family="immersive-3d"] .project-card:hover,
body[data-theme-family="immersive-3d"] .prototype-card:hover,
body[data-theme-family="immersive-3d"] .blog-card:hover {
  transform: translateY(var(--card-hover-lift)) rotateX(4deg) rotateY(-4deg);
}

body[data-theme-family="immersive-3d"] .btn-primary {
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--accent-1) 42%, transparent),
    0 0 30px color-mix(in srgb, var(--accent-1) 34%, transparent);
}

.hero {
  padding-top: clamp(2.6rem, 5vw, 4rem);
}

.hero-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--grid-gap-major);
}

.lead {
  font-size: 1.02rem;
  color: var(--muted);
  max-width: 60ch;
}

.stack-note {
  white-space: pre-line;
}

.hero-copy {
  max-width: 920px;
}

.hero-signal-row {
  margin: 0.8rem 0 0.9rem;
}

.hero-signal-row .tag {
  font-size: 0.73rem;
}

.value-list {
  margin: 0.6rem 0 1.1rem;
  padding-left: 1.1rem;
}

.value-list li {
  margin-bottom: 0.44rem;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--grid-gap-minor);
  margin: 1rem 0 1.1rem;
}

.hero-proof {
  display: grid;
  grid-template-columns: minmax(190px, 300px) minmax(0, 1fr);
  gap: var(--grid-gap-minor);
  max-width: 980px;
  align-items: stretch;
}

.hero-proof article {
  border-radius: var(--radius-sm);
  padding: 0.66rem 0.74rem;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  transition:
    transform var(--motion-base) var(--motion-ease),
    box-shadow var(--motion-base) var(--motion-ease),
    border-color var(--motion-base) var(--motion-ease);
}

.hero-proof-location {
  max-width: 300px;
}

.hero-proof-roles {
  min-width: 0;
}

.hero-proof span {
  display: block;
  margin-bottom: 0.26rem;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--muted);
}

.hero-proof strong {
  font-size: 0.88rem;
  line-height: 1.3;
}

.panel {
  border-radius: var(--radius-lg);
  padding: var(--panel-padding);
}

.now-building .focus-grid {
  display: grid;
  gap: var(--grid-gap-minor);
}

.now-building .focus-grid article {
  border-radius: var(--radius-sm);
  padding: 0.72rem;
  transition:
    transform var(--motion-base) var(--motion-ease),
    box-shadow var(--motion-base) var(--motion-ease),
    border-color var(--motion-base) var(--motion-ease);
}

.now-building .focus-grid p {
  margin: 0;
  font-size: 0.92rem;
  color: var(--muted);
}

.section-head {
  margin-bottom: 1.34rem;
}

.stack-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--grid-gap-major);
}

.stack-card {
  position: relative;
  overflow: hidden;
}

.project-toolbar {
  display: grid;
  gap: var(--grid-gap-minor);
  margin-bottom: 1rem;
  border-radius: var(--radius-md);
  position: sticky;
  top: calc(74px + 0.56rem);
  z-index: 84;
}

.filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--grid-gap-minor);
}

.search-field {
  display: grid;
  gap: 0.34rem;
}

.search-field span {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--muted);
}

input,
select,
textarea,
button {
  font-family: inherit;
}

input,
select,
textarea {
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  border-radius: 10px;
  padding: 0.62rem 0.72rem;
  color: var(--text);
  background: var(--glass-bg-soft);
  transition:
    border-color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    background var(--motion-fast) var(--motion-ease);
}

input:focus,
select:focus,
textarea:focus {
  border-color: color-mix(in srgb, var(--accent-2) 56%, transparent);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--accent-2) 28%, transparent),
    inset 0 1px 0 color-mix(in srgb, white 9%, transparent);
}

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

.project-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--grid-gap-major);
}

.project-card,
.prototype-card,
.blog-card,
.stack-card,
.wall-entry,
.testimonial-item {
  position: relative;
  overflow: hidden;
  transition:
    transform var(--motion-base) var(--motion-ease),
    box-shadow var(--motion-base) var(--motion-ease),
    border-color var(--motion-base) var(--motion-ease);
}

.project-card::after,
.prototype-card::after,
.blog-card::after,
.stack-card::after,
.wall-entry::after,
.testimonial-item::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(120deg, transparent 5%, rgba(255, 255, 255, 0.16) 38%, transparent 66%);
  transform: translateX(-125%);
  transition: transform 0.7s ease;
}

.project-card:hover::after,
.prototype-card:hover::after,
.blog-card:hover::after,
.stack-card:hover::after,
.wall-entry:hover::after,
.testimonial-item:hover::after {
  transform: translateX(125%);
}

.project-card {
  border-radius: var(--card-radius);
  padding: var(--card-padding);
  display: flex;
  flex-direction: column;
  gap: var(--grid-gap-minor);
  height: 100%;
}

.project-preview {
  position: relative;
  border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  background:
    radial-gradient(circle at 80% 10%, color-mix(in srgb, var(--accent-1) 36%, transparent), transparent 60%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.03));
  min-height: 148px;
  padding: 0.7rem;
  overflow: hidden;
}

.project-preview.has-image {
  min-height: 176px;
  padding: 0.66rem;
}

.preview-glow {
  position: absolute;
  inset: auto -20% -35% -20%;
  height: 70%;
  background: radial-gradient(circle, color-mix(in srgb, var(--accent-2) 40%, transparent), transparent 64%);
  filter: blur(24px);
  opacity: 0.7;
}

.preview-frame {
  position: relative;
  z-index: 1;
  border: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  border-radius: 9px;
  background: color-mix(in srgb, var(--glass-bg-soft) 82%, transparent);
  overflow: hidden;
}

.project-preview.has-image .preview-frame {
  height: 100%;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  background:
    radial-gradient(circle at 84% 4%, color-mix(in srgb, var(--accent-2) 20%, transparent), transparent 52%),
    color-mix(in srgb, var(--bg-2) 58%, transparent);
}

.preview-topbar {
  display: flex;
  gap: 0.3rem;
  padding: 0.35rem 0.45rem;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 80%, transparent);
}

.preview-topbar span {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--muted) 50%, transparent);
}

.preview-content {
  padding: 0.6rem;
  display: grid;
  gap: 0.38rem;
}

.preview-line {
  height: 8px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--line) 84%, transparent);
}

.preview-line.long {
  width: 92%;
}

.preview-line.mid {
  width: 70%;
}

.preview-line.short {
  width: 48%;
}

.preview-pill {
  justify-self: start;
  margin-top: 0.2rem;
  display: inline-flex;
  padding: 0.18rem 0.48rem;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--accent-2) 52%, transparent);
  background: color-mix(in srgb, var(--accent-2) 16%, transparent);
  font-size: 0.73rem;
  font-weight: 600;
}

.preview-media {
  position: relative;
  margin: 0.52rem;
  aspect-ratio: 16 / 10;
  border-radius: 11px;
  border: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  overflow: hidden;
  min-height: 0;
  background:
    radial-gradient(circle at 84% 8%, color-mix(in srgb, var(--accent-1) 18%, transparent), transparent 58%),
    color-mix(in srgb, var(--bg-1) 74%, transparent);
}

.preview-media::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, rgba(255, 255, 255, 0.2), transparent 38%, transparent 62%, rgba(255, 255, 255, 0.14));
  opacity: 0.3;
  pointer-events: none;
  z-index: 2;
}

.preview-media::after {
  content: "";
  position: absolute;
  inset: 36% 0 0;
  background: linear-gradient(180deg, rgba(4, 8, 18, 0), rgba(4, 8, 18, 0.7));
  pointer-events: none;
  z-index: 1;
}

.preview-image {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center top;
  filter: saturate(1.08) contrast(1.05);
  transform-origin: center top;
  transform: scale(1);
  transition:
    transform var(--motion-base) var(--motion-ease),
    filter var(--motion-base) var(--motion-ease);
}

.project-card:hover .preview-image {
  transform: scale(1.035);
  filter: saturate(1.16) contrast(1.08);
}

.preview-media .preview-pill {
  position: absolute;
  left: 0.62rem;
  bottom: 0.62rem;
  margin: 0;
  max-width: calc(100% - 1.24rem);
  background: color-mix(in srgb, var(--bg-1) 56%, transparent);
  border-color: color-mix(in srgb, var(--accent-2) 60%, transparent);
  backdrop-filter: blur(8px);
  z-index: 3;
}

.project-card[data-project-id="marketplace"] .project-preview {
  background:
    radial-gradient(circle at 10% 8%, rgba(56, 218, 255, 0.28), transparent 55%),
    linear-gradient(135deg, rgba(0, 173, 255, 0.2), rgba(2, 22, 49, 0.22));
}

.project-card[data-project-id="racetrack"] .project-preview {
  background:
    radial-gradient(circle at 90% 8%, rgba(255, 91, 145, 0.28), transparent 55%),
    linear-gradient(135deg, rgba(255, 94, 56, 0.2), rgba(8, 24, 44, 0.22));
}

.project-card[data-project-id="employee-tracker"] .project-preview {
  background:
    radial-gradient(circle at 75% 14%, rgba(124, 255, 150, 0.28), transparent 55%),
    linear-gradient(135deg, rgba(21, 198, 168, 0.22), rgba(7, 22, 42, 0.22));
}

.meta-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.6rem;
}

.meta-row .tag-row {
  justify-content: flex-end;
}

.project-card p {
  margin: 0;
  font-size: 0.92rem;
  color: var(--muted);
}

.tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.36rem;
}

.tag {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--accent-2) 48%, transparent);
  background: color-mix(in srgb, var(--accent-2) 14%, transparent);
  padding: 0.23rem 0.52rem;
  font-size: 0.76rem;
  font-weight: 600;
}

.tag--dotted {
  border-style: solid;
  border-width: 1px;
  background: color-mix(in srgb, var(--accent-2) 14%, transparent);
}

.tag--dotted::before {
  content: "IP";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-right: 0.34rem;
  padding: 0.06rem 0.26rem;
  border-radius: 999px;
  font-size: 0.56rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  line-height: 1.05;
  color: color-mix(in srgb, var(--text) 86%, white 14%);
  border: 1px solid color-mix(in srgb, var(--accent-2) 70%, transparent);
  background: color-mix(in srgb, var(--accent-2) 34%, transparent);
}

.tech-tag {
  border: 1px solid var(--tech-border, color-mix(in srgb, var(--accent-2) 48%, transparent));
  background: var(--tech-bg, color-mix(in srgb, var(--accent-2) 14%, transparent));
}

.tech-tag.tag--dotted {
  border-style: solid;
  border-width: 1px;
  background: var(--tech-bg, color-mix(in srgb, var(--accent-2) 14%, transparent));
}

.tech-tag[data-tech="html"],
.tech-html { --tech-border: rgba(255, 120, 102, 0.72); --tech-bg: rgba(255, 120, 102, 0.18); }
.tech-tag[data-tech="css"],
.tech-css { --tech-border: rgba(93, 174, 255, 0.72); --tech-bg: rgba(93, 174, 255, 0.18); }
.tech-tag[data-tech="javascript"],
.tech-javascript { --tech-border: rgba(245, 204, 74, 0.74); --tech-bg: rgba(245, 204, 74, 0.2); }
.tech-tag[data-tech="typescript"],
.tech-typescript { --tech-border: rgba(52, 121, 250, 0.74); --tech-bg: rgba(52, 121, 250, 0.2); }
.tech-tag[data-tech="react"],
.tech-react { --tech-border: rgba(68, 222, 255, 0.74); --tech-bg: rgba(68, 222, 255, 0.2); }
.tech-tag[data-tech="reactrouter"],
.tech-reactrouter { --tech-border: rgba(245, 98, 98, 0.74); --tech-bg: rgba(245, 98, 98, 0.2); }
.tech-tag[data-tech="bootstrap"],
.tech-bootstrap { --tech-border: rgba(171, 132, 255, 0.72); --tech-bg: rgba(171, 132, 255, 0.2); }
.tech-tag[data-tech="materialize"],
.tech-materialize { --tech-border: rgba(240, 102, 132, 0.74); --tech-bg: rgba(240, 102, 132, 0.2); }
.tech-tag[data-tech="tailwind"],
.tech-tailwind { --tech-border: rgba(56, 189, 248, 0.72); --tech-bg: rgba(56, 189, 248, 0.2); }
.tech-tag[data-tech="sass"],
.tech-sass { --tech-border: rgba(244, 114, 182, 0.74); --tech-bg: rgba(244, 114, 182, 0.2); }
.tech-tag[data-tech="handlebars"],
.tech-handlebars { --tech-border: rgba(249, 160, 83, 0.74); --tech-bg: rgba(249, 160, 83, 0.2); }
.tech-tag[data-tech="spa"],
.tech-spa { --tech-border: rgba(129, 140, 248, 0.74); --tech-bg: rgba(129, 140, 248, 0.2); }
.tech-tag[data-tech="responsive"],
.tech-responsive { --tech-border: rgba(45, 212, 191, 0.74); --tech-bg: rgba(45, 212, 191, 0.2); }

.tech-tag[data-tech="node"],
.tech-node { --tech-border: rgba(74, 222, 128, 0.74); --tech-bg: rgba(74, 222, 128, 0.2); }
.tech-tag[data-tech="express"],
.tech-express { --tech-border: rgba(148, 163, 184, 0.72); --tech-bg: rgba(148, 163, 184, 0.18); }
.tech-tag[data-tech="rest"],
.tech-rest { --tech-border: rgba(14, 165, 233, 0.74); --tech-bg: rgba(14, 165, 233, 0.2); }
.tech-tag[data-tech="passport"],
.tech-passport { --tech-border: rgba(124, 188, 255, 0.72); --tech-bg: rgba(124, 188, 255, 0.2); }
.tech-tag[data-tech="graphql"],
.tech-graphql { --tech-border: rgba(236, 72, 153, 0.74); --tech-bg: rgba(236, 72, 153, 0.2); }
.tech-tag[data-tech="websocket"],
.tech-websocket { --tech-border: rgba(34, 197, 94, 0.74); --tech-bg: rgba(34, 197, 94, 0.2); }
.tech-tag[data-tech="socketio"],
.tech-socketio { --tech-border: rgba(20, 184, 166, 0.74); --tech-bg: rgba(20, 184, 166, 0.2); }
.tech-tag[data-tech="go"],
.tech-go { --tech-border: rgba(8, 190, 216, 0.74); --tech-bg: rgba(8, 190, 216, 0.2); }

.tech-tag[data-tech="postgres"],
.tech-postgres { --tech-border: rgba(96, 165, 250, 0.74); --tech-bg: rgba(96, 165, 250, 0.2); }
.tech-tag[data-tech="mongodb"],
.tech-mongodb { --tech-border: rgba(34, 197, 110, 0.74); --tech-bg: rgba(34, 197, 110, 0.2); }
.tech-tag[data-tech="mongoose"],
.tech-mongoose { --tech-border: rgba(241, 90, 74, 0.74); --tech-bg: rgba(241, 90, 74, 0.2); }
.tech-tag[data-tech="mysql"],
.tech-mysql { --tech-border: rgba(245, 158, 11, 0.74); --tech-bg: rgba(245, 158, 11, 0.2); }
.tech-tag[data-tech="sequelize"],
.tech-sequelize { --tech-border: rgba(89, 177, 255, 0.74); --tech-bg: rgba(89, 177, 255, 0.2); }
.tech-tag[data-tech="sql"],
.tech-sql { --tech-border: rgba(52, 211, 153, 0.74); --tech-bg: rgba(52, 211, 153, 0.2); }
.tech-tag[data-tech="orm"],
.tech-orm { --tech-border: rgba(94, 234, 212, 0.74); --tech-bg: rgba(94, 234, 212, 0.2); }
.tech-tag[data-tech="modeling"],
.tech-modeling { --tech-border: rgba(196, 181, 253, 0.74); --tech-bg: rgba(196, 181, 253, 0.2); }
.tech-tag[data-tech="optimization"],
.tech-optimization { --tech-border: rgba(163, 230, 53, 0.74); --tech-bg: rgba(163, 230, 53, 0.2); }
.tech-tag[data-tech="sqlite"],
.tech-sqlite { --tech-border: rgba(125, 211, 252, 0.74); --tech-bg: rgba(125, 211, 252, 0.2); }

.tech-tag[data-tech="jwt"],
.tech-jwt { --tech-border: rgba(248, 113, 113, 0.74); --tech-bg: rgba(248, 113, 113, 0.2); }
.tech-tag[data-tech="oauth"],
.tech-oauth { --tech-border: rgba(251, 146, 60, 0.74); --tech-bg: rgba(251, 146, 60, 0.2); }
.tech-tag[data-tech="rbac"],
.tech-rbac { --tech-border: rgba(244, 114, 176, 0.74); --tech-bg: rgba(244, 114, 176, 0.2); }
.tech-tag[data-tech="bcrypt"],
.tech-bcrypt { --tech-border: rgba(239, 68, 68, 0.74); --tech-bg: rgba(239, 68, 68, 0.2); }

.tech-tag[data-tech="git"],
.tech-git { --tech-border: rgba(249, 115, 22, 0.74); --tech-bg: rgba(249, 115, 22, 0.2); }
.tech-tag[data-tech="docker"],
.tech-docker { --tech-border: rgba(59, 130, 246, 0.74); --tech-bg: rgba(59, 130, 246, 0.2); }
.tech-tag[data-tech="ci"],
.tech-ci { --tech-border: rgba(168, 85, 247, 0.74); --tech-bg: rgba(168, 85, 247, 0.2); }
.tech-tag[data-tech="postman"],
.tech-postman { --tech-border: rgba(255, 132, 61, 0.74); --tech-bg: rgba(255, 132, 61, 0.2); }
.tech-tag[data-tech="cli"],
.tech-cli { --tech-border: rgba(120, 140, 170, 0.74); --tech-bg: rgba(120, 140, 170, 0.2); }
.tech-tag[data-tech="figma"],
.tech-figma { --tech-border: rgba(225, 78, 202, 0.74); --tech-bg: rgba(225, 78, 202, 0.2); }
.tech-tag[data-tech="nextjs"],
.tech-nextjs { --tech-border: rgba(156, 163, 175, 0.74); --tech-bg: rgba(156, 163, 175, 0.2); }
.tech-tag[data-tech="firebase"],
.tech-firebase { --tech-border: rgba(250, 204, 21, 0.74); --tech-bg: rgba(250, 204, 21, 0.2); }
.tech-tag[data-tech="stripe"],
.tech-stripe { --tech-border: rgba(139, 92, 246, 0.74); --tech-bg: rgba(139, 92, 246, 0.2); }
.tech-tag[data-tech="chartjs"],
.tech-chartjs { --tech-border: rgba(240, 91, 135, 0.74); --tech-bg: rgba(240, 91, 135, 0.2); }
.tech-tag[data-tech="jquery"],
.tech-jquery { --tech-border: rgba(99, 102, 241, 0.74); --tech-bg: rgba(99, 102, 241, 0.2); }
.tech-tag[data-tech="inquirer"],
.tech-inquirer { --tech-border: rgba(146, 104, 255, 0.74); --tech-bg: rgba(146, 104, 255, 0.2); }
.tech-tag[data-tech="dotenv"],
.tech-dotenv { --tech-border: rgba(180, 150, 84, 0.74); --tech-bg: rgba(180, 150, 84, 0.2); }
.tech-tag[data-tech="pwa"],
.tech-pwa { --tech-border: rgba(28, 200, 170, 0.74); --tech-bg: rgba(28, 200, 170, 0.2); }
.tech-tag[data-tech="indexeddb"],
.tech-indexeddb { --tech-border: rgba(74, 149, 255, 0.74); --tech-bg: rgba(74, 149, 255, 0.2); }
.tech-tag[data-tech="serviceworker"],
.tech-serviceworker { --tech-border: rgba(116, 226, 170, 0.74); --tech-bg: rgba(116, 226, 170, 0.2); }
.tech-tag[data-tech="publicapi"],
.tech-publicapi { --tech-border: rgba(99, 224, 220, 0.74); --tech-bg: rgba(99, 224, 220, 0.2); }

.tech-tag[data-tech="ai"],
.tech-ai { --tech-border: rgba(34, 211, 238, 0.74); --tech-bg: rgba(34, 211, 238, 0.2); }
.tech-tag[data-tech="prompt"],
.tech-prompt { --tech-border: rgba(64, 201, 221, 0.74); --tech-bg: rgba(64, 201, 221, 0.2); }
.tech-tag[data-tech="rag"],
.tech-rag { --tech-border: rgba(147, 197, 253, 0.74); --tech-bg: rgba(147, 197, 253, 0.2); }
.tech-tag[data-tech="functioncalling"],
.tech-functioncalling { --tech-border: rgba(118, 176, 255, 0.74); --tech-bg: rgba(118, 176, 255, 0.2); }

.project-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  width: 100%;
  justify-content: flex-end;
  align-self: end;
  margin-top: auto;
}

.project-actions .btn {
  min-height: 46px;
  height: 46px;
  padding-block: 0;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
}

.contact-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.empty-state {
  border-radius: var(--radius-md);
  padding: 1.1rem;
}

.empty-state h3 {
  margin-bottom: 0.36rem;
}

.readiness-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.86rem;
}

.architecture-map {
  display: grid;
  grid-template-columns: repeat(7, auto);
  align-items: center;
  gap: 0.38rem;
  overflow-x: auto;
  padding-bottom: 0.15rem;
}

.arch-node {
  min-width: 160px;
  border-radius: 10px;
  padding: 0.62rem;
  font-weight: 600;
}

.arch-node small {
  display: block;
  margin-top: 0.2rem;
  font-weight: 500;
  font-size: 0.78rem;
  color: var(--muted);
}

.arch-arrow {
  color: var(--muted);
  font: 600 0.8rem var(--font-mono);
}

.api-contracts {
  display: grid;
  gap: 0.68rem;
}

.contract-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

table {
  width: 100%;
  border-collapse: collapse;
  min-width: 420px;
}

th,
td {
  border-bottom: 1px solid color-mix(in srgb, var(--line) 80%, transparent);
  text-align: left;
  padding: 0.52rem 0.46rem;
  vertical-align: top;
  font-size: 0.9rem;
}

th {
  font-size: 0.8rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.state-demo {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-bottom: 0.68rem;
}

.state-output {
  border-radius: 10px;
  padding: 0.75rem;
  min-height: 92px;
}

.state-box {
  display: grid;
  gap: 0.3rem;
}

.state-box p {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
}

.state-loading strong {
  color: #f7b54b;
}

.state-error strong {
  color: #ff7d7d;
}

.state-success strong {
  color: #5fe4a0;
}

.prototype-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--grid-gap-major);
}

.prototype-card {
  display: grid;
  gap: var(--grid-gap-minor);
  align-content: start;
}

.panel-headline {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.6rem;
}

.status-label {
  display: inline-flex;
  align-items: center;
  padding: 0.24rem 0.55rem;
  border-radius: 999px;
  font-size: 0.73rem;
  font-weight: 700;
  border: 1px solid color-mix(in srgb, var(--accent-3) 44%, transparent);
  background: color-mix(in srgb, var(--accent-3) 16%, transparent);
  color: color-mix(in srgb, var(--text) 78%, var(--accent-3));
}

.chat-thread {
  border-radius: 12px;
  min-height: 180px;
  max-height: 230px;
  overflow: auto;
  padding: 0.72rem;
  display: grid;
  gap: var(--grid-gap-minor);
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  background:
    radial-gradient(circle at 82% 8%, color-mix(in srgb, var(--accent-2) 12%, transparent), transparent 55%),
    color-mix(in srgb, var(--glass-bg-soft) 96%, transparent);
}

.chat-message {
  max-width: 86%;
  padding: 0.56rem 0.7rem;
  border-radius: 14px;
  font-size: 0.9rem;
  line-height: 1.48;
  color: var(--text);
}

.chat-assistant {
  justify-self: start;
  border: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  background: color-mix(in srgb, var(--bg-2) 74%, var(--glass-bg-soft));
}

.chat-user {
  justify-self: end;
  border: 1px solid color-mix(in srgb, var(--accent-2) 58%, transparent);
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent-1) 44%, transparent), color-mix(in srgb, var(--accent-2) 36%, transparent));
  color: var(--accent-ink);
}

.match-shell {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.7rem;
  align-items: center;
  border: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  border-radius: 12px;
  padding: 0.72rem;
  background: color-mix(in srgb, var(--glass-bg-soft) 94%, transparent);
}

.score-ring {
  --score: 0;
  width: 86px;
  height: 86px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  position: relative;
  background: conic-gradient(var(--accent-2) calc(var(--score) * 1%), color-mix(in srgb, var(--line) 46%, transparent) 0);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--line) 78%, transparent);
}

.score-ring::before {
  content: "";
  position: absolute;
  inset: 8px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--glass-bg) 92%, transparent);
  border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
}

.score-ring span {
  position: relative;
  font: 700 1rem/1 var(--font-mono);
}

.match-columns {
  display: grid;
  gap: var(--grid-gap-minor);
}

.match-columns h4 {
  margin: 0 0 0.28rem;
  font-size: 0.79rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--muted);
}

.tag.tag-good {
  border-color: rgba(111, 221, 147, 0.65);
  background: rgba(74, 186, 113, 0.22);
}

.tag.tag-gap {
  border-color: rgba(255, 155, 155, 0.62);
  background: rgba(255, 123, 123, 0.18);
}

.summary-output {
  border: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  border-radius: 12px;
  min-height: 150px;
  padding: 0.72rem;
  background: color-mix(in srgb, var(--glass-bg-soft) 94%, transparent);
  display: grid;
  gap: 0.6rem;
}

.summary-card {
  border: 1px solid color-mix(in srgb, var(--line) 76%, transparent);
  border-radius: 10px;
  padding: 0.56rem;
  background: color-mix(in srgb, var(--glass-bg-soft) 90%, transparent);
}

.summary-card h4 {
  margin: 0 0 0.34rem;
  font-size: 0.86rem;
}

.summary-card p,
.summary-card li {
  margin: 0;
  font-size: 0.84rem;
  color: var(--muted);
}

.summary-card ul {
  margin: 0;
  padding-left: 1rem;
}

.summary-sources {
  display: flex;
  flex-wrap: wrap;
  gap: 0.34rem;
}

.source-pill {
  border-radius: 999px;
  padding: 0.18rem 0.52rem;
  border: 1px solid color-mix(in srgb, var(--accent-3) 52%, transparent);
  background: color-mix(in srgb, var(--accent-3) 18%, transparent);
  font-size: 0.74rem;
  font-weight: 600;
}

.component-config-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--grid-gap-minor);
}

.component-pick-grid {
  margin: 0;
  border: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  border-radius: 12px;
  padding: 0.6rem;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.36rem;
}

.component-pick-grid legend {
  padding: 0 0.3rem;
  font-size: 0.76rem;
  color: var(--muted);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.component-check {
  display: flex;
  align-items: center;
  gap: 0.34rem;
  border: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  background: color-mix(in srgb, var(--glass-bg-soft) 88%, transparent);
  border-radius: 10px;
  padding: 0.35rem 0.44rem;
  font-size: 0.76rem;
}

.component-check input {
  accent-color: var(--accent-2);
}

.component-output {
  border: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  border-radius: 12px;
  min-height: 140px;
  padding: 0.65rem;
  background: color-mix(in srgb, var(--glass-bg-soft) 94%, transparent);
  display: grid;
  gap: var(--grid-gap-minor);
}

.component-board {
  --component-accent: var(--accent-2);
  display: grid;
  gap: 0.54rem;
}

.component-board-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 0.56rem;
  flex-wrap: wrap;
}

.component-board-head strong {
  font-size: 0.84rem;
}

.component-board-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.52rem;
}

.component-tile {
  border: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  border-radius: 12px;
  padding: 0.52rem;
  background: linear-gradient(
    150deg,
    color-mix(in srgb, var(--component-accent) 10%, var(--glass-bg-soft)),
    color-mix(in srgb, var(--glass-bg-soft) 90%, transparent)
  );
  display: grid;
  gap: 0.34rem;
}

.component-tile h4 {
  margin: 0;
  font-size: 0.78rem;
}

.component-mock {
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  background: color-mix(in srgb, var(--glass-bg) 90%, transparent);
  padding: 0.46rem;
  min-height: 52px;
  display: grid;
  align-items: center;
}

.component-ui-btn-row {
  display: flex;
  gap: 0.32rem;
}

.component-ui-btn {
  border: 1px solid color-mix(in srgb, var(--component-accent) 58%, transparent);
  background: color-mix(in srgb, var(--component-accent) 26%, transparent);
  color: var(--text);
  font-size: 0.68rem;
  border-radius: 999px;
  padding: 0.2rem 0.48rem;
}

.component-ui-btn.ghost {
  background: transparent;
}

.component-ui-input {
  height: 16px;
  border: 1px solid color-mix(in srgb, var(--line) 68%, transparent);
  border-radius: 999px;
  background: color-mix(in srgb, var(--line) 42%, transparent);
}

.component-ui-input.short {
  width: 60%;
  margin-top: 0.28rem;
}

.component-ui-card {
  border: 1px solid color-mix(in srgb, var(--component-accent) 52%, transparent);
  border-radius: 10px;
  padding: 0.36rem 0.42rem;
  display: grid;
  gap: 0.14rem;
}

.component-ui-card strong {
  font-size: 0.7rem;
}

.component-ui-card span {
  font-size: 0.66rem;
  color: var(--muted);
}

.component-ui-tabs {
  display: flex;
  gap: 0.24rem;
  flex-wrap: wrap;
}

.component-ui-tabs span {
  border: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  border-radius: 999px;
  padding: 0.16rem 0.42rem;
  font-size: 0.66rem;
}

.component-ui-tabs .active {
  border-color: color-mix(in srgb, var(--component-accent) 54%, transparent);
  background: color-mix(in srgb, var(--component-accent) 22%, transparent);
}

.component-ui-navbar {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 0.3rem;
  align-items: center;
  font-size: 0.66rem;
}

.component-ui-navbar .brand {
  font-weight: 700;
}

.component-ui-table {
  display: grid;
  gap: 0.2rem;
}

.component-ui-table i {
  display: block;
  height: 8px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--line) 70%, transparent);
}

.component-ui-tooltip {
  position: relative;
  display: inline-grid;
  gap: 0.2rem;
}

.component-ui-tooltip span {
  font-size: 0.66rem;
}

.component-ui-tooltip small {
  font-size: 0.62rem;
  border: 1px solid color-mix(in srgb, var(--component-accent) 50%, transparent);
  background: color-mix(in srgb, var(--component-accent) 20%, transparent);
  border-radius: 8px;
  padding: 0.16rem 0.35rem;
}

.component-ui-modal {
  border: 1px solid color-mix(in srgb, var(--line) 74%, transparent);
  border-radius: 10px;
  padding: 0.34rem 0.4rem;
  display: grid;
  gap: 0.14rem;
}

.component-ui-modal strong {
  font-size: 0.7rem;
}

.component-ui-modal span {
  font-size: 0.65rem;
  color: var(--muted);
}

.component-ui-toast {
  border: 1px solid color-mix(in srgb, var(--component-accent) 56%, transparent);
  background: color-mix(in srgb, var(--component-accent) 22%, transparent);
  border-radius: 999px;
  padding: 0.2rem 0.4rem;
  font-size: 0.66rem;
  width: max-content;
}

.component-ui-accordion {
  display: grid;
  gap: 0.24rem;
}

.component-ui-accordion span {
  border: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  border-radius: 8px;
  padding: 0.2rem 0.38rem;
  font-size: 0.66rem;
}

.component-ui-accordion .open {
  border-color: color-mix(in srgb, var(--component-accent) 54%, transparent);
  background: color-mix(in srgb, var(--component-accent) 18%, transparent);
}

.component-ui-dropdown {
  display: grid;
  gap: 0.16rem;
}

.component-ui-dropdown span {
  border: 1px solid color-mix(in srgb, var(--line) 74%, transparent);
  border-radius: 999px;
  padding: 0.2rem 0.38rem;
  font-size: 0.66rem;
}

.component-ui-dropdown i {
  width: 6px;
  height: 6px;
  border-right: 1px solid var(--muted);
  border-bottom: 1px solid var(--muted);
  transform: rotate(45deg);
  justify-self: end;
  margin-right: 0.34rem;
}

.component-ui-dropdown small {
  font-size: 0.62rem;
  color: var(--muted);
}

.component-ui-pagination {
  display: flex;
  flex-wrap: wrap;
  gap: 0.2rem;
}

.component-ui-pagination span {
  border: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  border-radius: 999px;
  padding: 0.1rem 0.3rem;
  font-size: 0.64rem;
}

.component-ui-pagination .active {
  border-color: color-mix(in srgb, var(--component-accent) 56%, transparent);
  background: color-mix(in srgb, var(--component-accent) 20%, transparent);
}

.component-ui-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.18rem;
  font-size: 0.64rem;
}

.component-ui-breadcrumb i {
  color: var(--muted);
}

.component-ui-breadcrumb .active {
  color: color-mix(in srgb, var(--component-accent) 74%, var(--text));
  font-weight: 700;
}

.component-ui-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.18rem;
}

.component-ui-badges span {
  border: 1px solid color-mix(in srgb, var(--component-accent) 58%, transparent);
  background: color-mix(in srgb, var(--component-accent) 20%, transparent);
  border-radius: 999px;
  padding: 0.12rem 0.34rem;
  font-size: 0.62rem;
}

.component-ui-avatar {
  display: inline-grid;
  justify-items: center;
  gap: 0.18rem;
}

.component-ui-avatar i {
  width: 26px;
  height: 26px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--component-accent) 56%, transparent);
  background: linear-gradient(135deg, color-mix(in srgb, var(--component-accent) 28%, transparent), transparent);
}

.component-ui-avatar small {
  font-size: 0.62rem;
  color: var(--muted);
}

.component-ui-progress {
  display: grid;
  gap: 0.2rem;
}

.component-ui-progress small {
  font-size: 0.62rem;
  color: var(--muted);
}

.component-ui-progress i {
  display: block;
  height: 8px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  overflow: hidden;
}

.component-ui-progress b {
  display: block;
  width: 62%;
  height: 100%;
  background: linear-gradient(90deg, var(--component-accent), color-mix(in srgb, var(--component-accent) 56%, white));
}

.component-ui-sidebar {
  display: grid;
  gap: 0.2rem;
}

.component-ui-sidebar span {
  border: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  border-radius: 8px;
  padding: 0.16rem 0.34rem;
  font-size: 0.64rem;
}

.component-ui-sidebar .active {
  border-color: color-mix(in srgb, var(--component-accent) 56%, transparent);
  background: color-mix(in srgb, var(--component-accent) 18%, transparent);
}

.component-ui-form {
  display: grid;
  gap: 0.18rem;
}

.component-ui-form i {
  display: block;
  height: 8px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  background: color-mix(in srgb, var(--line) 42%, transparent);
}

.component-ui-form i.short {
  width: 56%;
}

.component-ui-form button {
  border: 1px solid color-mix(in srgb, var(--component-accent) 56%, transparent);
  background: color-mix(in srgb, var(--component-accent) 24%, transparent);
  color: var(--text);
  border-radius: 999px;
  font-size: 0.62rem;
  width: max-content;
  padding: 0.12rem 0.4rem;
}

.wall-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.58fr) minmax(260px, 0.9fr);
  grid-template-rows: auto auto;
  gap: var(--grid-gap-major);
  align-items: stretch;
  min-height: 0;
}

.wall-grid > .panel {
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}

.wall-form-panel {
  grid-column: 1 / 2;
  grid-row: 1 / 2;
  overflow: hidden;
  padding-right: 0;
  padding-bottom: 0;
  scrollbar-gutter: auto;
}

.wall-form-panel::-webkit-scrollbar {
  width: 8px;
}

.wall-form-panel::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent-2) 40%, transparent);
}

.wall-form-panel::-webkit-scrollbar-track {
  background: color-mix(in srgb, var(--line) 22%, transparent);
}

.visitor-form {
  display: block;
  min-height: 100%;
  overflow: visible;
  padding: 0;
}

.visitor-form-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 0.58rem;
  align-items: stretch;
  min-height: 100%;
}

.visitor-form-layout:not(.is-greeting-mode) {
  grid-template-columns: 1fr;
}

.visitor-form-main,
.visitor-form-side {
  display: grid;
  gap: var(--grid-gap-minor);
  align-content: start;
  min-height: 0;
}

.visitor-form-main {
  padding-right: 0.08rem;
}

.visitor-form-layout:not(.is-greeting-mode) .visitor-form-main {
  padding-right: 0;
}

.visitor-form-side {
  padding-left: 0.08rem;
  align-self: stretch;
  align-content: stretch;
  height: 100%;
}

.visitor-form-layout:not(.is-greeting-mode) .visitor-form-side {
  display: none;
}

.visitor-form label {
  display: grid;
  gap: 0.28rem;
}

.visitor-form-actions {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.42rem;
  grid-column: 1 / 2;
  margin-bottom: 0.08rem;
  align-self: start;
}

.visitor-form-actions .btn {
  min-height: 42px;
}

.visitor-form-layout:not(.is-greeting-mode) .visitor-form-actions {
  grid-column: 1 / -1;
  justify-self: center;
  width: min(420px, 100%);
}

.visitor-form-layout.is-greeting-mode .visitor-form-actions {
  grid-column: 1 / -1;
  justify-self: center;
  width: min(360px, 100%);
}

.wall-status-capsule {
  margin: 0.08rem 0 0;
  min-height: 1.68rem;
  padding: 0.18rem 0.62rem;
  border-radius: 999px;
  border: 1px solid transparent;
  display: inline-flex;
  align-items: center;
  width: fit-content;
  grid-column: 1 / 2;
  justify-self: start;
  font-size: 0.77rem;
  line-height: 1.2;
  opacity: 0;
  transform: translateY(4px);
  transition:
    opacity var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease),
    border-color var(--motion-fast) var(--motion-ease),
    background var(--motion-fast) var(--motion-ease);
}

.wall-status-capsule:not(:empty) {
  opacity: 1;
  transform: translateY(0);
}

.wall-status-capsule[data-state="success"] {
  border-color: color-mix(in srgb, #52d9a4 56%, transparent);
  background: color-mix(in srgb, #52d9a4 16%, transparent);
  color: color-mix(in srgb, var(--text) 88%, #b9ffe4 12%);
}

.wall-status-capsule[data-state="info"] {
  border-color: color-mix(in srgb, var(--accent-2) 54%, transparent);
  background: color-mix(in srgb, var(--accent-2) 14%, transparent);
  color: color-mix(in srgb, var(--text) 90%, white 10%);
}

.wall-status-capsule[data-state="warn"] {
  border-color: color-mix(in srgb, #ff9d68 62%, transparent);
  background: color-mix(in srgb, #ff9d68 16%, transparent);
  color: color-mix(in srgb, var(--text) 88%, #ffd8b8 12%);
}

.visitor-form-layout.is-greeting-mode .wall-status-capsule {
  grid-column: 1 / -1;
  justify-self: center;
}

.visitor-form-layout:not(.is-greeting-mode) .wall-status-capsule {
  grid-column: 1 / -1;
}

.visitor-message-counter {
  margin: -0.24rem 0 0;
  text-align: right;
}

.visitor-form-main .visitor-message-counter {
  margin-top: -0.18rem;
}

.visitor-type-row {
  margin: 0;
  border: 1px solid color-mix(in srgb, var(--line) 80%, transparent);
  border-radius: 12px;
  background: color-mix(in srgb, var(--glass-bg-soft) 92%, transparent);
  padding: 0.46rem 0.58rem 0.58rem;
  display: grid;
  gap: 0.42rem;
}

.visitor-type-row legend {
  padding: 0 0.2rem;
  font-size: 0.74rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--muted);
}

.visitor-type-options {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.38rem;
}

.visitor-type-option {
  position: relative;
  display: block;
  min-width: 0;
  cursor: pointer;
}

.visitor-type-option input {
  position: absolute;
  inset: 0;
  width: 1px;
  height: 1px;
  margin: 0;
  opacity: 0;
  pointer-events: none;
}

.visitor-type-option-card {
  display: flex;
  align-items: center;
  gap: 0.46rem;
  min-height: 48px;
  border-radius: 11px;
  border: 1px solid color-mix(in srgb, var(--line) 76%, transparent);
  padding: 0.52rem 0.6rem;
  background: color-mix(in srgb, var(--bg-2) 44%, transparent);
  transition:
    border-color var(--motion-fast) var(--motion-ease),
    background var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease);
}

.visitor-type-option-icon {
  width: 26px;
  height: 26px;
  border-radius: 8px;
  border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.86rem;
  line-height: 1;
  color: color-mix(in srgb, var(--text) 86%, white 14%);
  background: color-mix(in srgb, var(--line) 26%, transparent);
}

.visitor-type-option-label {
  min-width: 0;
  font-size: 0.84rem;
  font-weight: 600;
  color: color-mix(in srgb, var(--text) 90%, white 10%);
}

.visitor-type-option input:checked + .visitor-type-option-card {
  border-color: color-mix(in srgb, var(--accent-2) 68%, transparent);
  background:
    linear-gradient(130deg, color-mix(in srgb, var(--accent-2) 20%, transparent), transparent 58%),
    color-mix(in srgb, var(--bg-2) 52%, transparent);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--accent-2) 24%, transparent),
    0 8px 14px color-mix(in srgb, var(--accent-2) 20%, transparent);
}

.visitor-type-option:hover .visitor-type-option-card {
  border-color: color-mix(in srgb, var(--accent-2) 56%, transparent);
  transform: translateY(var(--interactive-lift));
  box-shadow: var(--interactive-shadow);
  background: color-mix(in srgb, var(--bg-2) 56%, transparent);
}

.visitor-type-option:focus-within .visitor-type-option-card {
  border-color: color-mix(in srgb, var(--accent-2) 56%, transparent);
  transform: translateY(var(--interactive-lift));
  box-shadow: var(--interactive-shadow);
  background: color-mix(in srgb, var(--bg-2) 56%, transparent);
}

.visitor-type-option input:checked + .visitor-type-option-card .visitor-type-option-icon {
  border-color: color-mix(in srgb, var(--accent-2) 66%, transparent);
  background: color-mix(in srgb, var(--accent-2) 24%, transparent);
}

.visitor-type-option input:focus-visible + .visitor-type-option-card {
  outline: none;
  box-shadow:
    0 0 0 2px color-mix(in srgb, var(--accent-2) 34%, transparent),
    0 8px 14px color-mix(in srgb, var(--accent-2) 16%, transparent);
}

.visitor-drawing-section {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 0.5rem;
  padding: 0.52rem;
  border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--line) 80%, transparent);
  background:
    radial-gradient(circle at 10% 8%, color-mix(in srgb, var(--accent-2) 16%, transparent), transparent 48%),
    color-mix(in srgb, var(--glass-bg-soft) 90%, transparent);
  transition:
    opacity var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease),
    max-height var(--motion-fast) var(--motion-ease),
    padding var(--motion-fast) var(--motion-ease),
    margin var(--motion-fast) var(--motion-ease);
  height: 100%;
}

.visitor-drawing-section.is-hidden {
  opacity: 0;
  transform: translateY(-6px);
  max-height: 0;
  margin: 0;
  padding: 0;
  border: 0;
  overflow: hidden;
}

.drawing-toolbar {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 0.4rem;
  align-items: center;
}

.drawing-color-wrap {
  display: grid;
  gap: 0.18rem;
  font-size: 0.74rem;
  color: var(--muted);
}

#visitorDrawColor {
  width: 38px;
  height: 30px;
  border-radius: 8px;
  border: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  padding: 0;
  background: transparent;
  cursor: pointer;
}

.drawing-swatches {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.28rem;
}

.drawing-swatch {
  width: 18px;
  height: 18px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--line) 68%, transparent);
  background: var(--swatch);
  cursor: pointer;
  box-shadow: inset 0 1px 0 color-mix(in srgb, white 22%, transparent);
  transition:
    transform var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease);
}

.drawing-swatch.is-active {
  transform: scale(1.16);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--accent-2) 42%, transparent),
    0 0 0 4px color-mix(in srgb, var(--accent-2) 20%, transparent);
}

.drawing-clear {
  min-height: 30px;
  padding-inline: 0.62rem;
}

.visitor-greeting-canvas {
  width: 100%;
  min-height: 252px;
  height: 100%;
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, var(--line) 74%, transparent);
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--accent-1) 8%, transparent), transparent 52%),
    repeating-linear-gradient(
      0deg,
      color-mix(in srgb, var(--line) 18%, transparent) 0,
      color-mix(in srgb, var(--line) 18%, transparent) 1px,
      transparent 1px,
      transparent 18px
    ),
    color-mix(in srgb, var(--bg-2) 62%, transparent);
  cursor: crosshair;
  touch-action: none;
}

.wall-map-panel {
  grid-column: 1 / 2;
  grid-row: 2 / 3;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.54rem;
  align-self: stretch;
  padding: 0.72rem 0.84rem 0.82rem;
}

.wall-greetings-panel {
  grid-column: 2 / 3;
  grid-row: 1 / 3;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 0.3rem;
  align-self: stretch;
}

.wall-greetings-panel .panel-headline {
  margin: 0;
  padding-inline: 0.08rem;
}

.wall-greetings-panel .panel-headline h3 {
  margin: 0;
}

.map-sphere-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1 1 auto;
  width: 100%;
  min-height: 0;
}

.map-sphere {
  position: relative;
  width: min(100%, clamp(186px, 30vw, 266px));
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  border: 1px solid color-mix(in srgb, var(--line) 74%, transparent);
  background: radial-gradient(circle at 50% 44%, color-mix(in srgb, var(--accent-2) 26%, transparent), transparent 70%);
  overflow: hidden;
  cursor: grab;
  box-shadow:
    inset -28px -20px 48px rgba(6, 8, 20, 0.36),
    inset 18px 14px 34px rgba(255, 255, 255, 0.08);
}

.map-sphere:active {
  cursor: grabbing;
}

.globe-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.sphere-glow {
  position: absolute;
  inset: 6% 10% auto;
  height: 32%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.26), transparent 72%);
  filter: blur(12px);
  pointer-events: none;
}

.sphere-shade {
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 76% 66%, rgba(5, 8, 20, 0.34), transparent 48%);
  pointer-events: none;
}

.map-hint {
  margin: 0;
  width: fit-content;
  max-width: 100%;
  text-align: center;
  align-self: center;
}

.visitor-map-pins {
  position: absolute;
  inset: 0;
}

.map-pin {
  position: absolute;
  width: 12px;
  height: 12px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.78);
  background: linear-gradient(140deg, #83ecff, #6f8eff);
  box-shadow: 0 0 0 0 color-mix(in srgb, var(--accent-2) 42%, transparent);
  animation: pin-pulse 2.2s ease-out infinite;
  cursor: pointer;
  transform: translate(-50%, -50%);
  transition:
    transform var(--motion-fast) var(--motion-ease),
    opacity var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease);
}

.map-pin-greeting {
  background: linear-gradient(145deg, #83ecff, #6f8eff);
}

.map-pin-testimonial {
  background: linear-gradient(140deg, #ffd38a, #ff8b9b);
}

.map-pin.active {
  animation-play-state: paused;
  box-shadow:
    0 0 0 8px color-mix(in srgb, var(--accent-2) 22%, transparent),
    0 0 16px color-mix(in srgb, var(--accent-2) 32%, transparent);
  border-color: #fff;
}

@keyframes pin-pulse {
  0% {
    box-shadow: 0 0 0 0 color-mix(in srgb, var(--accent-2) 44%, transparent);
  }
  100% {
    box-shadow: 0 0 0 14px rgba(0, 0, 0, 0);
  }
}

.wall-list {
  --wall-card-height: 206px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(132px, 1fr));
  align-content: start;
  gap: var(--grid-gap-minor);
  min-height: calc(var(--wall-card-height) + var(--grid-gap-minor));
  max-height: calc((var(--wall-card-height) * 4) + (var(--grid-gap-minor) * 3) + 0.08rem);
  height: auto;
  overflow-y: auto;
  overflow-x: hidden;
  padding-right: 0.24rem;
  scrollbar-gutter: stable both-edges;
}

.wall-list::-webkit-scrollbar {
  width: 8px;
}

.wall-list::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent-2) 40%, transparent);
}

.wall-list::-webkit-scrollbar-track {
  background: color-mix(in srgb, var(--line) 20%, transparent);
}

.wall-entry {
  --entry-card-height: var(--wall-card-height, 206px);
  border-radius: 11px;
  padding: 0.54rem;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  grid-template-rows: minmax(0, 1fr) minmax(90px, 0.98fr);
  gap: 0.44rem;
  align-items: stretch;
  height: var(--entry-card-height);
  min-height: var(--entry-card-height);
  max-height: var(--entry-card-height);
  cursor: pointer;
  transition:
    border-color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease);
}

.wall-entry:hover {
  border-color: color-mix(in srgb, var(--accent-2) 56%, transparent);
  box-shadow: 0 14px 22px color-mix(in srgb, var(--accent-2) 16%, transparent);
  transform: translateY(-2px);
}

.wall-entry.is-selected {
  border-color: color-mix(in srgb, var(--accent-1) 62%, transparent);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--accent-1) 26%, transparent),
    0 16px 24px color-mix(in srgb, var(--accent-1) 16%, transparent);
}

.wall-entry-copy {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 0.26rem;
  min-height: 0;
}

.wall-meta {
  display: grid;
  gap: 0.08rem;
  margin: 0;
}

.wall-entry-name {
  font-size: 0.94rem;
  line-height: 1.18;
  color: color-mix(in srgb, var(--text) 96%, white 4%);
}

.wall-entry-message {
  margin: 0;
  color: var(--muted);
  font-size: 0.84rem;
  font-style: normal;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.wall-entry-meta {
  margin: 0;
  margin-top: auto;
  font-size: 0.72rem;
  color: color-mix(in srgb, var(--muted) 90%, white 10%);
}

.wall-entry-sketch {
  position: relative;
  border-radius: 10px;
  border: 1px dashed color-mix(in srgb, var(--line) 68%, transparent);
  background:
    linear-gradient(140deg, color-mix(in srgb, var(--line) 18%, transparent), transparent 54%),
    color-mix(in srgb, var(--bg-2) 36%, transparent);
  min-height: 90px;
  height: 100%;
  display: grid;
  place-items: center;
  overflow: hidden;
}

.wall-entry-sketch.has-drawing {
  border-style: solid;
}

.wall-entry-sketch img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.wall-entry-sketch .tiny {
  margin: 0;
  font-size: 0.7rem;
  line-height: 1.35;
  text-align: center;
  color: color-mix(in srgb, var(--muted) 88%, white 12%);
  padding: 0.42rem;
}

.wall-entry-sketch .visitor-entry-actions {
  position: absolute;
  right: 0.34rem;
  bottom: 0.34rem;
  z-index: 4;
  width: auto;
  align-self: auto;
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}

.visitor-entry-actions {
  display: inline-flex;
  flex-wrap: nowrap;
  gap: 0.36rem;
  margin-top: 0.22rem;
}

.entry-action-btn {
  width: 46px;
  min-width: 46px;
  min-height: 46px;
  padding: 0;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-color: color-mix(in srgb, var(--line) 84%, transparent);
  background: linear-gradient(
    145deg,
    color-mix(in srgb, var(--bg-3) 58%, transparent),
    color-mix(in srgb, var(--bg-2) 58%, transparent)
  );
  color: color-mix(in srgb, var(--text) 90%, white 10%);
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, white 14%, transparent),
    0 8px 14px color-mix(in srgb, var(--bg-1) 28%, transparent);
  transition:
    transform var(--motion-fast) var(--motion-ease),
    border-color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    background var(--motion-fast) var(--motion-ease);
}

.entry-action-btn.chip:hover {
  transform: translateY(-1px) scale(1.03);
  border-color: color-mix(in srgb, var(--accent-2) 56%, transparent);
  background: color-mix(in srgb, var(--accent-2) 16%, transparent);
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, white 18%, transparent),
    0 10px 16px color-mix(in srgb, var(--accent-2) 22%, transparent);
}

.entry-action-btn.chip:focus-visible {
  outline: none;
  box-shadow:
    0 0 0 2px color-mix(in srgb, var(--accent-2) 36%, transparent),
    0 8px 14px color-mix(in srgb, var(--accent-2) 22%, transparent);
}

.entry-action-btn.danger {
  border-color: color-mix(in srgb, #ff7e92 62%, transparent);
  color: color-mix(in srgb, #ffd2d9 92%, white 8%);
  background: linear-gradient(
    145deg,
    color-mix(in srgb, #ff7e92 20%, transparent),
    color-mix(in srgb, #ff5978 14%, transparent)
  );
}

.entry-action-btn.is-armed {
  border-color: color-mix(in srgb, #ffb46a 72%, transparent);
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, white 24%, transparent),
    0 0 0 2px color-mix(in srgb, #ffb46a 26%, transparent),
    0 10px 16px color-mix(in srgb, #ff8f5a 20%, transparent);
}

.entry-action-btn svg {
  width: 24px;
  height: 24px;
  flex: 0 0 auto;
}

.testimonials-panel {
  margin-top: 1.08rem;
  padding: 0.12rem 0 0;
  overflow: visible;
  border: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  display: grid;
  gap: 0.62rem;
}

.testimonials-panel .panel-headline {
  margin-bottom: 0;
  padding-inline: 0.18rem;
}

.testimonials-panel .panel-headline h3 {
  margin-bottom: 0;
}

.testimonial-list {
  display: grid;
  gap: 0.34rem;
  justify-items: stretch;
}

.testimonial-stage {
  display: grid;
  width: min(724px, 86vw);
  margin-inline: auto;
  grid-template-columns: 40px minmax(132px, 168px) minmax(206px, 232px) minmax(132px, 168px) 40px;
  gap: 0.22rem;
  align-items: stretch;
  justify-content: center;
  touch-action: pan-y;
}

.testimonial-nav {
  width: 40px;
  min-width: 40px;
  min-height: 282px;
  padding: 0;
  border: 0;
  background: transparent;
  color: color-mix(in srgb, var(--text) 34%, transparent);
  box-shadow: none;
  display: flex;
  align-items: center;
  justify-content: center;
  align-self: stretch;
  transition:
    transform var(--motion-fast) var(--motion-ease),
    color var(--motion-fast) var(--motion-ease),
    opacity var(--motion-fast) var(--motion-ease);
}

.testimonial-nav svg {
  width: 44px;
  height: 44px;
  opacity: 0.72;
}

.testimonial-nav svg path {
  stroke-width: 3.35;
}

.testimonial-nav:hover:not([disabled]) {
  transform: translateY(-1px) scale(1.16);
  color: color-mix(in srgb, var(--text) 84%, transparent);
}

.testimonial-nav[disabled] {
  opacity: 0.14;
  cursor: default;
}

.testimonial-stage.is-forward .testimonial-item {
  animation: testimonial-shift-forward 720ms cubic-bezier(0.16, 1, 0.3, 1);
}

.testimonial-stage.is-backward .testimonial-item {
  animation: testimonial-shift-backward 720ms cubic-bezier(0.16, 1, 0.3, 1);
}

@keyframes testimonial-shift-forward {
  0% {
    opacity: 0.06;
    transform: translateX(20px) scale(0.96);
  }
  100% {
    opacity: 1;
    transform: translateX(0) scale(1);
  }
}

@keyframes testimonial-shift-backward {
  0% {
    opacity: 0.06;
    transform: translateX(-20px) scale(0.96);
  }
  100% {
    opacity: 1;
    transform: translateX(0) scale(1);
  }
}

.testimonial-item {
  position: relative;
  margin: 0;
  padding: 0.68rem 0.62rem 0.54rem;
  border: 1px solid color-mix(in srgb, var(--line) 74%, transparent);
  border-radius: 18px;
  background: linear-gradient(150deg, color-mix(in srgb, var(--bg-3) 70%, transparent), color-mix(in srgb, var(--bg-2) 56%, transparent));
  backdrop-filter: blur(9px);
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, white 16%, transparent),
    0 16px 24px color-mix(in srgb, var(--bg-1) 28%, transparent);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto auto;
  gap: 0.48rem;
  cursor: pointer;
  justify-self: center;
  overflow: hidden;
  isolation: isolate;
  will-change: transform, opacity;
  transition:
    transform var(--motion-fast) var(--motion-ease),
    border-color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    opacity var(--motion-fast) var(--motion-ease);
}

.testimonial-item > * {
  position: relative;
  z-index: 2;
}

.testimonial-item::before {
  content: none;
}

.testimonial-item::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(120deg, transparent 5%, rgba(255, 255, 255, 0.16) 38%, transparent 66%);
  transform: translateX(-125%);
  transition: transform 0.7s ease;
}

.testimonial-main {
  width: min(232px, 100%);
  max-width: 232px;
  min-height: 282px;
  aspect-ratio: 3 / 4;
}

.testimonial-side {
  width: min(168px, 100%);
  max-width: 168px;
  min-height: 244px;
  aspect-ratio: 5 / 8;
  opacity: 0.52;
}

.testimonial-side-left {
  transform-origin: right center;
}

.testimonial-side-right {
  transform-origin: left center;
}

.testimonial-side.is-empty {
  opacity: 0;
  pointer-events: none;
}

.testimonial-item:hover {
  transform: translateY(-2px) scale(var(--testimonial-scale-current, 1));
  border-color: color-mix(in srgb, var(--accent-2) 56%, transparent);
  box-shadow: 0 14px 22px color-mix(in srgb, var(--accent-2) 16%, transparent);
}

.testimonial-item:focus-visible {
  outline: none;
}

.testimonial-item:focus-visible .testimonial-line-text {
  color: color-mix(in srgb, var(--text) 96%, white 4%);
}

.testimonial-item.is-selected {
  opacity: 1;
  border-color: color-mix(in srgb, var(--line) 74%, transparent);
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, white 16%, transparent),
    0 16px 24px color-mix(in srgb, var(--bg-1) 28%, transparent);
  animation: none;
}

.testimonial-line-head {
  display: grid;
  gap: 0.12rem;
  align-content: start;
}

.testimonial-name-pill {
  display: inline-flex;
  align-items: center;
  justify-self: start;
  border-radius: 999px;
  padding: 0.2rem 0.68rem;
  border: 1px solid color-mix(in srgb, var(--accent-2) 68%, transparent);
  background:
    linear-gradient(140deg, color-mix(in srgb, var(--accent-2) 28%, transparent), color-mix(in srgb, var(--accent-1) 18%, transparent));
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, white 20%, transparent),
    0 8px 14px color-mix(in srgb, var(--accent-2) 18%, transparent);
  color: color-mix(in srgb, var(--text) 98%, white 2%);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.05;
}

.testimonial-line-meta {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.34rem;
  line-height: 1.3;
  justify-self: start;
  align-self: end;
}

.testimonial-line-city {
  color: color-mix(in srgb, var(--text) 84%, white 16%);
  font-size: 0.82rem;
  font-weight: 600;
}

.testimonial-line-date {
  color: color-mix(in srgb, var(--muted) 86%, white 14%);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.035em;
}

.testimonial-line-date::before {
  content: "-";
  display: inline-block;
  margin-right: 0.28rem;
  opacity: 0.76;
}

.testimonial-line-text {
  margin: 0;
  color: color-mix(in srgb, var(--text) 95%, white 5%);
  font-size: 0.92rem;
  line-height: 1.55;
  font-weight: 500;
  font-style: italic;
  padding-left: 0.01rem;
  text-wrap: pretty;
  max-width: none;
}

.testimonial-main .testimonial-line-text {
  font-size: 1rem;
  line-height: 1.6;
  letter-spacing: 0.01em;
  max-width: none;
}

.testimonial-main .testimonial-line-meta {
  gap: 0.4rem;
}

.testimonial-main .testimonial-line-city {
  font-size: 0.84rem;
}

.testimonial-main .testimonial-line-date {
  font-size: 0.72rem;
}

.testimonial-side .testimonial-name-pill {
  font-size: 0.72rem;
  padding: 0.14rem 0.5rem;
}

.testimonial-side .testimonial-line-city {
  font-size: 0.72rem;
}

.testimonial-side .testimonial-line-date {
  font-size: 0.66rem;
}

.testimonial-side .testimonial-line-text {
  color: color-mix(in srgb, var(--muted) 82%, white 18%);
  font-size: 0.76rem;
  line-height: 1.42;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Carousel motion and transparency override */
.testimonial-stage {
  --testimonial-gap: 0.22rem;
  --testimonial-slot: clamp(156px, 21.5vw, 214px);
  --testimonial-visible: 3;
  --testimonial-base-shift: 1;
  --testimonial-shift-unit: calc(var(--testimonial-slot) + var(--testimonial-gap));
  --testimonial-drag-delta: 0px;
  --testimonial-duration: 1200ms;
  display: grid;
  width: min(100%, 840px);
  margin-inline: auto;
  grid-template-columns: 40px minmax(0, 1fr) 40px;
  gap: 0.22rem;
  align-items: stretch;
  justify-content: center;
  touch-action: pan-y;
}

.testimonial-viewport {
  min-width: 0;
  overflow: hidden;
  width: 100%;
  --testimonial-slot: calc((100% - (var(--testimonial-gap) * (var(--testimonial-visible) - 1))) / var(--testimonial-visible));
  --testimonial-shift-unit: calc(var(--testimonial-slot) + var(--testimonial-gap));
  margin-inline: auto;
}

.testimonial-track {
  display: flex;
  gap: var(--testimonial-gap);
  will-change: transform;
  transform: translateX(calc((var(--testimonial-shift-unit) * var(--testimonial-base-shift) * -1) + var(--testimonial-drag-delta)));
  transition: transform var(--testimonial-duration) cubic-bezier(0.16, 1, 0.3, 1);
}

.testimonial-stage.is-animating-forward .testimonial-track {
  transform: translateX(calc((var(--testimonial-shift-unit) * (var(--testimonial-base-shift) + 1) * -1) + var(--testimonial-drag-delta)));
}

.testimonial-stage.is-animating-backward .testimonial-track {
  transform: translateX(calc((var(--testimonial-shift-unit) * (var(--testimonial-base-shift) - 1) * -1) + var(--testimonial-drag-delta)));
}

.testimonial-stage.is-dragging .testimonial-track {
  transition-duration: 0ms;
}

.testimonial-stage.is-dragging,
.testimonial-stage.is-dragging * {
  user-select: none;
  -webkit-user-select: none;
}

.testimonial-nav {
  min-height: 266px;
}

.testimonial-item {
  flex: 0 0 var(--testimonial-slot);
  width: var(--testimonial-slot);
  min-height: 266px;
  padding: 0.66rem 0.6rem 0.54rem;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto auto;
  gap: 0.44rem;
  cursor: grab;
  opacity: var(--testimonial-opacity-live, var(--testimonial-opacity-current, 0.36));
  transform: scale(var(--testimonial-scale-live, var(--testimonial-scale-current, 0.93)));
  transition:
    opacity var(--testimonial-duration) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease),
    border-color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease);
}

.testimonial-viewport,
.testimonial-track,
.testimonial-item,
.testimonial-item * {
  cursor: grab;
}

.testimonial-item .visitor-entry-actions,
.testimonial-item .visitor-entry-actions * {
  cursor: pointer;
}

.testimonial-stage.is-dragging .testimonial-viewport,
.testimonial-stage.is-dragging .testimonial-viewport *,
.testimonial-stage.is-dragging .testimonial-track,
.testimonial-stage.is-dragging .testimonial-track *,
.testimonial-stage.is-dragging .testimonial-item,
.testimonial-stage.is-dragging .testimonial-item * {
  cursor: grabbing !important;
}

.testimonial-stage.is-dragging .testimonial-item {
  transition-duration: 0ms;
}

body.is-testimonial-dragging,
body.is-testimonial-dragging * {
  user-select: none !important;
  -webkit-user-select: none !important;
}

html.is-testimonial-grabbing,
html.is-testimonial-grabbing * {
  cursor: grabbing !important;
}

.testimonial-item[data-offset="0"] {
  --testimonial-opacity-current: 1;
  --testimonial-scale-current: 1;
  box-shadow: 0 12px 20px color-mix(in srgb, var(--bg-1) 24%, transparent);
  pointer-events: auto;
}

.testimonial-item[data-offset="-1"],
.testimonial-item[data-offset="1"] {
  --testimonial-opacity-current: 0.32;
  --testimonial-scale-current: 0.93;
  pointer-events: auto;
}

.testimonial-item[data-offset="-2"],
.testimonial-item[data-offset="2"] {
  --testimonial-opacity-current: 0.12;
  --testimonial-scale-current: 0.86;
  pointer-events: none;
}

.testimonial-item.testimonial-item-empty {
  opacity: 0;
  pointer-events: none;
}

.testimonial-item:hover {
  transform: translateY(-2px) scale(var(--testimonial-scale-live, var(--testimonial-scale-current, 1)));
  border-color: color-mix(in srgb, var(--accent-2) 56%, transparent);
  box-shadow: 0 14px 22px color-mix(in srgb, var(--accent-2) 16%, transparent);
}

.testimonial-item:focus-within {
  transform: translateY(-2px) scale(var(--testimonial-scale-live, var(--testimonial-scale-current, 1)));
  border-color: color-mix(in srgb, var(--accent-2) 56%, transparent);
  box-shadow: 0 14px 22px color-mix(in srgb, var(--accent-2) 16%, transparent);
}

.testimonial-item[data-offset="0"] .testimonial-line-text {
  display: -webkit-box;
  -webkit-line-clamp: 5;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.testimonial-item[data-offset="-1"] .testimonial-line-text,
.testimonial-item[data-offset="1"] .testimonial-line-text {
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.testimonial-item[data-offset="-2"] .testimonial-line-text,
.testimonial-item[data-offset="2"] .testimonial-line-text {
  font-size: 0.74rem;
  line-height: 1.34;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.testimonial-item[data-offset="-2"] .testimonial-name-pill,
.testimonial-item[data-offset="2"] .testimonial-name-pill {
  font-size: 0.66rem;
  padding: 0.12rem 0.4rem;
}

.testimonial-item[data-offset="-2"] .testimonial-line-meta,
.testimonial-item[data-offset="2"] .testimonial-line-meta {
  font-size: 0.66rem;
  gap: 0.22rem;
}

.testimonial-stage.is-animating-forward .testimonial-item,
.testimonial-stage.is-animating-backward .testimonial-item {
  animation: testimonial-visual-shift var(--testimonial-duration) cubic-bezier(0.16, 1, 0.3, 1) both;
}

.testimonial-stage.is-animating-forward .testimonial-item[data-offset="-2"] {
  --testimonial-from-opacity: 0.12;
  --testimonial-to-opacity: 0.06;
  --testimonial-from-scale: 0.86;
  --testimonial-to-scale: 0.82;
}

.testimonial-stage.is-animating-forward .testimonial-item[data-offset="-1"] {
  --testimonial-from-opacity: 0.32;
  --testimonial-to-opacity: 0.12;
  --testimonial-from-scale: 0.93;
  --testimonial-to-scale: 0.86;
}

.testimonial-stage.is-animating-forward .testimonial-item[data-offset="0"] {
  --testimonial-from-opacity: 1;
  --testimonial-to-opacity: 0.32;
  --testimonial-from-scale: 1;
  --testimonial-to-scale: 0.93;
}

.testimonial-stage.is-animating-forward .testimonial-item[data-offset="1"] {
  --testimonial-from-opacity: 0.32;
  --testimonial-to-opacity: 1;
  --testimonial-from-scale: 0.93;
  --testimonial-to-scale: 1;
}

.testimonial-stage.is-animating-forward .testimonial-item[data-offset="2"] {
  --testimonial-from-opacity: 0.12;
  --testimonial-to-opacity: 0.32;
  --testimonial-from-scale: 0.86;
  --testimonial-to-scale: 0.93;
}

.testimonial-stage.is-animating-backward .testimonial-item[data-offset="-2"] {
  --testimonial-from-opacity: 0.12;
  --testimonial-to-opacity: 0.32;
  --testimonial-from-scale: 0.86;
  --testimonial-to-scale: 0.93;
}

.testimonial-stage.is-animating-backward .testimonial-item[data-offset="-1"] {
  --testimonial-from-opacity: 0.32;
  --testimonial-to-opacity: 1;
  --testimonial-from-scale: 0.93;
  --testimonial-to-scale: 1;
}

.testimonial-stage.is-animating-backward .testimonial-item[data-offset="0"] {
  --testimonial-from-opacity: 1;
  --testimonial-to-opacity: 0.32;
  --testimonial-from-scale: 1;
  --testimonial-to-scale: 0.93;
}

.testimonial-stage.is-animating-backward .testimonial-item[data-offset="1"] {
  --testimonial-from-opacity: 0.32;
  --testimonial-to-opacity: 0.12;
  --testimonial-from-scale: 0.93;
  --testimonial-to-scale: 0.86;
}

.testimonial-stage.is-animating-backward .testimonial-item[data-offset="2"] {
  --testimonial-from-opacity: 0.12;
  --testimonial-to-opacity: 0.06;
  --testimonial-from-scale: 0.86;
  --testimonial-to-scale: 0.82;
}

@keyframes testimonial-visual-shift {
  from {
    opacity: var(--testimonial-from-opacity, 1);
    transform: scale(var(--testimonial-from-scale, 1));
  }
  to {
    opacity: var(--testimonial-to-opacity, 1);
    transform: scale(var(--testimonial-to-scale, 1));
  }
}

.wall-entry .visitor-entry-actions,
.testimonial-item .visitor-entry-actions {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  max-height: 0;
  overflow: hidden;
  margin-top: 0;
  transform: translateY(6px);
  transition:
    opacity var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease),
    max-height var(--motion-fast) var(--motion-ease),
    margin var(--motion-fast) var(--motion-ease),
    visibility var(--motion-fast) var(--motion-ease);
}

.wall-entry:hover .visitor-entry-actions,
.wall-entry:focus-within .visitor-entry-actions,
.testimonial-item:hover .visitor-entry-actions,
.testimonial-item:focus-within .visitor-entry-actions {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  max-height: 64px;
  margin-top: 0.08rem;
  transform: translateY(0);
}

.testimonial-item .visitor-entry-actions {
  position: absolute;
  right: 0.34rem;
  bottom: 0.34rem;
  z-index: 4;
  width: auto;
  justify-content: flex-end;
  align-self: auto;
  margin: 0;
  padding: 0;
  max-height: none;
  overflow: visible;
  border: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}

.wall-entry .visitor-entry-actions {
  width: auto;
  justify-content: flex-end;
  align-self: end;
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}

.wall-entry-sketch .visitor-entry-actions {
  width: auto;
  justify-content: flex-end;
  align-self: auto;
  max-height: none;
  overflow: visible;
}

.wall-entry:hover .wall-entry-sketch .visitor-entry-actions,
.wall-entry:focus-within .wall-entry-sketch .visitor-entry-actions {
  margin-top: 0;
}

.testimonial-item:hover .visitor-entry-actions,
.testimonial-item:focus-within .visitor-entry-actions {
  margin-top: 0;
}

.testimonial-item .entry-action-btn {
  width: 38px;
  min-width: 38px;
  min-height: 38px;
}

.testimonial-item .entry-action-btn svg {
  width: 20px;
  height: 20px;
}

.blog-toolbar {
  margin-bottom: 0.85rem;
}

.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--grid-gap-major);
}

.blog-card {
  display: grid;
  gap: var(--grid-gap-minor);
}

.blog-cover {
  position: relative;
  min-height: 124px;
  border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--line) 76%, transparent);
  background:
    radial-gradient(circle at 82% 14%, color-mix(in srgb, var(--blog-cover-c) 42%, transparent), transparent 58%),
    linear-gradient(140deg, color-mix(in srgb, var(--blog-cover-a) 62%, transparent), color-mix(in srgb, var(--blog-cover-b) 52%, transparent));
  padding: 0.7rem;
  display: grid;
  align-content: space-between;
}

.blog-cover-icon {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  font: 700 0.68rem/1 var(--font-mono);
  border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  background: color-mix(in srgb, var(--glass-bg-soft) 85%, transparent);
}

.blog-cover small {
  justify-self: end;
  font-size: 0.66rem;
  color: color-mix(in srgb, var(--text) 74%, var(--muted));
}

.blog-meta {
  justify-self: start;
  display: inline-flex;
  padding: 0.18rem 0.52rem;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--accent-2) 52%, transparent);
  background: color-mix(in srgb, var(--accent-2) 14%, transparent);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.03em;
}

.blog-card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.92rem;
}

.blog-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--grid-gap-minor);
}

.blog-action-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.36rem;
  border-radius: 999px;
  padding: 0.44rem 0.7rem;
  font-size: 0.84rem;
  line-height: 1;
  border-color: color-mix(in srgb, var(--line) 84%, transparent);
}

.blog-action-btn .btn-icon {
  width: 16px;
  height: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.blog-action-btn .btn-icon svg {
  width: 16px;
  height: 16px;
}

.blog-action-count {
  min-width: 1.5rem;
  height: 1.5rem;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid color-mix(in srgb, var(--accent-2) 56%, transparent);
  background: color-mix(in srgb, var(--accent-2) 22%, transparent);
  font: 700 0.74rem/1 var(--font-mono);
}

.blog-action-read:hover {
  border-color: color-mix(in srgb, var(--accent-2) 66%, transparent);
}

.blog-action-like:hover {
  border-color: color-mix(in srgb, var(--accent-1) 66%, transparent);
}

.blog-action-share:hover,
.blog-action-share.is-copied {
  border-color: color-mix(in srgb, var(--accent-3) 68%, transparent);
}

.blog-detail-hero {
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  padding: 0.92rem;
  display: grid;
  gap: 0.62rem;
  background:
    radial-gradient(circle at 85% 16%, color-mix(in srgb, var(--blog-cover-c) 42%, transparent), transparent 58%),
    linear-gradient(145deg, color-mix(in srgb, var(--blog-cover-a) 58%, transparent), color-mix(in srgb, var(--blog-cover-b) 48%, transparent));
}

.blog-detail-meta {
  display: flex;
  justify-content: space-between;
  gap: 0.6rem;
  align-items: center;
  flex-wrap: wrap;
}

.blog-detail-hero p {
  margin: 0;
  color: var(--text);
}

.blog-detail-hook {
  font-size: 1.02rem;
  font-weight: 600;
  line-height: 1.45;
}

.blog-detail-hero small {
  color: color-mix(in srgb, var(--text) 74%, var(--muted));
}

.blog-detail-visuals h4,
.blog-detail-prose h4 {
  margin-bottom: 0.58rem;
}

.blog-detail-gallery {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 0.56rem;
}

.blog-detail-shot {
  margin: 0;
  min-height: 128px;
  border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--line) 80%, transparent);
  background:
    radial-gradient(circle at 82% 16%, color-mix(in srgb, var(--shot-a) 44%, transparent), transparent 56%),
    linear-gradient(140deg, color-mix(in srgb, var(--shot-a) 40%, transparent), color-mix(in srgb, var(--shot-b) 50%, transparent));
  padding: 0.54rem;
  display: grid;
  align-content: space-between;
  gap: 0.46rem;
}

.blog-detail-shot-wide {
  min-height: 148px;
}

.shot-top {
  height: 12px;
  width: 48%;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--line) 74%, transparent);
  background: color-mix(in srgb, var(--glass-bg-soft) 80%, transparent);
}

.shot-lines {
  display: grid;
  gap: 0.3rem;
}

.shot-lines span {
  display: block;
  height: 8px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  background: color-mix(in srgb, var(--glass-bg-soft) 78%, transparent);
}

.shot-lines span:nth-child(2) {
  width: 84%;
}

.shot-lines span:nth-child(3) {
  width: 62%;
}

.blog-detail-shot figcaption {
  font-size: 0.72rem;
  font-weight: 700;
  color: color-mix(in srgb, var(--text) 78%, var(--muted));
}

.blog-detail-prose p {
  color: var(--text);
  line-height: 1.72;
  font-size: 0.97rem;
}

.about-head {
  margin-bottom: 1rem;
}

.about-layout {
  display: grid;
  grid-template-columns: minmax(236px, 300px) minmax(0, 1fr);
  gap: 1.02rem;
  align-items: start;
}

.about-portrait-block {
  padding: 0.62rem;
  border-radius: 18px;
  display: grid;
  gap: 0.5rem;
  max-width: 300px;
  justify-self: start;
  background:
    radial-gradient(circle at 15% 18%, color-mix(in srgb, var(--accent-1) 14%, transparent), transparent 56%),
    linear-gradient(158deg, color-mix(in srgb, var(--bg-3) 56%, transparent), color-mix(in srgb, var(--bg-2) 66%, transparent));
}

.about-photo {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  object-position: center 18%;
  border-radius: 16px;
  border: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  background: color-mix(in srgb, var(--glass-bg-soft) 80%, transparent);
  margin-inline: auto;
}

.about-portrait-caption {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.about-caption-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--accent-2) 58%, transparent);
  background: color-mix(in srgb, var(--accent-2) 18%, transparent);
  padding: 0.24rem 0.56rem;
  font-size: 0.76rem;
  font-weight: 700;
  color: color-mix(in srgb, var(--text) 86%, white 14%);
  letter-spacing: 0.01em;
}

.about-story-panel {
  display: grid;
  gap: 0.84rem;
  border-radius: 20px;
  padding: clamp(0.94rem, 1.4vw, 1.24rem);
  min-height: 0;
  background:
    radial-gradient(circle at 90% 12%, color-mix(in srgb, var(--accent-2) 12%, transparent), transparent 48%),
    linear-gradient(150deg, color-mix(in srgb, var(--bg-3) 52%, transparent), color-mix(in srgb, var(--bg-2) 62%, transparent));
}

.about-story-panel h3 {
  margin: 0;
  font-size: clamp(1.28rem, 2.1vw, 1.66rem);
  line-height: 1.12;
  color: color-mix(in srgb, var(--text) 94%, white 6%);
}

.about-story-panel p {
  margin: 0;
  color: var(--muted);
  line-height: 1.7;
  font-size: clamp(0.98rem, 1.06vw, 1.07rem);
  max-width: 74ch;
}

.about-timeline,
.about-market-signals,
.about-personal-notes {
  border: 1px solid color-mix(in srgb, var(--line) 80%, transparent);
  background: color-mix(in srgb, var(--glass-bg-soft) 94%, transparent);
  border-radius: var(--radius-md);
  padding: 0.9rem;
}

.about-market-signals h3,
.about-personal-notes h3 {
  margin: 0 0 0.56rem;
}

.journey-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--grid-gap-minor);
}

.journey-list li {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.56rem;
  align-items: start;
}

.journey-year {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--accent-2) 50%, transparent);
  background: color-mix(in srgb, var(--accent-2) 14%, transparent);
  color: color-mix(in srgb, var(--text) 82%, var(--accent-2));
  font: 700 0.69rem/1 var(--font-mono);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 0.22rem 0.5rem;
}

.journey-list strong {
  font-size: 0.89rem;
}

.journey-list p {
  margin: 0.22rem 0 0;
  color: var(--muted);
  font-size: 0.88rem;
}

.about-facts {
  display: grid;
  gap: 0.46rem;
  margin-top: 0;
}

.about-facts-inline {
  margin-top: 0.18rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.fact-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--accent-2) 48%, transparent);
  background: color-mix(in srgb, var(--accent-2) 15%, transparent);
  min-height: 40px;
  padding: 0.3rem 0.56rem;
  font-size: 0.74rem;
  font-weight: 600;
}

.signal-list {
  margin: 0;
  padding-left: 1.02rem;
  display: grid;
  gap: 0.38rem;
}

.signal-list li {
  color: var(--muted);
  font-size: 0.91rem;
  line-height: 1.55;
}

.contact-deck {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.82rem;
  padding: 0;
  align-items: stretch;
}

.contact-channel {
  --channel-a: var(--accent-1);
  --channel-b: var(--accent-2);
  --channel-c: #9adfff;
  position: relative;
  display: grid;
  align-content: start;
  justify-items: start;
  grid-template-rows: auto auto minmax(0, 1fr);
  gap: 0.46rem;
  min-height: 138px;
  padding: 0.86rem;
  border-radius: 16px;
  border: 1px solid color-mix(in srgb, var(--line) 76%, transparent);
  color: #ecf8ff;
  text-decoration: none;
  background:
    radial-gradient(circle at 86% 16%, color-mix(in srgb, var(--channel-b) 34%, transparent), transparent 58%),
    linear-gradient(
      150deg,
      color-mix(in srgb, var(--channel-a) 20%, var(--glass-bg-soft)),
      color-mix(in srgb, var(--channel-b) 12%, var(--glass-bg-soft))
    );
  box-shadow: var(--glass-shadow), var(--surface-extra-shadow);
  overflow: hidden;
  transition:
    transform var(--motion-fast) var(--motion-ease),
    border-color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    background var(--motion-fast) var(--motion-ease);
}

.contact-channel::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 8%, color-mix(in srgb, var(--channel-c) 24%, transparent) 42%, transparent 72%);
  transform: translateX(-125%);
  transition: transform 0.7s ease;
  pointer-events: none;
}

button.contact-channel {
  font: inherit;
  appearance: none;
  -webkit-appearance: none;
  cursor: pointer;
  text-align: left;
}

.contact-channel:hover,
.contact-channel:focus-visible {
  transform: translateY(var(--card-hover-lift));
  border-color: color-mix(in srgb, var(--accent-2) 56%, transparent);
  box-shadow: var(--interactive-shadow-strong);
}

.contact-channel:hover::after,
.contact-channel:focus-visible::after {
  transform: translateX(125%);
}

.contact-channel-icon {
  width: 46px;
  height: 46px;
  border-radius: 14px;
  display: inline-grid;
  place-items: center;
  color: color-mix(in srgb, white 92%, var(--channel-c));
  border: 1px solid color-mix(in srgb, var(--channel-c) 56%, transparent);
  background: color-mix(in srgb, var(--channel-a) 28%, transparent);
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, white 26%, transparent),
    0 8px 16px color-mix(in srgb, var(--channel-a) 18%, transparent);
}

.contact-channel-icon svg {
  width: 22px;
  height: 22px;
}

.contact-channel-label {
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  color: #f3fcff;
}

.contact-channel-hover {
  margin: 0;
  margin-top: auto;
  font-size: 0.74rem;
  line-height: 1.42;
  color: color-mix(in srgb, #e8f8ff 78%, var(--channel-c));
  opacity: 0.8;
  transform: none;
  transition:
    opacity var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease);
}

.contact-channel:hover .contact-channel-hover,
.contact-channel:focus-visible .contact-channel-hover {
  opacity: 1;
  transform: translateY(-1px);
}

.contact-channel-linkedin {
  --channel-a: #1d80ff;
  --channel-b: #5ac8ff;
  --channel-c: #9fe8ff;
}

.contact-channel-github {
  --channel-a: #6779ff;
  --channel-b: #a8b7ff;
  --channel-c: #d8ddff;
}

.contact-channel-email {
  --channel-a: #ff8a3d;
  --channel-b: #ffc857;
  --channel-c: #ffe29f;
}

.contact-channel-ai {
  --channel-a: #00c4cc;
  --channel-b: #7effb6;
  --channel-c: #b8fff0;
}

.contact-chat-thread {
  min-height: 210px;
  max-height: min(42vh, 300px);
}

.chat-mode-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.42rem;
}

.presence-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.34rem;
  border-radius: 999px;
  padding: 0.22rem 0.56rem;
  border: 1px solid color-mix(in srgb, var(--line) 80%, transparent);
  background: color-mix(in srgb, var(--glass-bg-soft) 88%, transparent);
  font-size: 0.74rem;
  font-weight: 700;
}

.presence-pill::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #67f0aa;
  box-shadow: 0 0 0 0 rgba(102, 239, 169, 0.4);
  animation: presence-pulse 1.8s ease-out infinite;
}

.presence-pill.away::before {
  background: #f5b961;
  box-shadow: none;
  animation: none;
}

@keyframes presence-pulse {
  0% {
    box-shadow: 0 0 0 0 rgba(102, 239, 169, 0.42);
  }
  100% {
    box-shadow: 0 0 0 10px rgba(102, 239, 169, 0);
  }
}

.site-footer {
  border-top: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  padding: 1.2rem 0;
}

.footer-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.9rem;
  flex-wrap: wrap;
}

.footer-inner p {
  margin: 0;
  font-size: 0.86rem;
  color: var(--muted);
}

.footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--grid-gap-minor);
}

.footer-links a {
  text-decoration: none;
  font-size: 0.78rem;
  color: var(--muted);
  border-bottom: 1px solid color-mix(in srgb, var(--line) 68%, transparent);
  transition:
    color var(--motion-fast) var(--motion-ease),
    border-color var(--motion-fast) var(--motion-ease);
}

.footer-links a:hover {
  color: var(--text);
  border-bottom-color: color-mix(in srgb, var(--accent-2) 64%, transparent);
}

.open-concierge-fab {
  position: fixed;
  left: max(1.36rem, env(safe-area-inset-left));
  bottom: max(1.24rem, env(safe-area-inset-bottom));
  z-index: 281;
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
  min-height: 48px;
  height: 48px;
  padding: 0.5rem 0.74rem;
  border-radius: 999px;
  color: var(--text);
  text-transform: var(--ui-transform);
  letter-spacing: var(--ui-letter-spacing);
}

.fab-dot {
  display: grid;
  place-items: center;
  width: 26px;
  height: 26px;
  border-radius: 999px;
  font: 700 0.64rem/1 var(--font-mono);
  color: var(--accent-ink);
  background: linear-gradient(120deg, var(--accent-1), var(--accent-2));
  box-shadow: 0 0 14px color-mix(in srgb, var(--accent-2) 30%, transparent);
}

.back-to-top {
  position: fixed;
  right: max(1.36rem, env(safe-area-inset-right));
  bottom: max(1.24rem, env(safe-area-inset-bottom));
  z-index: 280;
  min-width: 88px;
  height: 48px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--line) 84%, transparent);
  color: var(--text);
  opacity: 0;
  transform: translateY(14px) scale(0.96);
  pointer-events: none;
  transition:
    opacity var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.34rem;
  padding: 0 0.58rem;
}

.back-to-top.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

.back-to-top:hover,
.open-concierge-fab:hover {
  box-shadow: 0 18px 30px color-mix(in srgb, var(--accent-2) 24%, transparent);
}

.back-icon-wrap {
  width: 24px;
  height: 24px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: color-mix(in srgb, var(--accent-2) 22%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent-2) 52%, transparent);
}

.back-icon {
  font: 700 0.84rem var(--font-mono);
  transform: translateY(-1px);
}

.back-label {
  font-size: 0.72rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--muted);
}

.btn,
.chip,
.tab,
.icon-btn,
.menu-toggle,
.style-toggle,
.open-concierge-fab,
.back-to-top {
  border: 1px solid color-mix(in srgb, var(--line) 84%, transparent);
  background: var(--glass-bg-soft);
  color: var(--text);
  text-decoration: none;
  cursor: pointer;
  font-size: 0.86rem;
  font-weight: 600;
  transition:
    transform var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    background-color var(--motion-fast) var(--motion-ease),
    border-color var(--motion-fast) var(--motion-ease);
}

.btn,
.chip,
.tab,
.style-toggle {
  border-radius: var(--control-pill-radius);
  padding: 0.52rem 0.78rem;
  text-transform: var(--ui-transform);
  letter-spacing: var(--ui-letter-spacing);
}

.style-toggle-icon,
.header-actions .style-toggle-icon {
  width: 42px;
  height: 42px;
  min-height: 42px;
  min-width: 42px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.04rem;
}

#mainContent {
  display: flex;
  flex-direction: column;
}

#home {
  order: 1;
}

#about {
  order: 2;
}

#stack {
  order: 3;
}

#projects {
  order: 4;
}

#workingStyle {
  order: 5;
}

#cta {
  order: 6;
}

#blog {
  order: 7;
}

#visitorsWall {
  order: 8;
}

.icon-btn,
.menu-toggle {
  border-radius: var(--control-radius);
  padding: 0.52rem 0.78rem;
  text-transform: var(--ui-transform);
  letter-spacing: var(--ui-letter-spacing);
}

.btn:hover,
.chip:hover,
.tab:hover,
.icon-btn:hover,
.menu-toggle:hover,
.style-toggle:hover,
.open-concierge-fab:hover {
  transform: translateY(var(--interactive-lift));
  border-color: color-mix(in srgb, var(--accent-2) 60%, transparent);
  box-shadow: var(--interactive-shadow);
}

.btn-primary {
  background: linear-gradient(120deg, var(--accent-1), var(--accent-2));
  border-color: transparent;
  color: var(--accent-ink);
}

.chip.active,
.tab.active,
.style-chip.active {
  border-color: color-mix(in srgb, var(--accent-1) 72%, transparent);
  background: color-mix(in srgb, var(--accent-1) 18%, transparent);
}

.project-card:hover,
.prototype-card:hover,
.blog-card:hover,
.stack-card:hover,
.wall-entry:hover,
.hero-proof article:hover,
.now-building .focus-grid article:hover {
  transform: translateY(var(--card-hover-lift));
  border-color: color-mix(in srgb, var(--accent-2) 56%, transparent);
  box-shadow: var(--interactive-shadow-strong);
}

.console {
  margin: 0;
  border-radius: 10px;
  padding: 0.72rem;
  color: color-mix(in srgb, var(--text) 86%, #eaf4ff);
  font: 500 0.78rem/1.55 var(--font-mono);
  white-space: pre-wrap;
  overflow: auto;
  min-height: 108px;
}

.case-dialog {
  width: min(920px, 92vw);
  border: 0;
  border-radius: 16px;
  padding: 0;
  background: transparent;
  opacity: 0;
  transform: translateY(16px) scale(0.98);
  transform-origin: center;
}

.case-dialog[open] {
  opacity: 1;
  transform: translateY(0) scale(1);
  animation: dialog-shell-in 260ms var(--motion-ease);
}

.case-dialog[open].is-closing {
  animation: dialog-shell-out 260ms var(--motion-ease);
}

.case-dialog::backdrop {
  background: rgba(5, 10, 18, 0.62);
  backdrop-filter: blur(2px);
  animation: dialog-backdrop-in 260ms var(--motion-ease);
}

.case-dialog[open].is-closing::backdrop {
  animation: dialog-backdrop-out 260ms var(--motion-ease);
}

.dialog-card {
  border-radius: 16px;
  padding: 1rem;
  max-height: 85vh;
  overflow: auto;
  transform-origin: 50% 24%;
  will-change: transform, opacity, filter;
}

.case-dialog[open] .dialog-card {
  animation: dialog-card-in 260ms var(--motion-ease);
}

.case-dialog[open].is-closing .dialog-card {
  animation: dialog-card-out 260ms var(--motion-ease);
}

@keyframes dialog-shell-in {
  0% {
    opacity: 0;
    transform: translateY(16px) scale(0.98);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes dialog-shell-out {
  0% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
  100% {
    opacity: 0;
    transform: translateY(12px) scale(0.97);
  }
}

@keyframes dialog-card-in {
  0% {
    opacity: 0;
    filter: blur(4px);
    transform: translateY(14px) scale(0.95) rotateX(5deg);
  }
  100% {
    opacity: 1;
    filter: blur(0);
    transform: translateY(0) scale(1) rotateX(0deg);
  }
}

@keyframes dialog-card-out {
  0% {
    opacity: 1;
    filter: blur(0);
    transform: translateY(0) scale(1) rotateX(0deg);
  }
  100% {
    opacity: 0;
    filter: blur(3px);
    transform: translateY(10px) scale(0.95) rotateX(5deg);
  }
}

@keyframes dialog-backdrop-in {
  0% {
    background: rgba(5, 10, 18, 0);
  }
  100% {
    background: rgba(5, 10, 18, 0.62);
  }
}

@keyframes dialog-backdrop-out {
  0% {
    background: rgba(5, 10, 18, 0.62);
  }
  100% {
    background: rgba(5, 10, 18, 0);
  }
}

.dialog-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.7rem;
  margin-bottom: 0.7rem;
}

.dialog-head h3 {
  margin: 0;
}

.dialog-body {
  display: grid;
  gap: var(--grid-gap-major);
}

.dialog-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--grid-gap-major);
}

.dialog-block {
  border: 1px solid color-mix(in srgb, var(--line) 80%, transparent);
  border-radius: 10px;
  padding: 0.75rem;
  background: var(--glass-bg-soft);
}

.dialog-block h4 {
  margin: 0 0 0.5rem;
  font-size: 0.88rem;
}

.dialog-block p,
.dialog-block li {
  margin: 0;
  font-size: 0.88rem;
  color: var(--muted);
}

.dialog-block ul {
  margin: 0;
  padding-left: 1rem;
}

.concierge-dialog {
  position: fixed;
  inset: auto auto 0.9rem 0.9rem;
  width: min(430px, calc(100vw - 1rem));
  margin: 0;
  border-radius: 18px;
}

.concierge-dialog::backdrop {
  background: rgba(4, 9, 18, 0.08);
  backdrop-filter: none;
  animation: concierge-backdrop-in 260ms var(--motion-ease);
}

.concierge-dialog[open].is-closing::backdrop {
  animation: concierge-backdrop-out 260ms var(--motion-ease);
}

.concierge-dialog[open] .dialog-card {
  animation: concierge-card-in 260ms var(--motion-ease);
}

.concierge-dialog[open].is-closing .dialog-card {
  animation: concierge-card-out 260ms var(--motion-ease);
}

@keyframes concierge-card-in {
  0% {
    opacity: 0;
    filter: blur(4px);
    transform: translateY(20px) scale(0.95) rotateX(6deg);
  }
  100% {
    opacity: 1;
    filter: blur(0);
    transform: translateY(0) scale(1) rotateX(0deg);
  }
}

@keyframes concierge-card-out {
  0% {
    opacity: 1;
    filter: blur(0);
    transform: translateY(0) scale(1) rotateX(0deg);
  }
  100% {
    opacity: 0;
    filter: blur(3px);
    transform: translateY(16px) scale(0.95) rotateX(5deg);
  }
}

@keyframes concierge-backdrop-in {
  0% {
    background: rgba(4, 9, 18, 0);
  }
  100% {
    background: rgba(4, 9, 18, 0.08);
  }
}

@keyframes concierge-backdrop-out {
  0% {
    background: rgba(4, 9, 18, 0.08);
  }
  100% {
    background: rgba(4, 9, 18, 0);
  }
}

.concierge-dialog .dialog-card {
  max-height: min(68vh, 540px);
  padding: 0.72rem;
  border-radius: 18px;
  border: var(--surface-border-width) var(--surface-border-style) color-mix(in srgb, var(--line) 84%, transparent);
  background:
    radial-gradient(circle at 14% 92%, color-mix(in srgb, var(--accent-2) 16%, transparent), transparent 54%),
    radial-gradient(circle at 92% 10%, color-mix(in srgb, var(--accent-1) 14%, transparent), transparent 44%),
    var(--glass-bg);
  box-shadow: var(--glass-shadow), var(--surface-extra-shadow);
  backdrop-filter: var(--surface-filter);
}

.concierge-shell {
  display: grid;
  gap: 0.44rem;
  align-content: start;
}

.concierge-dialog .dialog-head {
  margin-bottom: 0;
}

.concierge-dialog .dialog-head h3 {
  margin: 0;
  font-size: clamp(1.16rem, 2.1vw, 1.4rem);
  letter-spacing: 0.01em;
  color: #f5fbff;
}

.concierge-head-actions {
  display: inline-flex;
  align-items: center;
  gap: 0.48rem;
  justify-content: flex-end;
}

.concierge-note {
  margin: 0;
  font-size: 0.76rem;
  color: var(--muted);
}

.concierge-dialog .presence-pill {
  color: #ecf8ff;
  border-color: color-mix(in srgb, var(--accent-2) 46%, transparent);
  background: color-mix(in srgb, var(--glass-bg-soft) 84%, transparent);
}

.concierge-dialog .contact-chat-thread {
  min-height: 154px;
  max-height: min(34vh, 230px);
  padding: 0.08rem 0;
  border-radius: 0;
  border: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 0.34rem;
  background: none !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}

.concierge-dialog .chat-message {
  max-width: 88%;
  padding: 0.42rem 0.56rem;
  font-size: 0.84rem;
  line-height: 1.45;
  border-radius: 12px;
}

.concierge-dialog .chat-assistant {
  align-self: flex-start;
  border: 0;
  background: transparent;
  color: color-mix(in srgb, #fff 86%, var(--muted));
  box-shadow: none;
}

.concierge-dialog .chat-user {
  align-self: flex-end;
  border-color: color-mix(in srgb, var(--accent-2) 54%, transparent);
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent-1) 26%, transparent), color-mix(in srgb, var(--accent-2) 20%, transparent));
  color: var(--accent-ink);
}

.concierge-dialog .chat-mode-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.16rem;
  width: 100%;
  padding: 0.12rem;
  border: 1px solid color-mix(in srgb, var(--line) 80%, transparent);
  border-radius: 12px;
  background: color-mix(in srgb, var(--bg-2) 48%, transparent);
}

.concierge-dialog .chat-mode-row .chip {
  min-height: 34px;
  padding: 0.34rem 0.58rem;
  border: 1px solid transparent;
  background: transparent;
  color: color-mix(in srgb, var(--text) 90%, white 10%);
  font-size: 0.88rem;
  font-weight: 700;
}

.concierge-dialog .chat-mode-row .chip.active {
  border-color: color-mix(in srgb, var(--accent-1) 68%, transparent);
  background: linear-gradient(
    145deg,
    color-mix(in srgb, var(--accent-1) 20%, transparent),
    color-mix(in srgb, var(--accent-2) 16%, transparent)
  );
  color: color-mix(in srgb, var(--text) 92%, white 8%);
  box-shadow: inset 0 1px 0 color-mix(in srgb, white 16%, transparent);
}

.concierge-dialog .chat-compose {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.42rem;
  align-items: end;
}

.concierge-dialog .chat-compose textarea {
  width: 100%;
  min-height: 56px;
  max-height: 110px;
  resize: none;
  padding: 0.54rem 0.68rem;
  font-size: 0.85rem;
  line-height: 1.4;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--line) 80%, transparent);
  background: color-mix(in srgb, var(--glass-bg-soft) 72%, transparent);
  color: var(--text);
  transition:
    border-color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease);
}

.concierge-dialog .chat-compose textarea:focus {
  border-color: color-mix(in srgb, var(--accent-2) 62%, transparent);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--accent-2) 24%, transparent),
    inset 0 1px 0 color-mix(in srgb, white 14%, transparent);
}

.concierge-dialog .chat-compose textarea::placeholder {
  color: color-mix(in srgb, var(--muted) 88%, white 12%);
}

.concierge-dialog .chat-compose .btn {
  align-self: end;
  white-space: nowrap;
  justify-self: end;
  width: auto;
  min-height: 44px;
  min-width: 88px;
  padding: 0.42rem 0.88rem;
  font-size: 0.98rem;
  border-radius: 999px;
}

#contactChatStatus {
  min-height: 0.9rem;
  margin: 0;
  color: color-mix(in srgb, var(--text) 78%, var(--muted));
  font-size: 0.74rem;
}

.modal-close-btn {
  width: 30px;
  height: 30px;
  min-width: 30px;
  min-height: 30px;
  border-radius: 999px;
  padding: 0;
  display: grid;
  place-items: center;
  font-size: 1.04rem;
  line-height: 1;
  color: var(--text);
  border-color: color-mix(in srgb, var(--line) 78%, transparent);
  background: color-mix(in srgb, var(--glass-bg-soft) 92%, transparent);
}

.reveal {
  opacity: 0;
  transform: translateY(var(--motion-reveal-distance));
  transition:
    opacity var(--motion-slow) var(--motion-ease),
    transform var(--motion-slow) var(--motion-ease);
}

.reveal.show {
  opacity: 1;
  transform: translateY(0);
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

button:focus-visible,
a:focus-visible {
  outline: var(--focus-ring-width) var(--focus-ring-style) var(--focus);
  outline-offset: var(--focus-ring-offset);
}

input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 1px solid color-mix(in srgb, var(--focus) 76%, transparent);
  outline-offset: 1px;
}

@media (max-width: 1120px) {
  .site-header {
    width: min(98vw, var(--header-shell-width));
  }

  .header-inner {
    gap: 0.72rem;
    min-height: 68px;
  }

  .main-nav {
    gap: 0.2rem;
  }

  .main-nav a {
    min-height: 36px;
    font-size: 0.84rem;
    padding: 0.34rem 0.56rem;
  }

  .stack-grid,
  .project-grid,
  .prototype-grid,
  .blog-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .hero-grid,
  .readiness-grid,
  .wall-grid,
  .dialog-grid,
  .hero-proof,
  .about-layout {
    grid-template-columns: 1fr;
  }

  .wall-grid > .panel {
    height: auto;
    min-height: 0;
    overflow: visible;
  }

  .wall-grid > .panel:last-child,
  .wall-map-panel {
    height: auto;
    min-height: 0;
  }

  .wall-form-panel,
  .wall-map-panel,
  .wall-greetings-panel {
    grid-column: auto;
    grid-row: auto;
  }

  .wall-form-panel {
    overflow: visible;
  }

  .visitor-form {
    overflow: visible;
    padding-right: 0;
  }

  .wall-list {
    --wall-card-height: 206px;
    height: auto;
    min-height: calc(var(--wall-card-height) + var(--grid-gap-minor));
    max-height: calc((var(--wall-card-height) * 2.5) + (var(--grid-gap-minor) * 2));
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  }

  .visitor-form-layout {
    grid-template-columns: 1fr;
    gap: var(--grid-gap-minor);
  }

  .visitor-form-main,
  .visitor-form-side {
    padding: 0;
  }

  .visitor-form-actions,
  .visitor-form-layout.is-greeting-mode .visitor-form-actions,
  .wall-status-capsule,
  .visitor-form-layout.is-greeting-mode .wall-status-capsule {
    grid-column: auto;
  }

  .testimonial-stage {
    width: min(100%, 860px);
    --testimonial-slot: clamp(142px, 23vw, 210px);
    gap: 0.18rem;
  }

  .testimonial-nav {
    width: 34px;
    min-width: 34px;
    min-height: 242px;
  }

  .testimonial-nav svg {
    width: 40px;
    height: 40px;
  }

  .testimonial-item {
    min-height: 242px;
    padding: 0.62rem 0.56rem 0.5rem;
  }

  .testimonial-item[data-offset="0"] .testimonial-line-text {
    font-size: 0.9rem;
    line-height: 1.48;
  }

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

  .component-board-grid,
  .component-pick-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .about-portrait-block {
    justify-self: center;
  }

  .about-portrait-caption {
    justify-content: center;
  }

  .about-facts-inline {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .blog-detail-shot-wide {
    grid-column: 1 / -1;
  }
}

@media (max-width: 860px) {
  .site-header {
    width: 99vw;
  }

  .header-inner {
    grid-template-columns: auto auto;
  }

  .main-nav,
  .header-actions {
    display: none;
  }

  .menu-toggle {
    display: inline-flex;
    justify-self: end;
  }

  .mobile-nav.is-open {
    display: grid;
    gap: 0.12rem;
  }

  .mobile-nav {
    right: 0.38rem;
    max-width: min(244px, calc(100vw - 0.76rem));
    padding: 0.34rem;
    border-radius: 12px;
  }

  .mobile-nav a {
    min-width: 134px;
    font-size: 0.86rem;
    padding: 0.56rem 0.5rem;
  }

  .project-grid,
  .prototype-grid,
  .stack-grid,
  .blog-grid {
    grid-template-columns: 1fr;
  }

  .contact-deck {
    grid-template-columns: repeat(auto-fit, minmax(174px, 208px));
    justify-content: center;
    padding: 0;
  }

  .contact-channel {
    width: 100%;
    min-height: 124px;
  }

  .component-config-grid,
  .component-board-grid,
  .component-pick-grid {
    grid-template-columns: 1fr;
  }

  .visitor-form-actions {
    grid-template-columns: 1fr;
  }

  .visitor-form {
    gap: 0.46rem;
  }

  .visitor-type-row {
    padding: 0.42rem 0.5rem 0.5rem;
  }

  .visitor-type-options {
    grid-template-columns: 1fr;
  }

  .drawing-toolbar {
    grid-template-columns: 1fr;
    justify-items: start;
    gap: 0.3rem;
  }

  .visitor-drawing-section {
    padding: 0.46rem;
  }

  .wall-entry {
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: minmax(0, 1fr) minmax(82px, 0.96fr);
    height: 192px;
    min-height: 192px;
    max-height: 192px;
  }

  .wall-entry-sketch {
    min-height: 82px;
    height: 100%;
  }

  .wall-list {
    --wall-card-height: 192px;
    min-height: calc(var(--wall-card-height) + var(--grid-gap-minor));
    max-height: calc((var(--wall-card-height) * 2.5) + (var(--grid-gap-minor) * 2));
    grid-template-columns: repeat(auto-fill, minmax(132px, 1fr));
  }

  .testimonial-stage {
    width: 100%;
    --testimonial-visible: 3;
    --testimonial-base-shift: 1;
    --testimonial-slot: clamp(92px, 26vw, 146px);
    gap: 0.16rem;
  }

  .testimonial-nav {
    width: 30px;
    min-width: 30px;
    min-height: 220px;
  }

  .testimonial-nav svg {
    width: 30px;
    height: 30px;
  }

  .testimonial-item {
    min-height: 220px;
  }

  .testimonial-item[data-offset="-2"],
  .testimonial-item[data-offset="2"] {
    pointer-events: none;
  }

  .testimonial-item .visitor-entry-actions {
    right: 0.3rem;
    bottom: 0.3rem;
  }

  .chat-compose {
    grid-template-columns: 1fr;
  }

  .chat-compose .btn {
    width: 100%;
  }

  .style-panel {
    right: 0.5rem;
    left: auto;
    width: min(320px, calc(100vw - 1rem));
    max-width: min(320px, calc(100vw - 1rem));
    max-height: none;
    padding: 0.5rem 0.52rem 0.58rem;
    border-radius: 18px;
  }

  .style-panel-head {
    top: -0.62rem;
    right: 0.32rem;
  }

  .style-mode-row,
  .style-lang-row {
    width: 100%;
  }

  .style-panel .chip {
    min-height: 38px;
    font-size: 0.8rem;
  }

  .style-flag-chip {
    min-height: 38px;
    font-size: 0.84rem;
  }

  .theme-preset-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 0.24rem;
  }

  .theme-preset {
    max-width: 22px;
  }

  .about-facts-inline {
    grid-template-columns: 1fr;
  }

  .concierge-dialog {
    inset: auto 0.5rem 0.5rem 0.5rem;
    width: auto;
  }

  .concierge-dialog .dialog-card {
    max-height: min(76vh, 560px);
  }

  .footer-inner {
    flex-direction: column;
    align-items: flex-start;
  }

  .open-concierge-fab {
    left: max(1rem, env(safe-area-inset-left));
    bottom: max(0.94rem, env(safe-area-inset-bottom));
    min-height: 48px;
    height: 48px;
    padding: 0.46rem 0.72rem;
  }

  .back-to-top {
    right: max(1rem, env(safe-area-inset-right));
    bottom: max(0.94rem, env(safe-area-inset-bottom));
    min-height: 48px;
    height: 48px;
  }

  .match-shell {
    grid-template-columns: 1fr;
  }

  .score-ring {
    justify-self: center;
  }

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

  .blog-detail-shot-wide {
    grid-column: auto;
  }
}

@media (prefers-contrast: more) {
  :root {
    --surface-border-width: 2px;
    --focus-ring-width: 4px;
    --focus-ring-offset: 3px;
    --texture-opacity: 0;
    --grain-opacity: 0;
  }

  .btn,
  .chip,
  .tab,
  .icon-btn,
  .menu-toggle,
  .style-toggle,
  .open-concierge-fab,
  .back-to-top {
    box-shadow: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
