﻿@font-face {
  font-family: "Inter";
  src: url("font/inter-v20-latin-regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Inter";
  src: url("font/inter-v20-latin-600.woff2") format("woff2");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "IBM Plex Serif";
  src: url("font/ibm-plex-serif-v20-latin-regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "IBM Plex Serif";
  src: url("font/ibm-plex-serif-v20-latin-500.woff2") format("woff2");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

:root {
  --bg: #f4efe7;
  --bg-elevated: #fbf6ef;
  --surface: #fffdfa;
  --surface-strong: #fffdfa;
  --surface-glass: rgba(255, 253, 249, 0.78);
  --surface-glass-soft: rgba(255, 253, 249, 0.84);
  --surface-glass-strong: rgba(255, 253, 249, 0.92);
  --text-primary: #27231d;
  --text-secondary: #6e665d;
  --text: var(--text-primary);
  --muted: var(--text-secondary);
  --border: rgba(42, 34, 27, 0.12);
  --border-soft: rgba(42, 34, 27, 0.08);
  --border-strong: rgba(42, 34, 27, 0.16);
  --line: var(--border);
  --accent: #b0006d;
  --accent-strong: #8b0055;
  --accent-secondary: #5f6f8a;
  --accent-secondary-strong: #435067;
  --accent-secondary-light: #edf1f7;
  --accent-secondary-line: rgba(95, 111, 138, 0.12);
  --accent-soft: rgba(176, 0, 109, 0.12);
  --text-on-accent: #ffffff;
  --shadow-soft: 0 10px 24px rgba(23, 24, 32, 0.08);
  --shadow-card: 0 18px 40px rgba(53, 20, 42, 0.05);
  --shadow-panel: 0 20px 50px rgba(53, 20, 42, 0.06);
  --shadow-strong: 0 28px 70px rgba(53, 20, 42, 0.14);
  --radius-lg: 28px;
  --max-width: 1120px;
  --font-serif: "IBM Plex Serif", Georgia, "Times New Roman", serif;
  --font-sans: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --focus-ring: 0 0 0 3px rgba(176, 0, 109, 0.18);
  --focus-ring-strong: 0 0 0 4px rgba(176, 0, 109, 0.28);
  --page-gradient-start: #fffdfa;
  --page-gradient-mid: #f8f1ea;
  --page-gradient-end: var(--bg);
  --page-glow-top: rgba(176, 0, 109, 0.08);
  --page-glow-bottom: rgba(176, 0, 109, 0.05);
  --panel-overlay-start: rgba(255, 253, 249, 0.9);
  --panel-overlay-end: rgba(255, 253, 249, 0.72);
  --panel-glow: rgba(176, 0, 109, 0.05);
  --menu-overlay-start: rgba(255, 253, 249, 0.78);
  --menu-overlay-end: rgba(248, 241, 234, 0.84);
  --placeholder-start: #efebe6;
  --placeholder-end: #e8e3dd;
  --image-drop-shadow: drop-shadow(0 12px 28px rgba(40, 18, 32, 0.05));
  --modal-backdrop: rgba(39, 35, 58, 0.22);
  --status-badge-bg: rgba(255, 253, 249, 0.72);
  --status-badge-border: rgba(16, 23, 21, 0.08);
  --success: #15c26b;
  --success-ring: rgba(21, 194, 107, 0.35);
  --signature-bg: rgba(176, 0, 109, 0.08);
  --signature-border: rgba(176, 0, 109, 0.14);
  --lamp-glow: rgba(255, 214, 140, 0.12);
  --lamp-image-opacity: 0.9;
}

html[data-theme="dark"] {
  --bg: #11110f;
  --bg-elevated: #1a1916;
  --surface: #201e1a;
  --surface-strong: #1a1916;
  --surface-glass: rgba(32, 30, 26, 0.78);
  --surface-glass-soft: rgba(32, 30, 26, 0.88);
  --surface-glass-strong: rgba(26, 25, 22, 0.94);
  --text-primary: #ece7df;
  --text-secondary: #b7aea0;
  --text: var(--text-primary);
  --muted: var(--text-secondary);
  --border: #2d2a24;
  --border-soft: rgba(236, 231, 223, 0.08);
  --border-strong: rgba(236, 231, 223, 0.16);
  --line: var(--border);
  --accent: #d46aa6;
  --accent-strong: #e184b5;
  --accent-secondary: #cdbfae;
  --accent-secondary-strong: #e0d5c8;
  --accent-secondary-light: rgba(236, 231, 223, 0.06);
  --accent-secondary-line: rgba(236, 231, 223, 0.08);
  --accent-soft: rgba(212, 106, 166, 0.14);
  --text-on-accent: #11110f;
  --shadow-soft: 0 10px 24px rgba(0, 0, 0, 0.28);
  --shadow-card: 0 20px 44px rgba(0, 0, 0, 0.24);
  --shadow-panel: 0 24px 56px rgba(0, 0, 0, 0.28);
  --shadow-strong: 0 32px 72px rgba(0, 0, 0, 0.38);
  --page-gradient-start: #161512;
  --page-gradient-mid: #12110f;
  --page-gradient-end: var(--bg);
  --page-glow-top: rgba(212, 106, 166, 0.08);
  --page-glow-bottom: rgba(255, 214, 140, 0.04);
  --panel-overlay-start: rgba(33, 30, 26, 0.96);
  --panel-overlay-end: rgba(26, 25, 22, 0.92);
  --panel-glow: rgba(212, 106, 166, 0.08);
  --menu-overlay-start: rgba(17, 17, 15, 0.82);
  --menu-overlay-end: rgba(26, 25, 22, 0.9);
  --placeholder-start: #2a2721;
  --placeholder-end: #221f1a;
  --image-drop-shadow: drop-shadow(0 20px 38px rgba(0, 0, 0, 0.38));
  --modal-backdrop: rgba(7, 7, 6, 0.56);
  --status-badge-bg: rgba(26, 25, 22, 0.72);
  --status-badge-border: rgba(236, 231, 223, 0.08);
  --signature-bg: rgba(212, 106, 166, 0.12);
  --signature-border: rgba(212, 106, 166, 0.2);
  --lamp-glow: rgba(255, 214, 140, 0.16);
  --lamp-image-opacity: 0.96;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  background: var(--bg);
  color-scheme: light;
}

html[data-theme="dark"] {
  color-scheme: dark;
}

body {
  margin: 0;
  min-width: 320px;
  font-family: var(--font-sans);
  color: var(--text-primary);
  background:
    radial-gradient(circle at top left, var(--page-glow-top), transparent 24%),
    radial-gradient(circle at bottom right, var(--page-glow-bottom), transparent 20%),
    linear-gradient(180deg, var(--page-gradient-start) 0%, var(--page-gradient-mid) 54%, var(--page-gradient-end) 100%);
  line-height: 1.5;
  transition:
    background-color 220ms ease,
    color 220ms ease,
    border-color 220ms ease,
    box-shadow 220ms ease;
}

a {
  color: inherit;
}

a {
  text-decoration: none;
}

button {
  font: inherit;
}

a:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
}

button:focus-visible {
  outline: none;
}

.page-shell {
  width: min(calc(100% - 24px), var(--max-width));
  margin: 0 auto;
  padding: 24px 0 44px;
}

.site-topbar {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
  z-index: 40;
}

.site-topbar-start {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  padding-right: 60px;
}

.site-signature {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  color: var(--text-primary);
  font-family: var(--font-sans);
  font-size: 0.98rem;
  font-weight: 600;
  letter-spacing: 0.01em;
}

.site-nav {
  display: inline-flex;
  align-items: center;
  gap: 18px;
  font-family: var(--font-sans);
  font-size: 0.96rem;
  font-weight: 600;
}

.site-menu-toggle {
  display: none;
}

.js .site-menu-toggle {
  display: inline-flex;
  position: absolute;
  top: 0;
  right: 0;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  padding: 0;
  color: var(--text-primary);
  background: var(--surface-glass);
  border: 1px solid var(--line);
  border-radius: 14px;
  cursor: pointer;
  z-index: 24;
}

.site-menu-toggle-icon {
  position: absolute;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition:
    transform 160ms ease,
    opacity 160ms ease;
}

.site-menu-toggle-icon svg {
  display: block;
}

.site-menu-toggle-icon-menu {
  opacity: 1;
  transform: scale(1);
}

.site-menu-toggle-icon-close {
  opacity: 0;
  transform: scale(0.92);
}

.js .site-topbar.is-menu-open .site-menu-toggle-icon-menu {
  opacity: 0;
  transform: scale(0.92);
}

.js .site-topbar.is-menu-open .site-menu-toggle-icon-close {
  opacity: 1;
  transform: scale(1);
}

.js .site-topbar.is-menu-open .site-menu-toggle {
  position: fixed;
  top: 24px;
  right: 12px;
  z-index: 60;
  background: var(--surface-glass-strong);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.js .site-nav {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 30;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 28px;
  padding: 96px 24px 40px;
  background:
    linear-gradient(180deg, var(--menu-overlay-start) 0%, var(--menu-overlay-end) 100%);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  text-align: center;
}

.js .site-topbar.is-menu-open .site-nav {
  display: flex;
}

.site-nav-link {
  color: var(--text-primary);
  text-decoration: none;
  text-decoration-thickness: 1.5px;
  text-underline-offset: 0.24em;
  transition:
    color 160ms ease,
    text-decoration-color 160ms ease;
}

.js .site-nav-link {
  font-size: clamp(2rem, 8vw, 2.8rem);
  font-weight: 400;
  letter-spacing: -0.04em;
  line-height: 1.05;
}

.site-nav-link:hover,
.site-nav-link:focus-visible {
  color: var(--accent);
  text-decoration: underline;
  text-decoration-color: currentColor;
}

.site-nav-link[aria-current="page"],
.site-nav-link[aria-current="location"] {
  color: var(--accent);
  text-decoration: underline;
  text-decoration-color: currentColor;
}

body.site-menu-open {
  overflow: hidden;
}

.signature-mark {
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  background: var(--signature-bg);
  border: 2px solid var(--signature-border);
  box-shadow: var(--shadow-soft);
}

.signature-mark img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center 26%;
}

.hero {
  min-height: auto;
  display: grid;
  gap: 32px;
  padding: 32px 24px;
  background:
    linear-gradient(180deg, var(--panel-overlay-start) 0%, var(--panel-overlay-end) 100%),
    radial-gradient(circle at top right, var(--panel-glow), transparent 24%),
    var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-panel);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.hero-copy {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
}

.theme-lamp {
  position: relative;
  display: grid;
  place-items: center;
  width: min(100%, 320px);
  padding: 10px;
  border-radius: 32px;
}

.theme-lamp::before {
  content: "";
  position: absolute;
  left: 60%;
  top: 30%;
  width: 42%;
  height: 42%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background: radial-gradient(circle, var(--lamp-glow) 0%, transparent 72%);
  filter: blur(18px);
  opacity: 0.88;
  pointer-events: none;
  transition: opacity 180ms ease, transform 180ms ease;
}

html[data-theme="dark"] .theme-lamp::before {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1.04);
}

.theme-lamp-glow {
  position: absolute;
  left: 60%;
  top: 30%;
  width: 30%;
  height: 30%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background: radial-gradient(circle, var(--lamp-glow) 0%, transparent 75%);
  filter: blur(22px);
  pointer-events: none;
}

.hero-visual {
  display: grid;
  place-items: center;
  gap: 18px;
  width: min(100%, 320px);
  justify-self: center;
  justify-items: center;
  padding: 0;
  min-width: 0;
}

.hero-visual img {
  width: min(100%, 280px);
  height: auto;
  object-fit: contain;
  transform: scaleX(-1);
  transform-origin: center;
  opacity: var(--lamp-image-opacity);
  filter: var(--image-drop-shadow);
}

.theme-toggle {
  position: relative;
  display: inline-grid;
  grid-template-columns: auto auto auto;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  color: var(--text-primary);
  background: var(--surface-glass);
  border: 1px solid var(--border-soft);
  border-radius: 999px;
  box-shadow: 0 10px 24px rgba(24, 20, 16, 0.08);
  cursor: pointer;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease;
}

html[data-theme="dark"] .theme-toggle {
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.24);
}

