/* ============================================
   HAYLEY STOLEE-SMITH — PORTFOLIO STYLESHEET
   Palette:
     Background:  #fafafa (near-white)
     Text:        #111111 (near-black)
     Teal 1:      #0c445a (deep teal — primary)
     Teal 2:      #265d74 (lighter teal — secondary / patent cards)
     Coral:       #f97171 (coral — accent labels & details)
     Red:         #c81d25 (deep red — reserved for emphasis)
     Gold:        #f4cf77 (gold — nav active underline)
     Subtle:      #f0f0ee (light grey for cards/dividers)
     Muted text:  #6b6b6b
   Font: Inter (Google Fonts — add link to <head>)
   ============================================ */
/* ---- RESET ---- */
* {
  box-sizing: border-box;
}
/* ---- ADD THIS TO THE <head> OF EVERY HTML FILE ----
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap" rel="stylesheet">
--------------------------------------------------- */
/* ---- BASE ---- */
body {
  margin: 0;
  font-family: 'Inter', Arial, sans-serif;
  background-color: #fafafa;
  color: #111111;
  -webkit-font-smoothing: antialiased;
}
/* ---- DARK PAGE VARIANTS (SubPac + Technical Design) ---- */
body.subpac-page {
  background-color: #0f0f10;
  color: #f0ece6;
}
body.technical-design-page {
  background-color: #111214;
  color: #f0ece6;
}
body.technical-design-page .site-name-link,
body.technical-design-page .nav-link,
body.technical-design-page .text-link,
body.technical-design-page .inline-link,
body.technical-design-page .project-link,
body.technical-design-page .page-title,
body.technical-design-page h2 {
  color: #f0ece6;
}
body.technical-design-page .eyebrow {
  color: #f4cf77;
}
body.technical-design-page .case-study-meta,
body.technical-design-page .project-type {
  color: #a0a09e;
}
body.technical-design-page .nav-link.active {
  color: #ffffff;
}
body.technical-design-page .case-study-intro,
body.technical-design-page .case-study-large-text p {
  color: rgba(240, 236, 230, 0.85);
}
body.subpac-page .site-name-link,
body.subpac-page .nav-link,
body.subpac-page .text-link,
body.subpac-page .inline-link,
body.subpac-page .project-link,
body.subpac-page .page-title,
body.subpac-page h2 {
  color: #f0ece6;
}
body.subpac-page .eyebrow {
  color: #f97171;
}
body.subpac-page .case-study-meta,
body.subpac-page .project-type {
  color: #a0a09e;
}
body.subpac-page .nav-link.active {
  color: #ffffff;
}
body.subpac-page .case-study-intro,
body.subpac-page .case-study-large-text p,
body.subpac-page .video-fallback-text,
body.subpac-page .project-row-note,
body.subpac-page .contact-copy {
  color: rgba(240, 236, 230, 0.85);
}
/* ---- PATENTS DARK PAGE ---- */
body.patents-dark-page {
  background-color: #0f0f10;
  color: #f0ece6;
}
body.patents-dark-page .site-name-link,
body.patents-dark-page .nav-link {
  color: #f0ece6;
}
body.patents-dark-page .nav-link:hover {
  color: #ffffff;
}
body.patents-dark-page .nav-link.active {
  color: #ffffff;
  text-decoration-color: #f4cf77;
}
body.patents-dark-page .page-title,
body.patents-dark-page .patent-copy h2 {
  color: #f0ece6;
}
body.patents-dark-page .patent-meta {
  color: #a0a09e;
}
body.patents-dark-page .patent-copy p {
  color: rgba(240, 236, 230, 0.80);
}
body.patents-dark-page .project-link {
  color: #f4cf77;
}
body.patents-dark-page .patents-header {
  border-bottom-color: rgba(255, 255, 255, 0.08);
}
body.patents-dark-page .patent-entry {
  border-bottom-color: rgba(255, 255, 255, 0.08);
}
body.patents-dark-page .patent-entry:first-child {
  border-top-color: rgba(255, 255, 255, 0.08);
}
body.patents-dark-page .patent-image-frame {
  background: transparent;
  border-color: transparent;
  padding: 0;
}
/* ---- HEADER / NAV ---- */
.site-header {
  padding: 1.5rem 1.5rem 0;
}
.site-header-nav {
  width: 100%;
  max-width: 1440px;
  margin: 0 auto;
  padding: 1.75rem 2.5rem 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
}
.site-name,
.site-name-link {
  margin: 0;
  font-size: 0.96rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #0c445a;
  text-decoration: none;
}
.site-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
}
.nav-link {
  color: #6b6b6b;
  text-decoration: none;
  font-size: 0.85rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  transition: color 0.15s ease;
}
.nav-link:hover {
  color: #0c445a;
}
.nav-link.active {
  color: #0c445a;
  font-weight: 600;
  text-decoration: underline;
  text-decoration-color: #f4cf77;
  text-decoration-thickness: 2px;
  text-underline-offset: 0.25em;
}
/* ---- PAGE SHELL ---- */
.page-shell {
  width: 100%;
  max-width: 1440px;
  margin: 0 auto;
}
.technical-shell {
  max-width: none;
}
/* ---- TYPOGRAPHY ---- */
h1 {
  margin-top: 0;
  margin-bottom: 1.25rem;
  font-size: clamp(2.6rem, 6vw, 5.2rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.02em;
  text-transform: uppercase;
}h2 {
  margin: 0;
  max-width: 520px;
  font-size: clamp(2rem, 4vw, 3.4rem);
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -0.02em;
}
.eyebrow {
  margin: 0 0 0.75rem;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #0c445a;
}
.intro {
  margin-bottom: 2.5rem;
  font-size: 1.05rem;
  line-height: 1.75;
  color: #444444;
  max-width: 608px;
}
/* ---- BUTTONS & LINKS ---- */
.button {
  display: inline-block;
  padding: 0.85rem 1.75rem;
  border-radius: 4px;
  background-color: #0c445a;
  color: #ffffff;
  text-decoration: none;
  font-weight: 600;
  font-size: 0.85rem;
  letter-spacing: 0.04em;
  transition: background-color 0.15s ease;
}
.button:hover {
  background-color: #265d74;
}
.secondary-button {
  background-color: #0c445a;
}
.secondary-button:hover {
  background-color: #265d74;
}
.text-link {
  color: #0c445a;
  font-weight: 600;
  font-size: 0.9rem;
  text-decoration: underline;
  text-decoration-thickness: 1.5px;
  text-underline-offset: 0.2em;
  letter-spacing: 0.02em;
  transition: color 0.15s ease;
}
.text-link:hover {
  color: #265d74;
}
.inline-link {
  color: inherit;
  font-weight: 600;
  text-decoration-thickness: 1.5px;
  text-underline-offset: 0.15em;
}
.project-link {
  color: #0c445a;
  font-weight: 600;
  text-decoration-thickness: 1.5px;
  text-underline-offset: 0.15em;
}
/* ---- HERO (HOME PAGE) ---- */
.hero {
  min-height: 100vh;
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  gap: 5rem;
  padding: 5.76rem 2.5rem;
}
.hero-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1.25rem;
}
.hero-text {
  width: 100%;
  max-width: 676px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}
