.skip-link {
  position: absolute;
  left: 0.75rem;
  top: -3rem;
  z-index: 2000;
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  background: #fff;
  color: #000;
  border: 3px solid #000;
  box-shadow: 4px 4px 0 #000;
  padding: 0.55rem 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.72rem;
}

.skip-link:focus-visible {
  top: 0.75rem;
}

html {
  scroll-behavior: smooth;
}

body,
.creative-agency,
.legal-page {
  font-family: var(--font-body);
}

.creative-agency {
  --primary: var(--accent-red);
  --secondary: var(--accent-blue);
  --cta: var(--accent-yellow);
  --bg: var(--surface-card);
  --text: var(--ink);
  --text-muted: var(--ink-muted);
  --border: #000;
}

h1,
h2,
h3,
h4,
h5,
h6,
.home-nav-logo,
.footer-logo,
.btn-brutal,
.section-kicker,
.pill,
.pill-brutal {
  font-family: var(--font-heading);
}

.container-page {
  width: min(100% - (var(--space-gutter) * 2), var(--container-page));
  margin-inline: auto;
}

/* Utility primitives (previously only in vendor CSS) */
.brutal-border {
  border: 3px solid #000;
}

.brutal-shadow {
  box-shadow: var(--shadow-hard);
}

.highlight-red {
  background: var(--accent-red);
  color: #fff;
  padding: 0 0.22em;
}

.home-nav-logo .highlight-red,
.footer-logo .highlight-red {
  padding: 0 0.25em;
}

.highlight-blue {
  background: var(--accent-blue);
  color: #fff;
  padding: 0 0.22em;
}

.highlight-yellow {
  background: var(--accent-yellow);
  color: #000;
  padding: 0 0.22em;
}


.btn-brutal,
button.btn-brutal,
button[type="submit"].btn-brutal {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--btn-min-h-mobile);
  padding: var(--btn-pad-y) var(--btn-pad-x);
  font-size: var(--btn-font-size);
  letter-spacing: var(--btn-letter-spacing);
  line-height: 1.1;
  text-transform: uppercase;
  transition: transform 180ms ease, box-shadow 180ms ease, background-color 180ms ease, color 180ms ease;
  touch-action: manipulation;
  cursor: pointer;
}

.btn-brutal:hover {
  transform: translate(-1px, -1px);
  box-shadow: var(--shadow-hard) !important;
}

.btn-brutal:active {
  transform: translate(6px, 6px);
  box-shadow: none !important;
}

.btn-brutal-secondary {
  background: #fff !important;
  color: #000 !important;
}

.btn-brutal-secondary:hover,
.btn-brutal-secondary:focus-visible {
  background: var(--surface-soft) !important;
}

.icon-stroke {
  display: inline-block;
  width: 1em;
  height: 1em;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.4;
  stroke-linecap: square;
  stroke-linejoin: miter;
}

.inline-icon {
  flex: 0 0 auto;
  margin-left: 0.35em;
  vertical-align: -0.12em;
}

.marquee-icon {
  color: var(--cta);
  width: 1.05em;
  height: 1.05em;
}

.project-card-logo {
  font-family: var(--font-heading);
  text-shadow: 2px 2px 0 rgba(0, 0, 0, 0.3);
}

.home-nav-cta,
.home-nav-mobile-link {
  min-height: var(--btn-min-h-mobile);
}

.home-nav-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  min-width: 44px;
  min-height: 44px;
  border: 3px solid #000;
  background: #fff;
  color: #000;
  box-shadow: 4px 4px 0 #000;
  cursor: pointer;
  touch-action: manipulation;
  transition: transform 180ms ease, box-shadow 180ms ease, background-color 180ms ease;
}

.home-nav-toggle:hover {
  transform: translate(1px, 1px);
  box-shadow: var(--shadow-soft);
}

.home-nav-toggle svg {
  width: 22px;
  height: 22px;
  display: block;
}

.home-nav-toggle .nav-line {
  transition: transform 200ms ease, opacity 200ms ease;
  transform-origin: center;
}

.home-nav-toggle[data-open="true"] .nav-line-top {
  transform: translateY(7px) rotate(45deg);
}

.home-nav-toggle[data-open="true"] .nav-line-middle {
  opacity: 0;
}

.home-nav-toggle[data-open="true"] .nav-line-bottom {
  transform: translateY(-7px) rotate(-45deg);
}

.home-nav-mobile-panel {
  display: none;
  grid-template-columns: 1fr;
  gap: 0.5rem;
  padding: 0 0 0.9rem;
}