.theme-toggle:hover,
.theme-toggle:focus-visible {
  transform: translateY(-2px);
  border-color: var(--accent-secondary-line);
  box-shadow: var(--shadow-card);
}

.theme-toggle:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring-strong);
}

.theme-toggle-icon {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  color: var(--text-secondary);
  background: transparent;
  transition:
    color 180ms ease,
    background 180ms ease,
    transform 180ms ease;
}

html[data-theme="light"] .theme-toggle-icon-sun,
html[data-theme="dark"] .theme-toggle-icon-moon {
  color: var(--text-on-accent);
  background: var(--accent);
  transform: scale(1.02);
}

.theme-toggle-track {
  position: relative;
  width: 48px;
  height: 26px;
  border-radius: 999px;
  background: var(--accent-secondary-light);
  border: 1px solid var(--border-soft);
  box-shadow: inset 0 2px 8px rgba(24, 20, 16, 0.12);
}

.theme-toggle-thumb {
  position: absolute;
  top: 3px;
  left: 3px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 6px 14px rgba(24, 20, 16, 0.18);
  transition: transform 220ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

html[data-theme="dark"] .theme-toggle-thumb {
  transform: translateX(22px);
}

.status-badge {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: fit-content;
  min-height: 34px;
  margin: 0;
  padding: 0 12px 0 10px;
  color: var(--text-primary);
  background: var(--status-badge-bg);
  border: 1px solid var(--status-badge-border);
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 600;
  font-family: var(--font-sans);
  letter-spacing: 0.01em;
}

.status-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--success);
  box-shadow: 0 0 0 0 var(--success-ring);
  animation: live-pulse 1.8s ease-out infinite;
}