.hero-image {
  width: 100%;
  max-width: 483px;
  display: flex;
  flex-shrink: 0;
  margin-right: 10%;
}
.profile-image {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
  object-position: center top;
  border-radius: 4px;
}
/* ---- ABOUT PAGE ---- */
.about {
  padding: 4rem 2.5rem 6rem;
}
.about-page,
.projects-page,
.patents-page {
  padding: 5.76rem 2.5rem 0;
}
.about-layout {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  align-items: start;
}
.about-eyebrow {
  margin-bottom: 0.25rem;
}
.about-lead {
  max-width: 336px;
  margin-top: 1.5rem;
  font-size: 1.05rem;
  line-height: 1.8;
  color: #444444;
}
.about-copy {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1px;
  border: 1px solid #e8e8e6;
  border-radius: 4px;
  overflow: hidden;
}
.about-card {
  padding: 2rem;
  background-color: #ffffff;
  border-right: 1px solid #e8e8e6;
}
.about-card:last-child {
  border-right: none;
}
.about-card h3 {
  margin-top: 0;
  margin-bottom: 0.85rem;
  font-size: 0.75rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 600;
  color: #0c445a;
}
.about-card p {
  margin: 0;
  line-height: 1.8;
  color: #444444;
  font-size: 0.95rem;
}
/* ---- EXPERIENCE SECTION ---- */
.experience-section {
  padding: 0 2.5rem 7rem;
}
.experience-section.about-page {
  padding-top: 5.76rem;
}
.experience-section.about-page .experience-header {
  display: inline-block;
}
.experience-section.about-page .experience-title {
  white-space: nowrap;
}
.experience-section.about-page .about-lead,
.experience-section.about-page .text-link {
  max-width: 100%;
}
.experience-inner {
  width: 100%;
}
.experience-header {
  max-width: 760px;
  margin-bottom: 2rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid #e8e8e6;
}
.experience-title {
  margin: 0;
  font-size: clamp(1.8rem, 3vw, 2.8rem);
  line-height: 1.15;
  letter-spacing: -0.02em;
}
.experience-list {
  display: grid;
  gap: 0;
}
.experience-item {
  display: grid;
  grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
  gap: 2rem;
  padding: 1.75rem 0;
  border-bottom: 1px solid #e8e8e6;
}
.experience-meta p,
.experience-copy p {
  margin: 0;
}
.experience-meta {
  display: grid;
  gap: 0.35rem;
  align-content: start;
}
.experience-role {
  font-weight: 600;
  font-size: 0.9rem;
}
.experience-years {
  color: #f97171;
  font-size: 0.85rem;
  font-weight: 500;
}
.experience-copy p {
  line-height: 1.8;
  max-width: 700px;
  color: #444444;
  font-size: 0.95rem;
}
/* ---- PROJECTS PAGE ---- */
.projects {
  padding: 5.76rem 2.5rem 7rem;
}
.projects-inner {
  width: 100%;
}
.projects-header {
  max-width: 820px;
  margin-bottom: 4rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid #e8e8e6;
}
.projects-intro {
  margin-top: 1.25rem;
  font-size: 1.05rem;
  line-height: 1.8;
  color: #444444;
}
.project-list {
  display: grid;
  gap: 0;
}
.project-row {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
  gap: 3rem;
  align-items: center;
  text-decoration: none;
  color: inherit;
  padding: 3.5rem 0;
  border-bottom: 1px solid #e8e8e6;
  transition: opacity 0.15s ease;
}
.project-row:first-child {
  border-top: 1px solid #e8e8e6;
}
.project-row:hover {
  opacity: 0.75;
}
.project-row:nth-child(even) {
  grid-template-columns: minmax(280px, 0.8fr) minmax(0, 1.2fr);
}
.project-row:nth-child(even) .project-row-image {
  order: 2;
}
.project-row:nth-child(even) .project-row-copy {
  order: 1;
}
.project-row-image {
  width: 100%;
  aspect-ratio: 16 / 11;
  display: block;
  object-fit: cover;
  border-radius: 4px;
}
.project-row-image-contain {
  object-fit: contain;
  background: transparent;
}
.project-row-copy {
  padding-bottom: 0.5rem;
}
.project-row-copy h2 {
  max-width: none;
  margin-bottom: 0.75rem;
  font-size: clamp(2rem, 3.5vw, 3.2rem);
  letter-spacing: -0.02em;
}
.project-type {
  margin-top: 0;
  margin-bottom: 0.75rem;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #f97171;
}
.project-row-note {
  max-width: 420px;
  margin: 0;
  color: #6b6b6b;
  line-height: 1.7;
  font-size: 0.95rem;
}
.project-row-coming-soon {
  grid-template-columns: 1fr;
  padding-top: 1rem;
  border-top: 1px solid #e8e8e6;
}
.project-card {
  padding: 2rem;
  border-radius: 4px;
  background-color: #ffffff;
  border: 1px solid #e8e8e6;
}
.project-meta,
.project-detail {
  color: #6b6b6b;
  margin: 0 0 0.9rem;
  font-size: 0.95rem;
  line-height: 1.6;
}
.project-card h3 {
  margin-top: 0;
  margin-bottom: 0.75rem;
  font-size: 1.5rem;
  letter-spacing: -0.01em;
}
.project-description {
  margin: 0 0 1.25rem;
  line-height: 1.8;
  color: #444444;
}
/* ---- CASE STUDY PAGES ---- */
.case-study-hero {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(420px, 1.05fr);
  gap: 4rem;
  align-items: center;
  padding: 5.76rem 2.5rem 5rem;
}
.case-study-meta {
  margin: 0 0 1.25rem;
  color: #6b6b6b;
  line-height: 1.7;
  font-size: 0.9rem;
}
.case-study-intro {
  max-width: 600px;
  margin: 0 0 2rem;
  font-size: 1.05rem;
  line-height: 1.85;
  color: #444444;
}
.case-study-image-wrap {
  border-radius: 4px;
  overflow: hidden;
}
.case-study-hero-image {
  width: 100%;
  aspect-ratio: 4 / 5;
  display: block;
  object-fit: cover;
  border-radius: 4px;
}
body.subpac-page .case-study-image-wrap {
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.03);
}
body.subpac-page .case-study-hero-image {
  aspect-ratio: 4 / 5;
  object-fit: contain;
  background: transparent;
}
body.technical-design-page .technical-hero-wrap {
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.02);
}
.technical-hero-image {
  aspect-ratio: auto;
  object-fit: contain;
  background: transparent;
  padding: 1rem;
}
body.technical-design-page .technical-hero-image {
  aspect-ratio: auto;
  object-fit: contain;
  background: transparent;
  padding: 1rem;
}
.case-study-section,
.case-study-text-section,
.case-study-gallery-section,
.case-study-video-section {
  padding: 0 2.5rem 5rem;
}
.technical-gallery-section {
  padding-left: 2.5rem;
  padding-right: 2.5rem;
}
.case-study-section-header {
  margin-bottom: 2rem;
  max-width: 760px;
}
.case-study-text-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 2.5rem;
}
.case-study-text-grid p {
  margin: 0;
  line-height: 1.85;
  font-size: 1rem;
  color: #444444;
}
.case-study-large-text {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 2.5rem;
  padding-top: 1rem;
  border-top: 1px solid #e8e8e6;
}
.case-study-large-text p {
  margin: 0;
  line-height: 1.9;
  font-size: 1rem;
  color: #444444;
}
/* ---- GALLERY ---- */
.case-study-gallery {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}
.gallery-image {
  width: 100%;
  aspect-ratio: 4 / 3;
  display: block;
  object-fit: cover;
  border-radius: 4px;
}
body.subpac-page .gallery-image {
  aspect-ratio: auto;
  object-fit: contain;
}
.gallery-image-centered {
  align-self: center;
}
body.fx-page .fx-hero-image,
body.fx-page .fx-gallery-image {
  object-fit: contain;
  background: transparent;
}
.fx-full-bleed-section {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  padding: 0 0 4rem;
}
.fx-full-bleed-image {
  width: 100%;
  display: block;
  aspect-ratio: 16 / 7;
  object-fit: cover;
}
/* ---- KITE MEDIA GRID ---- */
.kite-media-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(0, 0.95fr);
  grid-template-areas: "video render";
  gap: 1rem;
  align-items: stretch;
}
.kite-gallery-image {
  width: 100%;
  display: block;
}
.kite-gallery-image-contain {
  object-fit: contain;
  background: #f0f0ee;
}
.kite-gallery-image-solid {
  grid-area: render;
  align-self: stretch;
  height: 100%;
}
.kite-gallery-image-armband {
  grid-area: armband;
  aspect-ratio: 16 / 11;
  padding: 1rem;
}
.kite-video-link {
  align-self: stretch;
}
.kite-video-link-feature {
  grid-area: video;
  min-height: 100%;
  background: #f0f0ee;
  display: flex;
  align-items: center;
  justify-content: center;
}
.kite-video-link-feature .video-link-overlay {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.0) 0%, rgba(0, 0, 0, 0.72) 100%);
  left: 5%;
  right: 5%;
}
.kite-video-link-feature .video-link-image {
  aspect-ratio: auto;
  object-fit: contain;
  width: 90%;
  margin: 0 auto;
}
.case-study-gallery img:first-child {
  grid-column: span 2;
  aspect-ratio: 16 / 9;
}
/* ---- TECHNICAL DESIGN GALLERY ---- */
.technical-gallery-pair {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
  margin-top: 0.75rem;
}
.technical-gallery-pair:first-child {
  margin-top: 0;
}
.technical-gallery-pair-feature {
  gap: 1rem;
}
.technical-gallery-image {
  width: 100%;
  display: block;
  object-fit: contain;
  padding: 0;
  border-radius: 0;
  background: transparent;
}
.technical-gallery-small {
  aspect-ratio: 4 / 4.9;
}
/* ---- VIDEO ---- */
.video-frame {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: 4px;
  background: #000000;
}
.video-frame iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}
.video-frame video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}
.video-fallback-card {
  padding: 2rem;
  border-radius: 4px;
  background-color: #f0f0ee;
  border: 1px solid #e8e8e6;
}
body.subpac-page .video-fallback-card {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.07);
}
.video-fallback-text {
  margin-top: 0;
  margin-bottom: 1.25rem;
  max-width: 620px;
  line-height: 1.8;
  font-weight: 600;
  font-size: 0.8rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #6b6b6b;
}
.video-link-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}
.video-link-card {
  position: relative;
  overflow: hidden;
  border-radius: 4px;
  text-decoration: none;
}
.video-link-image {
  width: 100%;
  aspect-ratio: 16 / 10;
  display: block;
  object-fit: cover;
}
.video-link-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-end;
  padding: 1.25rem;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.0) 0%, rgba(0, 0, 0, 0.72) 100%);
}
.video-link-label {
  color: #ffffff;
  font-weight: 600;
  font-size: 0.85rem;
  letter-spacing: 0.04em;
}
/* ---- PATENTS PAGE ---- */
.patents-header {
  max-width: 780px;
  margin-bottom: 2rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid #e8e8e6;
}
.patents-intro {
  margin-top: 1.25rem;
  font-size: 1.05rem;
  line-height: 1.8;
  max-width: 680px;
  color: #444444;
}
.patent-list {
  display: grid;
  gap: 0;
  padding-bottom: 3rem;
}
.patent-entry {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
  gap: 2rem;
  align-items: center;
  padding: 2.5rem 0;
  border-bottom: 1px solid #e8e8e6;
}
.patent-entry:first-child {
  border-top: 1px solid #e8e8e6;
}
.patent-entry:nth-child(even) {
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
}
.patent-entry:nth-child(even) .patent-image-frame {
  order: 2;
}
.patent-entry:nth-child(even) .patent-copy {
  order: 1;
}
.patent-image-frame {
  padding: 0;
  border-radius: 0;
  background: transparent;
  border: none;
}
.patent-image {
  width: 100%;
  aspect-ratio: 4 / 3;
  display: block;
  object-fit: contain;
  object-position: center;
  background-color: #ffffff;
}
.patent-image-natural {
  aspect-ratio: auto;
  height: auto;
}
.patent-kicker {
  margin: 0 0 0.9rem;
  color: #0c445a;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.patent-copy h2 {
  max-width: 620px;
  margin-bottom: 0.9rem;
}
.patent-meta {
  margin: 0 0 1rem;
  color: #6b6b6b;
  line-height: 1.7;
  font-size: 0.9rem;
}
.patent-copy p {
  margin-top: 0;
  line-height: 1.8;
  color: #444444;
  font-size: 0.95rem;
}
/* ---- CASE STUDY BACK NAV ---- */
.case-study-back-nav {
  padding: 0 2.5rem 4rem;
  border-top: 1px solid #e8e8e6;
  padding-top: 2.5rem;
}
/* ---- CONTACT PAGE ---- */
.contact-section {
  min-height: calc(100vh - 120px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 5.76rem 2.5rem 6rem;
}
.contact-layout {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 420px);
  gap: 3rem;
  align-items: center;
}
.contact-card {
  width: 100%;
}
.page-title {
  max-width: 780px;
}
.contact-copy {
  max-width: 520px;
  margin: 1.5rem 0 2rem;
  line-height: 1.8;
  font-size: 1.05rem;
  color: #444444;
}
.contact-email {
  margin-top: 1.25rem;
  color: #6b6b6b;
  font-size: 0.9rem;
  letter-spacing: 0.02em;
}
.contact-image-card {
  border-radius: 4px;
  overflow: hidden;
}
.contact-image {
  width: 100%;
  aspect-ratio: 4 / 5;
  display: block;
  object-fit: cover;
  object-position: center 14%;
  border-radius: 4px;
}
/* ---- IMAGE PLACEHOLDER (fallback) ---- */
.image-placeholder {
  width: 100%;
  aspect-ratio: 4 / 5;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #e8e8e6;
  border-radius: 4px;
  background-color: #f0f0ee;
  color: #6b6b6b;
  font-size: 0.85rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
/* ---- RESPONSIVE / MOBILE ---- */
@media (max-width: 800px) {
  .hero {
    flex-direction: column-reverse;
    text-align: center;
    padding: 3rem 1.5rem;
  }
  .hero-text {
    max-width: 100%;
  }
  .intro {
    max-width: 100%;
  }
  .site-header,
  .site-header-nav {
    text-align: center;
    justify-content: center;
    flex-direction: column;
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }
  .about-copy {
    grid-template-columns: 1fr;
  }
  .about-card {
    border-right: none;
    border-bottom: 1px solid #e8e8e6;
  }
  .about-card:last-child {
    border-bottom: none;
  }
  .experience-item {
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }
  .project-list,
  .project-row,
  .project-row:nth-child(even),
  .case-study-hero,
  .case-study-text-grid,
  .case-study-large-text,
  .case-study-gallery,
  .technical-gallery-pair,
  .kite-media-grid {
    grid-template-columns: 1fr;
  }
  .kite-media-grid {
    grid-template-areas:
      "video"
      "render"
      "armband";
  }
  .project-row:nth-child(even) .project-row-image,
  .project-row:nth-child(even) .project-row-copy {
    order: initial;
  }
  .patent-entry,
  .patent-entry:nth-child(even) {
    grid-template-columns: 1fr;
  }
  .patent-entry:nth-child(even) .patent-image-frame,
  .patent-entry:nth-child(even) .patent-copy {
    order: initial;
  }
  .contact-layout {
    grid-template-columns: 1fr;
  }
  .video-link-list {
    grid-template-columns: 1fr;
  }
  .case-study-gallery img:first-child {
    grid-column: span 1;
    aspect-ratio: 4 / 3;
  }
  .hero-actions,
  .site-nav {
    justify-content: center;
  }
  .case-study-hero {
    padding: 2rem 1.5rem 3rem;
  }
  .case-study-text-section,
  .case-study-gallery-section,
  .case-study-video-section {
    padding: 0 1.5rem 3rem;
  }
  .projects {
    padding: 2rem 1.5rem 5rem;
  }
  .experience-section {
    padding: 0 1.5rem 5rem;
  }
  .about {
    padding: 3rem 1.5rem 4rem;
  }
}