.home-nav-mobile-panel.is-open {
  display: grid;
}

.home-nav-mobile-link {
  display: flex;
  align-items: center;
  min-height: var(--btn-min-h-mobile);
  padding: 0.6rem 0.85rem;
  border: 3px solid #000;
  background: #fff;
  color: #000;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.74rem;
}

.home-nav-mobile-link[aria-current="page"] {
  background: var(--cta, var(--accent-yellow));
  box-shadow: 4px 4px 0 #000;
}

.home-nav-mobile-link.mobile-cta {
  background: var(--cta, var(--accent-yellow));
}

body.nav-open {
  overflow: hidden;
}

.site-footer {
  margin-top: 2rem;
  padding-block: 3rem;
  border-top: 3px solid #000;
  padding-inline: 0;
  overflow-x: clip;
}

.site-footer .footer-logo {
  font-size: 1.875rem;
  line-height: 1;
  font-weight: 800;
  letter-spacing: 0;
}

.site-footer .footer-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
  margin-bottom: 1.65rem;
}

.site-footer .footer-brand {
  max-width: 34rem;
  padding-bottom: 0.25rem;
  grid-column: 1 / -1;
}

.site-footer .footer-brand a {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
}

.site-footer .footer-card {
  border: 3px solid #000;
  background: #fff;
  box-shadow: var(--shadow-mid);
  padding: 0.85rem 0.75rem;
  min-width: 0;
}

.site-footer .footer-card .footer-title {
  margin: 0 0 0.5rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.72rem;
  color: #000;
}

.site-footer .footer-link-list {
  display: grid;
  gap: 0.3rem;
}