h1,
h2,
h3 {
  margin: 0;
  font-family: var(--font-serif);
  letter-spacing: -0.04em;
  line-height: 1;
}

h1 {
  max-width: none;
  font-size: clamp(2.6rem, 11vw, 4.5rem);
  font-weight: 500;
  white-space: normal;
}

h2 {
  font-size: clamp(2rem, 8vw, 3rem);
  font-weight: 400;
}

h3 {
  font-size: 1.5rem;
  font-weight: 400;
}

.hero-tagline {
  max-width: 18ch;
  margin: 0;
  font-family: var(--font-serif);
  font-size: clamp(2rem, 8vw, 3.5rem);
  font-weight: 500;
  line-height: 1;
}

.hero-text {
  max-width: 58ch;
  margin: 16px 0 0;
  color: var(--muted);
  font-family: var(--font-sans);
  font-size: 1.02rem;
  line-height: 1.65;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 30px;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  gap: 10px;
  padding: 0 22px;
  color: inherit;
  border-radius: 14px;
  text-decoration: none;
  font-family: var(--font-sans);
  font-weight: 600;
  transition:
    transform 160ms ease,
    background-color 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease;
}

.button:hover,
.button:focus-visible {
  color: var(--accent);
}

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

.button-primary {
  background: var(--accent);
  color: var(--text-on-accent);
  border: 1px solid transparent;
}

.button-secondary {
  color: var(--text);
  border: 1px solid var(--line);
  background: var(--surface-strong);
}

.button-primary:hover,
.button-primary:focus-visible {
  color: var(--text-on-accent);
  background: var(--accent-strong);
}

.button-secondary:hover,
.button-secondary:focus-visible {
  color: var(--text);
  background: var(--bg-elevated);
}

.projects-section {
  margin-top: 40px;
}

.section-heading {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 16px;
  margin-bottom: 24px;
}

.section-heading h2 {
  color: var(--accent-secondary-strong);
  font-family: var(--font-sans);
  font-size: 0.92rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.section-line {
  display: block;
  height: 1px;
  background: var(--border-strong);
}

.projects-grid {
  display: grid;
  gap: 20px;
  padding: 4px;
  margin: -4px;
}

.project-card {
  overflow: visible;
  background: var(--surface-glass-soft);
  border: 1px solid var(--line);
  border-radius: 24px;
  box-shadow: var(--shadow-card);
}

.project-card-link {
  transition:
    transform 160ms ease,
    box-shadow 160ms ease,
    border-color 160ms ease;
}

.project-link {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  border-radius: inherit;
}

.project-button {
  width: 100%;
  padding: 0;
  color: inherit;
  text-align: left;
  background: transparent;
  border: 0;
  cursor: pointer;
}

.project-link:hover {
  color: inherit;
}

.project-link:focus-visible {
  border-radius: 24px;
  box-shadow: none;
}

.project-card-link:hover,
.project-card-link:focus-visible,
.project-card-link:focus-within {
  transform: translateY(-2px);
  outline: none;
  border-color: var(--accent-soft);
  box-shadow: var(--shadow-panel);
}

.project-card-link:active {
  transform: translateY(-1px);
}

.project-card-link:focus-within {
  border-color: var(--accent-soft);
  box-shadow: var(--shadow-panel);
}

.project-placeholder {
  width: auto;
  margin: 14px;
  aspect-ratio: 16 / 9;
  border-radius: 16px;
  background: linear-gradient(180deg, var(--placeholder-start) 0%, var(--placeholder-end) 100%);
  border: 1px solid var(--border-soft);
}

.project-image {
  display: block;
  width: 100%;
  aspect-ratio: 328 / 184;
  object-fit: cover;
  border-bottom: 1px solid var(--border-soft);
  border-radius: 24px 24px 0 0;
  background: linear-gradient(180deg, var(--placeholder-start) 0%, var(--placeholder-end) 100%);
}

.project-copy {
  padding: 18px 20px 22px;
}

.project-tag {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 26px;
  margin: 0 0 12px;
  padding: 0 8px;
  color: var(--accent-secondary);
  background: var(--accent-secondary-light);
  border: 1px solid var(--accent-secondary-line);
  border-radius: 999px;
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}

.project-protected-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--muted);
  line-height: 1;
  flex-shrink: 0;
}

.project-protected-icon svg,
.project-protected-icon .lucide {
  display: block;
  width: 16px;
  height: 16px;
}

.project-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.project-title-with-icon {
  min-width: 0;
}

.project-external-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  color: var(--muted);
  flex-shrink: 0;
}

.project-external-icon svg,
.project-external-icon .lucide {
  display: block;
  width: 100%;
  height: 100%;
}


.about-main {
  padding-top: 0;
}

.about-card {
  display: grid;
  gap: 28px;
  padding: 32px 24px;
  background:
    linear-gradient(180deg, var(--panel-overlay-start) 0%, var(--panel-overlay-end) 100%),
    radial-gradient(circle at top right, var(--panel-glow), transparent 30%),
    var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-panel);
}

.about-photo {
  display: grid;
  place-items: center;
  gap: 16px;
  min-height: 280px;
  background: transparent;
  text-align: center;
}

.about-photo span {
  max-width: 16ch;
  color: var(--muted);
  font-family: var(--font-sans);
  font-size: 0.95rem;
  line-height: 1.6;
}

.about-photo img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: inherit;
  object-fit: cover;
  border-radius: 24px;
}


.about-copy {
  max-width: 60ch;
}

.about-title {
  margin: 0;
  font-family: var(--font-serif);
  font-size: clamp(2rem, 8vw, 3.5rem);
  font-weight: 500;
  line-height: 1;
}

.about-lead {
  margin-top: 18px;
}

.about-copy p + p {
  margin-top: 14px;
}

.about-copy .hero-text a {
  color: var(--text);
  font-weight: 500;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.18em;
}

.about-copy .hero-text a:hover,
.about-copy .hero-text a:focus-visible {
  color: var(--accent);
}

.about-inline-link,
.about-inline-link:visited {
  color: var(--text);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.18em;
}

.about-inline-link:hover,
.about-inline-link:focus-visible {
  color: var(--accent);
}

.about-home-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 24px;
  color: var(--accent);
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 600;
  text-decoration: none;
}

.about-home-link:hover,
.about-home-link:focus-visible {
  text-decoration: underline;
  text-underline-offset: 0.18em;
}

.site-footer {
  padding: 56px 4px 0;
  content-visibility: auto;
  contain-intrinsic-size: 1px 180px;
}

.site-footer p {
  margin: 0;
  color: var(--muted);
  font-family: var(--font-sans);
  font-size: 0.92rem;
  text-align: center;
}

.footer-note + .footer-links {
  margin-top: 10px;
}

.site-footer span {
  color: var(--accent);
}

.site-footer a {
  color: inherit;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.16em;
}

.site-footer a:hover,
.site-footer a:focus-visible {
  color: var(--accent);
}

.footer-separator {
  margin: 0 0.45em;
}

.contact-modal {
  width: min(calc(100% - 24px), 560px);
  padding: 28px;
  border: 1px solid var(--line);
  border-radius: 24px;
  background: var(--surface-glass-strong);
  box-shadow: var(--shadow-strong);
}

.contact-modal:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring-strong), var(--shadow-strong);
}

.contact-modal::backdrop {
  background: var(--modal-backdrop);
  backdrop-filter: blur(8px);
}

.contact-modal-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}

.contact-modal-kicker {
  margin: 0;
  padding-top: 14px;
  color: var(--accent-secondary-strong);
  font-family: var(--font-sans);
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.contact-modal-close {
  flex-shrink: 0;
  min-height: 40px;
  min-width: 40px;
  padding: 0;
  color: var(--muted);
  font-size: 1.6rem;
  line-height: 1;
  background: transparent;
  border: 0;
  cursor: pointer;
}

.contact-modal-close:focus-visible {
  box-shadow: var(--focus-ring-strong);
  border-radius: 8px;
}

.contact-modal-text {
  margin: 16px 0 0;
  color: var(--muted);
  font-family: var(--font-sans);
  font-size: 1rem;
  line-height: 1.65;
}

.contact-modal-text a {
  color: var(--accent);
  font-weight: 600;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.16em;
}

.contact-modal-text a:hover,
.contact-modal-text a:focus-visible {
  color: var(--accent);
}

.contact-modal-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 26px;
}

.password-gate-form {
  margin-top: 22px;
}

.password-gate-label {
  display: block;
  margin-bottom: 8px;
  color: var(--text);
  font-family: var(--font-sans);
  font-size: 0.92rem;
  font-weight: 600;
}

.password-gate-field {
  position: relative;
}

.password-gate-input {
  width: 100%;
  min-height: 54px;
  padding: 0 56px 0 16px;
  color: var(--text);
  background: var(--surface-glass-strong);
  border: 1px solid var(--border-strong);
  border-radius: 14px;
  font: inherit;
}

.password-gate-input:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
  border-color: var(--accent);
}

.password-gate-toggle {
  position: absolute;
  top: 50%;
  right: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  padding: 0;
  color: var(--muted);
  background: transparent;
  border: 0;
  border-radius: 999px;
  cursor: pointer;
  transform: translateY(-50%);
}

.password-gate-toggle-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.password-gate-icon {
  display: block;
  width: 20px;
  height: 20px;
}

.password-gate-icon.is-hidden {
  display: none;
}

.password-gate-toggle:hover,
.password-gate-toggle:focus-visible {
  color: var(--accent);
}

.password-gate-toggle:focus-visible {
  box-shadow: var(--focus-ring);
}

.password-gate-error {
  margin: 10px 0 0;
  font-family: var(--font-sans);
  font-size: 0.9rem;
  line-height: 1.5;
}

.password-gate-error {
  color: var(--accent-strong);
  font-weight: 600;
}

.case-study-shell {
  width: min(calc(100% - 24px), 960px);
  margin: 0 auto;
  padding: 24px 0 56px;
}

.case-study-hero {
  padding: 32px 24px;
  background:
    linear-gradient(180deg, var(--panel-overlay-start) 0%, var(--panel-overlay-end) 100%),
    radial-gradient(circle at top right, var(--panel-glow), transparent 26%),
    var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-panel);
}

.case-study-hero-grid {
  display: grid;
  gap: 24px;
}

.case-study-hero-copy {
  min-width: 0;
}

.case-study-kicker {
  margin: 0 0 12px;
  color: var(--accent-secondary-strong);
  font-family: var(--font-sans);
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.case-study-intro {
  max-width: 62ch;
  margin: 18px 0 0;
  color: var(--muted);
  font-family: var(--font-sans);
  font-size: 1.02rem;
  line-height: 1.7;
}

.case-study-meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 24px;
}

.case-study-meta-item {
  position: relative;
  padding: 14px 16px;
  background: var(--surface-glass);
  border: 1px solid var(--border-soft);
  border-radius: 18px;
}

.case-study-meta-copy {
  min-width: 0;
}

.case-study-meta-label {
  display: block;
  color: var(--accent-secondary-strong);
  font-family: var(--font-sans);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.case-study-meta-value {
  display: block;
  margin-top: 8px;
  color: var(--text);
  font-family: var(--font-sans);
  font-size: 0.98rem;
  font-weight: 600;
  line-height: 1.3;
}

.tp-lucide-meta {
  width: 1rem;
  height: 1rem;
  position: absolute;
  top: 14px;
  right: 16px;
  color: var(--accent-secondary-strong);
}

.case-study-hero-note {
  max-width: 58ch;
  margin: 18px 0 0;
  color: var(--muted);
  font-family: var(--font-sans);
  font-size: 0.98rem;
  line-height: 1.65;
}

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

.case-study-metrics-band {
  margin-top: 18px;
}

.case-study-metric {
  padding: 16px;
  background: var(--surface-glass);
  border: 1px solid var(--border-soft);
  border-radius: 18px;
}

.case-study-metric strong {
  display: block;
  font-family: var(--font-serif);
  font-size: 1.7rem;
  font-weight: 500;
  letter-spacing: -0.04em;
  line-height: 1;
}

.case-study-metric-trend {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  flex-wrap: nowrap;
  white-space: nowrap;
  width: 100%;
  font-family: var(--font-serif);
  font-size: 1.7rem;
  font-weight: 500;
  letter-spacing: -0.04em;
  line-height: 1;
}

.case-study-metric strong.case-study-metric-trend span {
  margin-top: 0;
  color: inherit;
  font: inherit;
  line-height: inherit;
}

.case-study-metrics-three-up {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.case-study-metrics-three-up .case-study-metric,
.case-study-metrics-four-up .case-study-metric {
  min-width: 0;
}

.case-study-metric span {
  display: block;
  margin-top: 8px;
  color: var(--muted);
  font-family: var(--font-sans);
  font-size: 0.92rem;
  line-height: 1.45;
}

.case-study-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 28px;
}

.case-study-section {
  margin-top: 28px;
  padding: 24px;
  background: var(--surface-glass-soft);
  border: 1px solid var(--line);
  border-radius: 24px;
  box-shadow: var(--shadow-card);
}

.case-study-section p {
  margin: 12px 0 0;
  color: var(--muted);
  font-family: var(--font-sans);
  line-height: 1.7;
}

.case-study-section-head {
  max-width: 60ch;
}

.case-study-section-kicker {
  margin: 0 0 12px;
  color: var(--accent-secondary-strong);
  font-family: var(--font-sans);
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.app-referral-case-study .case-study-section-kicker {
  margin-bottom: 12px;
  color: var(--accent-secondary-strong);
}

.case-study-shell .case-study-section-kicker {
  color: var(--accent-secondary-strong);
}

.case-study-section-head h2 {
  margin: 0;
  line-height: 1.02;
}

#app-usability-title {
  font-weight: 400;
}

.case-study-section-head h2 + .case-study-section-kicker {
  margin: 14px 0 0;
}

.case-study-section-intro {
  margin: 16px 0 12px;
}

.case-study-facts {
  display: grid;
  gap: 16px;
  margin-top: 22px;
}

.case-study-context-blocks {
  display: grid;
  gap: 0;
  margin-top: 24px;
}

#case-study-context .case-study-context-blocks {
  margin-top: 16px;
}