.site-footer .footer-link-list a,
.site-footer .footer-link-list .footer-link-disabled {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: 0 0.1rem;
  color: var(--text-muted, #5f5f5f);
  font-weight: 600;
  transition: transform 180ms ease, color 180ms ease;
}

.site-footer .footer-link-list a:hover,
.site-footer .footer-link-list a:focus-visible {
  color: var(--text, #000);
  transform: translateX(2px);
}

.site-footer .footer-link-disabled {
  opacity: 0.72;
}

.site-footer .footer-meta {
  padding-top: 1.2rem;
  border-top: 3px solid #000;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.75rem;
}

.site-footer .footer-legal {
  display: flex;
  gap: 1.25rem;
  flex-wrap: wrap;
}

.site-footer .footer-legal a {
  min-width: 44px;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  color: var(--text-muted, #5f5f5f);
}

.site-footer .footer-legal a:hover,
.site-footer .footer-legal a:focus-visible {
  color: var(--text, #000);
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
summary:focus-visible {
  outline: 3px solid var(--focus-color);
  outline-offset: 3px;
}

/* Phase 2: Form field focus states — yellow highlight for "Precision Fields" */
input.brutal-border:focus,
textarea.brutal-border:focus,
select.brutal-border:focus {
  background-color: var(--focus-field-bg);
  outline: 3px solid #000;
  outline-offset: 0;
}

input.brutal-border:focus::placeholder {
  color: rgba(0, 0, 0, 0.45);
}

.home-nav-logo,
.home-nav-inline a,
.site-footer .footer-legal a,
.faq-item summary {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
}

.faq-item {
  transition: transform 180ms ease, box-shadow 180ms ease, background-color 180ms ease;
}

.faq-item:hover {
  transform: translate(1px, 1px);
}

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

@media (min-width: 768px) {
  .site-footer .footer-grid {
    grid-template-columns: minmax(0, 2fr) minmax(0, 1fr) minmax(0, 1fr);
    gap: 1.25rem;
  }

  .site-footer .footer-brand {
    grid-column: auto;
  }

  .site-footer .footer-card {
    box-shadow: 4px 4px 0 #000;
    padding: 0.9rem 0.85rem;
  }

  .site-footer .footer-meta {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }
}

@media (max-width: 1023px) {
  .home-nav-inline,
  .home-nav-cta {
    display: none !important;
  }
}

@media (min-width: 1024px) {
  .btn-brutal,
  button.btn-brutal,
  button[type="submit"].btn-brutal,
  .home-nav-cta,
  .home-nav-mobile-link {
    min-height: var(--btn-min-h-desktop);
  }

  .home-nav-toggle,
  .home-nav-mobile-panel {
    display: none !important;
  }

  body.nav-open {
    overflow: auto;
  }
}


.home-nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;
  background: rgba(232, 232, 232, 0.85);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  border-bottom: 3px solid #000;
  transition: background-color 300ms ease, box-shadow 300ms ease;
}

.home-nav.nav-scrolled {
  background: rgba(232, 232, 232, 0.95);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.12);
}

.home-nav-wrap {
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 1.25rem;
}

.home-nav-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.9rem 0 0.75rem;
}

.home-nav-logo {
  font-weight: 700;
  font-size: 1.5rem;
  letter-spacing: 0;
  color: #000;
}

.home-nav-inline {
  display: none;
  align-items: center;
  gap: 1.2rem;
}

.home-nav-inline a {
  font-size: 0.74rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  padding: 0.45rem 0.1rem;
  white-space: nowrap;
  color: #000;
  transition: color 180ms ease, transform 180ms ease;
}

.home-nav-inline a:hover,
.home-nav-inline a[aria-current="page"] {
  color: var(--primary, var(--accent-red));
}

.home-nav-inline a:hover {
  transform: translateY(-1px);
}

.home-nav-scroll {
  display: flex;
  gap: 0.55rem;
  overflow-x: auto;
  padding: 0 0 0.75rem;
  scrollbar-width: none;
}

.home-nav-scroll::-webkit-scrollbar {
  display: none;
}

.home-nav-scroll a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.1rem;
  padding: 0.35rem 0.7rem;
  border: 3px solid #000;
  background: #fff;
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  white-space: nowrap;
  color: #000;
}

.home-nav-scroll a[aria-current="page"] {
  background: var(--cta, var(--accent-yellow));
  box-shadow: 4px 4px 0 #000;
}

.home-nav-cta {
  min-width: 8.2rem;
  text-align: center;
  background: var(--cta, var(--accent-yellow)) !important;
  color: #000 !important;
  border: 3px solid #000 !important;
  box-shadow: 6px 6px 0 #000;
  padding: 1rem 2rem;
  font-weight: 700;
  letter-spacing: 0.05em;
}

.home-main {
  padding-top: 6.25rem;
}

.contact-hero {
  padding-bottom: clamp(1.8rem, 4vw, 3rem);
}

.contact-layout {
  align-items: start;
}

.contact-form-card {
  position: relative;
}

@media (min-width: 1024px) {
  .home-nav-top {
    padding: 1rem 0;
  }

  .home-nav-inline {
    display: flex;
  }

  .home-nav-scroll {
    display: none;
  }

  .home-main {
    padding-top: 5.9rem;
  }

  .contact-form-card {
    margin-top: -2.25rem;
  }
}

/* ----------------------------------------------------------------
   Shared component styles (extracted from inline <style> blocks)
   ---------------------------------------------------------------- */

.section-kicker {
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 700;
  font-size: 0.75rem;
}

.pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.35rem 0.7rem;
  border: 3px solid #000;
  font-weight: 700;
  text-transform: uppercase;
  font-size: 0.72rem;
}

.lead {
  font-size: 1.08rem;
  line-height: 1.7;
  color: var(--text-muted);
  max-width: var(--container-readable);
}

.cta-rail {
  border: 3px solid #000;
  box-shadow: 8px 8px 0 #000;
}


.faq-item summary {
  cursor: pointer;
  font-weight: 700;
  display: flex;
  justify-content: space-between;
  align-items: center;
  list-style: none;
}
.faq-item summary::-webkit-details-marker {
  display: none;
}
.faq-item summary::after {
  content: "+";
  font-size: 1.5rem;
  line-height: 1;
  flex-shrink: 0;
  transform: translateY(-1px);
}
.faq-item[open] summary::after {
  content: "-";
}


.faq-item[open] summary {
  color: var(--primary);
}

.table-qual {
  width: 100%;
  border-collapse: collapse;
}

.table-qual th,
.table-qual td {
  border: 3px solid #000;
  padding: 0.75rem;
  text-align: left;
  vertical-align: top;
}

.table-qual th {
  text-transform: uppercase;
  font-size: 0.75rem;
}

.contact-card {
  background: var(--surface-card);
}

.section-shell {
  padding-inline: var(--space-gutter);
}

.section-base {
  padding-block: var(--space-section);
}

.section-tight {
  padding-block: clamp(2.25rem, 5vw, 3.25rem);
}

.section-emphasis {
  padding-block: var(--space-section-lg);
}

.stack-main > * + * {
  margin-top: var(--space-stack);
}

html {
  scroll-behavior: smooth;
}