.case-study-context-item {
  min-width: 0;
  padding: 20px 0 0;
  border-top: 1px solid var(--border-soft);
}

.case-study-context-item:first-child {
  border-top: 0;
  padding-top: 0;
}

.case-study-context-item h3 {
  margin: 0;
  color: var(--accent-secondary-strong);
  font-family: var(--font-sans);
  font-size: 0.94rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.case-study-context-item p {
  max-width: 54ch;
  margin-top: 12px;
}

.case-study-context-layout,
.case-study-context-copy {
  min-width: 0;
}

.case-study-legacy-gallery {
  display: grid;
  gap: 12px;
  margin-top: 18px;
}

.case-study-legacy-shot {
  margin: 0;
  overflow: hidden;
  border: 1px solid var(--border-soft);
  border-radius: 18px;
  background: var(--surface-glass-strong);
  box-shadow: var(--shadow-panel);
}

.case-study-legacy-shot img {
  display: block;
  width: 100%;
  height: auto;
}

.case-study-business-goals {
  display: grid;
  gap: 18px;
  margin-top: 24px;
}

.case-study-business-goal {
  padding: 22px;
  background: var(--surface-glass);
  border: 1px solid var(--border-soft);
  border-radius: 20px;
}

.case-study-business-goal-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  margin-bottom: 18px;
  color: var(--accent);
  background: linear-gradient(180deg, var(--surface-glass-strong) 0%, var(--surface-glass) 100%);
  border: 1px solid var(--accent-soft);
  border-radius: 18px;
}

.case-study-business-goal-icon svg {
  display: block;
  width: 28px;
  height: 28px;
}

.tp-lucide {
  display: block;
  width: 20px;
  height: 20px;
  stroke-width: 1.75;
}

.tp-lucide-card {
  width: 28px;
  height: 28px;
}

.tp-lucide-nav {
  width: 18px;
  height: 18px;
}

.tp-lucide-metric {
  width: 28px;
  height: 28px;
  stroke-width: 2.4;
}

.case-study-business-goal h3 {
  margin: 0;
  color: var(--accent-secondary-strong);
  font-family: var(--font-sans);
  font-size: 0.94rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  line-height: 1.3;
}

.case-study-business-goal p {
  max-width: 30ch;
  margin-top: 12px;
}

.case-study-analysis-blocks {
  margin-top: 26px;
}

.case-study-fact {
  padding: 18px;
  background: var(--surface-glass);
  border: 1px solid var(--border-soft);
  border-radius: 18px;
}

.case-study-fact h3,
.case-study-process-step h3,
.case-study-impact-card h3 {
  font-family: var(--font-sans);
  font-size: 1.08rem;
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1.3;
}

.case-study-fact p {
  margin-top: 10px;
}

.case-study-split {
  display: grid;
  gap: 22px;
}

.case-study-copy-block,
.case-study-visual-block,
.case-study-visual-stack {
  min-width: 0;
}

.case-study-columns {
  display: grid;
  gap: 18px;
  margin-top: 22px;
}

.case-study-editorial-grid {
  display: grid;
  gap: 20px;
  margin-top: 22px;
}

.case-study-editorial-copy,
.case-study-editorial-visual {
  min-width: 0;
  margin: 0;
}

.case-study-usability-copy {
  margin-top: 22px;
}

.case-study-chip-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 20px;
}

.case-study-chip {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  color: var(--accent-secondary-strong);
  background: var(--surface-glass-soft);
  border: 1px solid var(--border-soft);
  border-radius: 999px;
  font-family: var(--font-sans);
  font-size: 0.88rem;
  line-height: 1;
}

.case-study-results-stack {
  display: grid;
  gap: 16px;
}

.case-study-results-kpis {
  margin-top: 22px;
}

.case-study-results-stack.case-study-usability-stats {
  margin-top: 22px;
  padding-bottom: 16px;
  grid-template-columns: 1fr;
}

.case-study-result-stat {
  padding: 20px;
  background: var(--surface-glass);
  border: 1px solid var(--border-soft);
  border-radius: 20px;
}

.case-study-result-stat strong {
  display: block;
  font-family: var(--font-serif);
  font-size: 1.8rem;
  font-weight: 500;
  letter-spacing: -0.04em;
  line-height: 1;
}

.case-study-result-stat strong.case-study-metric-trend {
  font-size: 1.7rem;
}

.case-study-result-stat strong.case-study-metric-trend span {
  margin-top: 0;
  color: inherit;
  font: inherit;
  line-height: inherit;
}

.case-study-result-stat strong.case-study-metric-trend .tp-lucide-metric {
  flex: 0 0 28px;
}

.case-study-result-stat p {
  margin-top: 10px;
  max-width: 34ch;
}

.case-study-results-stack.case-study-usability-stats .case-study-result-stat p {
  max-width: none;
}

.case-study-usability-shot {
  margin-top: 32px;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.case-study-list {
  margin: 20px 0 0;
  padding-left: 1.2rem;
  color: var(--text);
  font-family: var(--font-sans);
}

.case-study-list li + li {
  margin-top: 10px;
}

.case-study-solution-list {
  margin-top: 24px;
  padding-left: 0;
  list-style: none;
}

.case-study-solution-list li {
  position: relative;
  padding-left: 28px;
  color: var(--muted);
  font-family: var(--font-sans);
  font-size: 1rem;
  line-height: 1.55;
}

.case-study-solution-list li::before {
  content: "";
  position: absolute;
  top: 0.52em;
  left: 0;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--accent);
}

.case-study-check-list {
  padding-left: 0;
  list-style: none;
}

.case-study-check-list li {
  position: relative;
  padding-left: 30px;
  color: var(--muted);
  font-family: var(--font-sans);
  font-size: 1rem;
  line-height: 1.55;
}

.case-study-check-list li::before {
  content: "";
  position: absolute;
  top: 0.16em;
  left: 0;
  width: 18px;
  height: 18px;
  background:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Cpolygon points='14 21.414 9 16.413 10.413 15 14 18.586 21.585 11 23 12.415 14 21.414' fill='%23b0006d'/%3E%3Cpath d='M16 2A14 14 0 1 0 30 16 14 14 0 0 0 16 2Zm0 26A12 12 0 1 1 28 16 12 12 0 0 1 16 28Z' fill='%23b0006d'/%3E%3C/svg%3E")
    center / contain no-repeat;
}

.case-study-caption {
  margin-top: 18px;
  color: var(--muted);
  font-size: 0.94rem;
}

.case-study-process-grid {
  display: grid;
  gap: 18px;
  margin-top: 24px;
}

.case-study-process-step,
.case-study-impact-card {
  padding: 20px;
  background: var(--surface-glass);
  border: 1px solid var(--border-soft);
  border-radius: 20px;
}

.case-study-process-shot {
  margin: 20px 0 0;
  overflow: hidden;
  border: 1px solid var(--border-soft);
  border-radius: 18px;
  background: var(--surface-glass-strong);
}

.case-study-process-shot img {
  display: block;
  width: 100%;
  height: auto;
}

.case-study-placeholder {
  display: grid;
  gap: 10px;
  align-content: end;
  min-height: 220px;
  padding: 18px;
  background:
    linear-gradient(180deg, var(--panel-overlay-start) 0%, var(--panel-overlay-end) 100%),
    linear-gradient(135deg, var(--accent-soft), transparent);
  border: 1px dashed var(--accent-soft);
  border-radius: 20px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

.case-study-placeholder-hero {
  min-height: 320px;
}

.case-study-hero-shot {
  height: 100%;
  margin: 0;
  overflow: hidden;
  border: 1px solid var(--border-soft);
  border-radius: 22px;
  background: var(--surface-glass-strong);
  box-shadow: var(--shadow-card);
}

.case-study-hero-shot picture {
  display: block;
}

.case-study-hero-shot img {
  display: block;
  width: 100%;
  height: auto;
}

.case-study-app-hero-shot {
  border: 0;
  background: transparent;
  box-shadow: none;
}

.case-study-placeholder-label {
  color: var(--text);
  font-family: var(--font-sans);
  font-size: 0.92rem;
  font-weight: 600;
}

.case-study-placeholder-note {
  color: var(--muted);
  font-family: var(--font-sans);
  font-size: 0.88rem;
  line-height: 1.5;
}

.case-study-visual-stack {
  display: grid;
  gap: 16px;
}

.case-study-team-visual {
  margin-top: 12px;
}

.case-study-tech-title {
  margin: 24px 0 0;
  color: var(--accent-secondary-strong);
  font-family: var(--font-sans);
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  line-height: 1;
  text-transform: uppercase;
}

.case-study-tech-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 12px;
}

.case-study-tech-card {
  display: grid;
  place-items: center;
  gap: 12px;
  min-height: 132px;
  padding: 20px 14px;
  text-align: center;
  background: var(--surface-glass-strong);
  border: 1px solid var(--border-soft);
  border-radius: 20px;
  box-shadow: var(--shadow-soft);
}

.case-study-tech-card img {
  display: block;
  width: 48px;
  height: 48px;
  object-fit: contain;
}

.case-study-tech-card span {
  color: var(--text);
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1.2;
}

.case-study-solution-shot {
  margin: 0;
  overflow: hidden;
  border: 1px solid var(--border-soft);
  border-radius: 20px;
  background: var(--surface-glass-strong);
  box-shadow: var(--shadow-panel);
}

.case-study-solution-shot img {
  display: block;
  width: 100%;
  height: auto;
}

.case-study-hero-shot img,
.case-study-solution-shot img {
  cursor: zoom-in;
}

.case-study-hero-shot img:focus-visible,
.case-study-solution-shot img:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring-strong);
}

.case-study-usability-shot img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.case-study-lightbox {
  width: min(calc(100% - 24px), 1180px);
  max-height: calc(100dvh - 32px);
  padding: 0;
  overflow: visible;
  background: transparent;
  border: 0;
}

.case-study-lightbox::backdrop {
  background: rgba(17, 17, 15, 0.82);
  backdrop-filter: blur(8px);
}

.case-study-lightbox-image {
  display: block;
  max-width: 100%;
  max-height: calc(100dvh - 32px);
  margin: auto;
  object-fit: contain;
  border-radius: 14px;
  box-shadow: 0 28px 80px rgba(0, 0, 0, 0.38);
  cursor: default;
}

.case-study-lightbox-close {
  position: absolute;
  top: -14px;
  right: -14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  padding: 0;
  color: var(--text);
  background: var(--surface-strong);
  border: 1px solid var(--border-strong);
  border-radius: 999px;
  box-shadow: var(--shadow-card);
  cursor: pointer;
}

.case-study-lightbox-close:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring-strong), var(--shadow-card);
}

.case-study-impact-grid {
  display: grid;
  gap: 18px;
  margin-top: 22px;
}

.case-study-learnings-grid {
  display: grid;
  gap: 18px;
  margin-top: 22px;
}

.case-study-learning-card {
  padding: 22px;
  background: var(--surface-glass);
  border: 1px solid var(--border-soft);
  border-radius: 20px;
}

.case-study-learning-icon {
  margin-bottom: 10px;
}

.case-study-learning-card h3 {
  margin-top: 0;
  color: var(--accent-secondary-strong);
  font-family: var(--font-sans);
  font-size: 0.94rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  line-height: 1.3;
}

.case-study-learning-card p {
  margin-top: 12px;
  max-width: 26ch;
}

.case-study-cta {
  margin: 28px 0 18px;
}

.site-signature-link:hover,
.site-signature-link:focus-visible {
  color: inherit;
}

.archive-hero {
  padding: 16px 0 8px;
}

.archive-kicker {
  margin: 0 0 12px;
  color: var(--accent-secondary-strong);
  font-family: var(--font-sans);
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.archive-page h1 {
  max-width: 14ch;
}

.archive-intro {
  max-width: 64ch;
  margin: 20px 0 0;
  color: var(--muted);
  font-family: var(--font-sans);
  font-size: 1.04rem;
  line-height: 1.7;
}

.archive-grid {
  display: grid;
  gap: 18px;
  margin-top: 28px;
  content-visibility: auto;
  contain-intrinsic-size: 1px 1800px;
}

.archive-card {
  display: flex;
  flex-direction: column;
  padding: 24px;
  background: var(--surface-glass-soft);
  border: 1px solid var(--line);
  border-radius: 24px;
  box-shadow: var(--shadow-card);
}

.archive-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 14px;
}

.archive-meta span {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 9px;
  color: var(--accent-secondary);
  background: var(--accent-secondary-light);
  border: 1px solid var(--accent-secondary-line);
  border-radius: 999px;
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}

.archive-subtitle {
  margin: 10px 0 0;
  color: var(--text);
  font-family: var(--font-serif);
  font-size: 1.12rem;
  line-height: 1.25;
}

.archive-card p:last-child {
  margin: 14px 0 0;
  color: var(--muted);
  font-family: var(--font-sans);
  line-height: 1.7;
}

.archive-card a {
  color: var(--accent);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.16em;
}

.archive-card a:hover,
.archive-card a:focus-visible {
  color: var(--accent-strong);
}

.archive-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: auto;
  padding-top: 18px;
}

.archive-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 0 22px;
  color: var(--text-on-accent);
  background: var(--accent);
  border: 1px solid transparent;
  border-radius: 14px;
  font-family: var(--font-sans);
  font-size: 1rem;
  font-weight: 600;
  transition:
    transform 160ms ease,
    background-color 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease;
  text-decoration: none;
}

.archive-card a.archive-action {
  color: var(--text-on-accent);
  text-decoration: none;
}

.archive-action:hover,
.archive-action:focus-visible {
  color: var(--text-on-accent);
  background: var(--accent-strong);
  text-decoration: none;
  transform: translateY(-1px);
}

.archive-action-muted {
  color: var(--muted);
  background: var(--surface-strong);
  border-color: var(--border-soft);
  font-size: 1rem;
  font-weight: 600;
}

.archive-home-link {
  align-self: flex-end;
  min-height: 44px;
  padding: 0 16px;
  color: var(--text);
}

.archive-home-link-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  line-height: 0;
}

.archive-home-link-icon svg,
.archive-home-link-icon .lucide,
.archive-home-link-icon img {
  display: block;
  width: 100%;
  height: 100%;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

@media (min-width: 721px) {
  .page-shell {
    width: min(calc(100% - 40px), var(--max-width));
    padding: 36px 0 64px;
  }

  .site-topbar {
    gap: 24px;
    margin-bottom: 16px;
  }

  .site-topbar-start {
    gap: 16px;
    padding-right: 0;
  }

  .site-menu-toggle,
  .js .site-menu-toggle {
    display: none;
  }

  .site-nav,
  .js .site-nav {
    position: static;
    display: inline-flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    gap: 24px;
    min-width: 0;
    padding: 0;
    background: transparent;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

  .js .site-nav-link {
    font-size: 0.96rem;
    font-weight: 600;
    letter-spacing: normal;
    line-height: normal;
  }

  .hero {
    grid-template-columns: minmax(0, 1.15fr) minmax(200px, 0.55fr);
    align-items: center;
    gap: 52px;
    min-height: calc(100vh - 92px);
    padding: 68px 56px;
  }

  .hero-visual {
    justify-self: end;
    justify-items: center;
  }

  h1 {
    font-size: clamp(3.1rem, 5.4vw, 4.3rem);
  }

  .hero-text {
    font-size: 1.04rem;
  }

  .projects-section {
    margin-top: 48px;
  }

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


  .about-card {
    grid-template-columns: minmax(280px, 0.8fr) minmax(0, 1fr);
    align-items: center;
    gap: 40px;
    padding: 48px 40px;
  }

  .about-photo {
    min-height: 360px;
  }

  .site-footer {
    padding-top: 72px;
  }

  .archive-home-link {
    align-self: auto;
  }

  .case-study-shell {
    width: min(calc(100% - 40px), 960px);
    padding: 36px 0 72px;
  }

  .case-study-hero {
    padding: 48px 40px;
  }

  .case-study-hero-grid {
    grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.8fr);
    align-items: stretch;
    gap: 28px;
  }

  .case-study-metrics {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .case-study-meta {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .case-study-facts {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .case-study-context-blocks {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .case-study-context-item {
    padding-top: 0;
    border-top: 0;
  }

  .case-study-context-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
    align-items: center;
    gap: 24px;
  }

  .case-study-legacy-gallery {
    position: relative;
    margin-top: 0;
    justify-self: end;
    width: min(100%, 520px);
    min-height: 290px;
    padding-top: 0;
  }

  .case-study-legacy-shot {
    position: relative;
    width: 66%;
  }

  .case-study-legacy-shot:first-child {
    position: absolute;
    top: 0;
    right: 88px;
    z-index: 2;
  }

  .case-study-legacy-shot:last-child {
    position: absolute;
    right: 0;
    bottom: 0;
    width: 72%;
  }

  .case-study-business-goals {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .case-study-split {
    grid-template-columns: minmax(0, 1fr) minmax(320px, 0.9fr);
    align-items: start;
  }

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

  .case-study-editorial-grid {
    grid-template-columns: minmax(0, 1.02fr) minmax(320px, 0.84fr);
    align-items: start;
  }

  .case-study-tech-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .case-study-process-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .case-study-impact-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .case-study-results-kpis {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .app-referral-case-study .case-study-results-kpis {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .case-study-learnings-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (min-width: 900px) {
  .case-study-results-stack.case-study-usability-stats {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 420px) {
  h1 {
    font-size: clamp(2.45rem, 9.8vw, 3.1rem);
  }

  .hero-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .button {
    width: 100%;
  }

  .contact-modal-actions {
    flex-direction: column;
  }

  .hero-visual {
    padding: 8px 0 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  body,
  .button,
  .theme-lamp,
  .theme-lamp::before,
  .theme-toggle,
  .theme-toggle-icon,
  .theme-toggle-thumb {
    transition: none;
  }

  .status-dot {
    animation: none;
  }
}

@keyframes live-pulse {
  0% {
    box-shadow: 0 0 0 0 var(--success-ring);
  }

  70% {
    box-shadow: 0 0 0 8px rgba(21, 194, 107, 0);
  }

  100% {
    box-shadow: 0 0 0 0 rgba(21, 194, 107, 0);
  }
}


.product-hub-body {
  background:
    radial-gradient(circle at top left, var(--page-glow-top), transparent 24%),
    radial-gradient(circle at bottom right, var(--page-glow-bottom), transparent 20%),
    linear-gradient(180deg, var(--page-gradient-start) 0%, var(--page-gradient-mid) 54%, var(--page-gradient-end) 100%);
}

.product-hub-shell {
  width: min(calc(100% - 24px), 1120px);
  margin: 0 auto;
  padding: 24px 0 56px;
}

.product-hub-main {
  display: grid;
  gap: 22px;
}

.product-hub-hero,
.product-hub-section {
  border: 1px solid var(--border);
  box-shadow: var(--shadow-card);
}

.product-hub-hero {
  display: grid;
  gap: 24px;
  padding: 28px 20px;
  background:
    linear-gradient(180deg, var(--panel-overlay-start) 0%, var(--panel-overlay-end) 100%),
    radial-gradient(circle at top right, var(--panel-glow), transparent 28%);
  border-radius: 30px;
  overflow: hidden;
}

.product-hub-eyebrow {
  display: inline-flex;
  align-items: center;
  margin: 0;
  color: var(--accent-secondary-strong);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.product-hub-eyebrow::before {
  content: none;
}

.product-hub-hero-copy h1 {
  margin-top: 14px;
  max-width: 11ch;
  font-size: clamp(2.6rem, 10vw, 4.6rem);
  line-height: 0.96;
}

.product-hub-intro,
.product-hub-section-note {
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.7;
}

.product-hub-intro {
  max-width: 62ch;
  margin: 16px 0 0;
}

.product-hub-kpis {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 18px;
}

.product-hub-kpi {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 14px 12px;
  background: var(--surface-glass);
  border: 1px solid var(--border-soft);
  border-radius: 18px;
}

.product-hub-kpi-value {
  display: block;
  color: var(--text-primary);
  font-family: var(--font-serif);
  font-size: 1.55rem;
  font-weight: 500;
  letter-spacing: -0.04em;
  line-height: 1;
}

.product-hub-kpi-value--star {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
}

.product-hub-kpi-star {
  width: 17px;
  height: 17px;
  color: #e4bf67;
  fill: currentColor;
  stroke: currentColor;
  stroke-width: 1.8;
  flex-shrink: 0;
  transform: translateY(-1px);
}

.product-hub-kpi-label {
  display: block;
  margin-top: 8px;
  color: var(--muted);
  font-size: 0.84rem;
  line-height: 1;
}

.product-hub-spotlight {
  display: grid;
  margin: 0 -20px -28px;
}

.product-hub-spotlight-frame {
  margin: 0;
  overflow: hidden;
  min-height: 260px;
  padding: 0;
  background: transparent;
  border-radius: 0;
}

.product-hub-spotlight-frame img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  border: 0;
  border-radius: 0;
}

.product-hub-section {
  padding: 24px 20px;
  background: var(--surface-glass-soft);
  border-radius: 28px;
}

.product-hub-section-header h2 {
  margin-top: 12px;
  max-width: 17ch;
  font-size: clamp(2rem, 6vw, 3.1rem);
  line-height: 1.03;
}

.product-hub-section-note {
  max-width: 60ch;
  margin: 14px 0 0;
}

.feature-grid {
  display: grid;
  gap: 18px;
  margin-top: 22px;
}

.feature-grid__secondary {
  display: contents;
}

.feature-card {
  display: flex;
  flex-direction: column;
  width: 100%;
  padding: 0;
  overflow: hidden;
  color: inherit;
  text-align: left;
  font: inherit;
  background: var(--surface-glass-soft);
  border: 1px solid var(--border-soft);
  border-radius: 24px;
  box-shadow: var(--shadow-card);
}

button.feature-card {
  cursor: pointer;
}

.feature-card__image {
  padding: 0;
  overflow: hidden;
  border-bottom: 1px solid var(--border-soft);
}

.feature-card__image--featured {
  min-height: 170px;
}

.feature-card__image--compact {
  min-height: 108px;
}

.feature-card__image img,
.feature-card__image-placeholder {
  display: block;
  width: 100%;
  height: 100%;
  min-height: inherit;
  border-radius: 0;
}

.feature-card__image img {
  object-fit: cover;
}

.feature-card__image-placeholder {
  background: linear-gradient(180deg, var(--placeholder-start) 0%, var(--placeholder-end) 100%);
  border: 1px solid var(--border-soft);
}

.feature-card__content {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 12px;
  padding: 18px;
}

.feature-card__content--featured {
  gap: 16px;
  padding: 20px;
}

.feature-card__content--compact {
  gap: 16px;
  padding: 16px 16px 18px;
}

.feature-card__topic {
  margin: 0;
  color: var(--accent-secondary-strong);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.feature-card__title {
  margin: 0;
  color: var(--text-primary);
  font-family: var(--font-serif);
  font-size: 1.18rem;
  font-weight: 500;
  line-height: 1.08;
  letter-spacing: -0.03em;
}

.feature-card__description {
  margin: 0;
  color: var(--muted);
  font-size: 0.96rem;
  line-height: 1.65;
}

.feature-card__actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: auto;
  padding-top: 4px;
  gap: 12px;
}

.feature-card__cta,
.feature-card__chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 44px;
  padding: 0 18px;
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 600;
  line-height: 1;
  white-space: nowrap;
  text-decoration: none;
}

.feature-card__cta {
  color: var(--text-on-accent);
  background: var(--accent);
  border: 1px solid transparent;
  border-radius: 14px;
  pointer-events: none;
}

.feature-card__chip {
  color: var(--accent-secondary-strong);
  background: var(--accent-secondary-light);
  border: 1px solid var(--accent-secondary-line);
  border-radius: 999px;
}

.feature-card__lock-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  color: var(--muted);
  flex-shrink: 0;
}

.feature-card__lock-icon svg,
.feature-card__lock-icon .lucide {
  display: block;
  width: 16px;
  height: 16px;
}

.feature-card--available,
.feature-card--soon {
  transition:
    transform 160ms ease,
    box-shadow 160ms ease,
    border-color 160ms ease;
}

.feature-card--available:hover,
.feature-card--available:focus-visible,
.feature-card--available:focus-within {
  transform: translateY(-2px);
  outline: none;
  border-color: var(--accent-soft);
  box-shadow: var(--shadow-panel);
}

.feature-card--featured {
  border-color: var(--accent-secondary-line);
  box-shadow: var(--shadow-panel);
}

.feature-card--soon {
  cursor: default;
  background: linear-gradient(180deg, var(--panel-overlay-start) 0%, var(--panel-overlay-end) 100%);
  border-color: var(--border-soft);
}

.feature-card--soon .feature-card__image {
  border-bottom-color: var(--border-soft);
}

.feature-card--soon .feature-card__image-placeholder {
  background: linear-gradient(180deg, var(--placeholder-start) 0%, var(--placeholder-end) 100%);
  border-color: var(--border-soft);
}

.feature-card--soon .feature-card__topic {
  color: var(--accent-secondary-strong);
}

.feature-card--soon .feature-card__description {
  color: var(--muted);
}

.feature-card[data-feature-state="coming-soon"] {
  cursor: default;
}

.js [data-reveal] {
  opacity: 0;
  transform: translateY(18px);
  transition:
    opacity 520ms ease,
    transform 520ms ease;
}

.js [data-reveal].is-visible {
  opacity: 1;
  transform: none;
}

@media (max-width: 520px) {
  .product-hub-kpis {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
  }

  .product-hub-kpi {
    min-height: 112px;
    padding: 16px 14px;
    border-radius: 20px;
  }

  .product-hub-kpi:last-child {
    grid-column: 1 / -1;
  }

  .product-hub-kpi-value {
    font-size: 1.7rem;
  }

  .product-hub-kpi-label {
    margin-top: 10px;
    font-size: 0.92rem;
  }
}

@media (min-width: 721px) {
  .product-hub-shell {
    width: min(calc(100% - 40px), 1120px);
    padding: 36px 0 72px;
  }

  .product-hub-main {
    gap: 24px;
  }

  .product-hub-hero {
    grid-template-columns: minmax(0, 1.06fr) minmax(320px, 0.94fr);
    align-items: center;
    gap: 32px;
    padding: 42px 38px;
  }

  .product-hub-spotlight {
    align-self: stretch;
    margin: -42px -38px -42px 0;
  }

  .product-hub-spotlight-frame {
    min-height: 100%;
  }

  .product-hub-section {
    padding: 34px 32px;
  }

  .product-hub-kpis {
    gap: 12px;
    margin-top: 22px;
  }

  .product-hub-section-note {
    max-width: none;
    white-space: nowrap;
  }

  .feature-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: stretch;
  }

  .feature-card--featured {
    min-height: 100%;
  }

  .feature-card--featured .feature-card__content {
    justify-content: space-between;
  }
}
