/* Krapik foundation — use the classes below in Kadence Blocks. */
.krapik-site .content-wrap,
.krapik-site .wp-site-blocks,
.krapik-site .site-container {
  max-width: none;
}

.krapik-container {
  width: var(--krapik-wrap);
  margin-inline: auto;
}

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

.krapik-section--ink {
  background: var(--krapik-ink);
  color: var(--krapik-paper);
}

.krapik-eyebrow {
  display: inline-flex;
  gap: 0.55rem;
  align-items: center;
  color: var(--krapik-muted);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  line-height: 1.2;
  text-transform: uppercase;
}

.krapik-eyebrow::before {
  width: 1.2rem;
  height: 2px;
  background: var(--krapik-lime);
  content: "";
}

.krapik-display {
  max-width: 13ch;
  margin: 0;
  color: inherit;
  font-size: clamp(2.8rem, 2rem + 4.5vw, 6.25rem);
  font-weight: 700;
  letter-spacing: -0.065em;
  line-height: 0.94;
}

.krapik-lead {
  max-width: 60ch;
  color: var(--krapik-muted);
  font-size: clamp(1.1rem, 1rem + 0.4vw, 1.35rem);
  line-height: 1.65;
}

.krapik-section--ink .krapik-lead,
.krapik-section--ink .krapik-eyebrow {
  color: rgba(247, 246, 241, 0.72);
}

.krapik-button,
.krapik-site .wp-block-button__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.65rem;
  min-height: 48px;
  padding: 0.85rem 1.15rem;
  border: 1px solid var(--krapik-ink);
  border-radius: 999px;
  background: var(--krapik-ink);
  box-shadow: none;
  color: var(--krapik-paper);
  font-size: 0.92rem;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
  transition: transform 180ms ease, background-color 180ms ease, color 180ms ease;
}

.krapik-button:hover,
.krapik-site .wp-block-button__link:hover {
  background: var(--krapik-lime);
  color: var(--krapik-ink);
  transform: translateY(-2px);
}

.krapik-button--ghost {
  background: transparent;
  color: var(--krapik-ink);
}

.krapik-section--ink .krapik-button--ghost {
  border-color: var(--krapik-paper);
  color: var(--krapik-paper);
}

.krapik-grid {
  display: grid;
  gap: var(--krapik-space-3);
}

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

.krapik-card {
  height: 100%;
  padding: var(--krapik-space-3);
  border: 1px solid var(--krapik-line);
  border-radius: var(--krapik-radius-md);
  background: var(--krapik-surface);
  transition: border-color 180ms ease, transform 180ms ease, box-shadow 180ms ease;
}

.krapik-card:hover {
  border-color: var(--krapik-ink);
  box-shadow: var(--krapik-shadow);
  transform: translateY(-4px);
}

.krapik-card__number {
  display: block;
  margin-bottom: 2.25rem;
  color: var(--krapik-muted);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.12em;
}

.krapik-card h3 {
  margin-bottom: 0.75rem;
  font-size: clamp(1.35rem, 1.15rem + 0.7vw, 1.9rem);
  letter-spacing: -0.04em;
}

.krapik-card p { color: var(--krapik-muted); }

.krapik-project-card {
  display: block;
  overflow: hidden;
  border-radius: var(--krapik-radius-md);
  background: var(--krapik-ink);
  color: var(--krapik-paper);
  text-decoration: none;
}

.krapik-project-card__media {
  position: relative;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: #26292b;
}

.krapik-project-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 500ms ease;
}

.krapik-project-card:hover .krapik-project-card__media img { transform: scale(1.04); }

.krapik-project-card__body { padding: 1.25rem 1.35rem 1.4rem; }

.krapik-project-card__meta {
  color: rgba(247, 246, 241, 0.62);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.krapik-project-card h2,
.krapik-project-card h3 {
  margin: 0.4rem 0 0;
  color: var(--krapik-paper);
  font-size: clamp(1.4rem, 1.1rem + 1vw, 2.1rem);
  letter-spacing: -0.045em;
}

.krapik-project-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  padding-block: 1.25rem;
  border-top: 1px solid var(--krapik-line);
  border-bottom: 1px solid var(--krapik-line);
}

.krapik-project-meta dt {
  color: var(--krapik-muted);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.krapik-project-meta dd {
  margin: 0.4rem 0 0;
  font-weight: 700;
}

.krapik-prose {
  max-width: 750px;
  font-size: 1.1rem;
  line-height: 1.7;
}

.krapik-prose > * + * { margin-top: 1.2rem; }

.krapik-cta {
  display: grid;
  gap: var(--krapik-space-3);
  grid-template-columns: 1.6fr auto;
  align-items: end;
  padding: clamp(1.8rem, 1rem + 3vw, 4rem);
  border-radius: var(--krapik-radius-lg);
  background: var(--krapik-lime);
  color: var(--krapik-ink);
}

.krapik-back-to-top {
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 99;
  display: grid;
  width: 46px;
  height: 46px;
  place-items: center;
  border: 1px solid var(--krapik-ink);
  border-radius: 50%;
  background: var(--krapik-ink);
  color: var(--krapik-paper);
  cursor: pointer;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 160ms ease, transform 160ms ease, background-color 160ms ease;
}

.krapik-back-to-top.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.krapik-back-to-top:hover {
  background: var(--krapik-lime);
  color: var(--krapik-ink);
}

@media (prefers-reduced-motion: reduce) {
  .krapik-site *, .krapik-site *::before, .krapik-site *::after { scroll-behavior: auto !important; transition-duration: 0.01ms !important; }
}

/* Krapik v1.1 — site shell and front page */
.krapik-site #masthead {
  border-bottom: 1px solid var(--krapik-line);
  background: var(--krapik-paper);
}
.krapik-site .site-main-header-inner-wrap { min-height: 76px; }
.krapik-site .site-branding a.brand img,
.krapik-site .site-branding a.brand img.svg-logo-image { width: auto; max-width: 148px; max-height: 42px; }
.krapik-site .main-navigation .primary-menu-container > ul > li.menu-item > a {
  color: var(--krapik-ink);
  font-size: 0.86rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}
.krapik-site .main-navigation .primary-menu-container > ul > li.menu-item > a:hover,
.krapik-site .main-navigation .primary-menu-container > ul > li.menu-item.current-menu-item > a { color: var(--krapik-ink); }
.krapik-site .main-navigation .primary-menu-container > ul > li.menu-item > a:after { background: var(--krapik-lime); }
.krapik-site .main-navigation .primary-menu-container > ul > li.krapik-menu-cta > a {
  margin-left: .55rem;
  padding: .75rem 1rem;
  border: 1px solid var(--krapik-ink);
  border-radius: 999px;
  background: var(--krapik-ink);
  color: var(--krapik-paper);
}
.krapik-site .main-navigation .primary-menu-container > ul > li.krapik-menu-cta > a:hover { background: var(--krapik-lime); color: var(--krapik-ink); }
.krapik-site .mobile-toggle-open-container .menu-toggle-open,
.krapik-site .mobile-toggle-open-container .menu-toggle-open:focus { color: var(--krapik-ink); }
.krapik-site #mobile-drawer .drawer-inner { background: var(--krapik-ink); }
.krapik-site .mobile-navigation ul li > a,
.krapik-site .mobile-navigation ul li.menu-item-has-children > .drawer-nav-drop-wrap { color: var(--krapik-paper); }
.krapik-site .mobile-navigation ul li.current-menu-item > a { color: var(--krapik-lime); }
.krapik-site .site-bottom-footer-wrap { border-top: 1px solid var(--krapik-line); background: var(--krapik-paper); }
.krapik-site .footer-html-inner { color: var(--krapik-muted); font-size: .86rem; }
.krapik-site .footer-html-inner a { color: var(--krapik-ink); font-weight: 700; }

.krapik-home { overflow: clip; background: var(--krapik-paper); }
.krapik-home-hero { padding: clamp(4rem, 6vw, 7rem) 0 clamp(4.5rem, 8vw, 9rem); border-bottom: 1px solid var(--krapik-line); }
.krapik-home-hero__grid { display: grid; grid-template-columns: minmax(0, 1.3fr) minmax(250px, .7fr); gap: var(--krapik-space-5); align-items: end; }
.krapik-home-hero__content .krapik-lead { margin: 1.75rem 0 0; }
.krapik-home-actions { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: 2rem; }
.krapik-home-signal { position: relative; min-height: 330px; padding: 1.35rem; overflow: hidden; border: 1px solid var(--krapik-ink); border-radius: var(--krapik-radius-lg); background: var(--krapik-ink); color: var(--krapik-paper); }
.krapik-home-signal::before { position: absolute; inset: 0; opacity: .18; background-image: linear-gradient(rgba(247,246,241,.8) 1px, transparent 1px), linear-gradient(90deg, rgba(247,246,241,.8) 1px, transparent 1px); background-size: 34px 34px; content: ''; }
.krapik-home-signal__mark { position: absolute; right: -1.05rem; bottom: -2.2rem; color: var(--krapik-lime); font-size: clamp(12rem, 17vw, 18rem); font-weight: 800; letter-spacing: -.16em; line-height: .8; }
.krapik-home-signal__copy { position: relative; z-index: 1; display: flex; flex-direction: column; gap: .45rem; font-size: .76rem; font-weight: 700; letter-spacing: .13em; text-transform: uppercase; }
.krapik-home-signal__copy span::before { display: inline-block; width: .62rem; height: .62rem; margin-right: .6rem; border-radius: 50%; background: var(--krapik-lime); content: ''; }
.krapik-home-intro { border-bottom: 1px solid var(--krapik-line); }
.krapik-home-intro__grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: var(--krapik-space-4); padding-block: 1.4rem; font-size: clamp(1rem, .95rem + .25vw, 1.2rem); line-height: 1.55; }
.krapik-home-intro__grid p { margin: 0; }
.krapik-home-intro__label { color: var(--krapik-ink); font-weight: 700; }
.krapik-section-heading { display: flex; justify-content: space-between; gap: var(--krapik-space-4); align-items: end; margin-bottom: var(--krapik-space-4); }
.krapik-section-heading .krapik-lead { margin: 0; }
.krapik-section-heading--light .krapik-heading { color: var(--krapik-paper); }
.krapik-heading { max-width: 12ch; margin: .85rem 0 0; color: var(--krapik-ink); font-size: clamp(2rem, 1.4rem + 2vw, 3.65rem); font-weight: 700; letter-spacing: -.06em; line-height: .98; }
.krapik-services-grid { align-items: stretch; }
.krapik-featured-work .krapik-project-card { border: 1px solid rgba(247,246,241,.2); }
.krapik-project-card__placeholder { display: grid; width: 100%; height: 100%; place-items: center; background: #26292b; color: var(--krapik-lime); font-size: 8rem; font-weight: 800; letter-spacing: -.12em; }
.krapik-text-link { color: var(--krapik-paper); font-size: .9rem; font-weight: 700; text-decoration: none; white-space: nowrap; }
.krapik-text-link:hover { color: var(--krapik-lime); }
.krapik-process { display: grid; grid-template-columns: minmax(0, .8fr) minmax(0, 1.2fr); gap: var(--krapik-space-5); }
.krapik-process__list { display: grid; margin: 0; padding: 0; list-style: none; border-top: 1px solid var(--krapik-line); }
.krapik-process__list li { display: grid; grid-template-columns: 4rem 1fr; gap: 1rem; padding: 1.35rem 0; border-bottom: 1px solid var(--krapik-line); }
.krapik-process__list > li > span { color: var(--krapik-muted); font-size: .75rem; font-weight: 700; letter-spacing: .11em; }
.krapik-process h3 { margin: 0; color: var(--krapik-ink); font-size: clamp(1.25rem, 1rem + .8vw, 1.75rem); letter-spacing: -.04em; }
.krapik-process p { margin: .45rem 0 0; color: var(--krapik-muted); }
.krapik-section--paper-top { padding-top: 0; }
.krapik-display--cta { margin-top: .75rem; font-size: clamp(2.65rem, 2rem + 3.5vw, 5rem); }
.krapik-cta p { max-width: 50ch; margin: 1rem 0 0; }

.krapik-site .entry-hero { border-bottom: 1px solid var(--krapik-line); background: var(--krapik-paper); }
.krapik-site .entry-hero .entry-title { max-width: 13ch; color: var(--krapik-ink); font-size: clamp(2.4rem, 2rem + 2vw, 4rem); letter-spacing: -.06em; line-height: 1; }

/* Krapik v1.2 — Core pages and contact flow */
.krapik-page {
  overflow: clip;
  background: var(--krapik-paper);
}

.krapik-page-hero {
  padding: clamp(4.25rem, 8vw, 9rem) 0 clamp(3.5rem, 6vw, 6.5rem);
  border-bottom: 1px solid var(--krapik-line);
  background: var(--krapik-paper);
}

.krapik-page-hero--ink {
  background: var(--krapik-ink);
  color: var(--krapik-paper);
}

.krapik-page-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(260px, .8fr);
  gap: var(--krapik-space-5);
  align-items: end;
}

.krapik-page-hero .krapik-lead {
  margin: 0;
}

.krapik-page-hero--ink .krapik-eyebrow,
.krapik-page-hero--ink .krapik-lead {
  color: rgba(247, 246, 241, .72);
}

.krapik-page-hero--ink .krapik-display {
  color: var(--krapik-paper);
}

.krapik-section--border-top {
  border-top: 1px solid var(--krapik-line);
}

.krapik-page-intro {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(220px, .85fr);
  gap: var(--krapik-space-5);
  align-items: start;
}

.krapik-page-intro__statement,
.krapik-about-statement__lead {
  max-width: 23ch;
  margin: 0;
  color: var(--krapik-ink);
  font-family: var(--krapik-font-display);
  font-size: clamp(2rem, 1.55rem + 2vw, 3.7rem);
  font-weight: 600;
  letter-spacing: -.065em;
  line-height: .98;
}

.krapik-page-intro > p:last-child {
  max-width: 42ch;
  margin: 0;
  color: var(--krapik-muted);
  font-size: clamp(1rem, .92rem + .35vw, 1.2rem);
  line-height: 1.65;
}

.krapik-service-stack {
  border-top: 1px solid var(--krapik-line);
}

.krapik-service-row {
  display: grid;
  grid-template-columns: minmax(4rem, .25fr) minmax(0, 1.75fr);
  gap: var(--krapik-space-4);
  padding: clamp(2.1rem, 1.5rem + 2vw, 4rem) 0;
  border-bottom: 1px solid var(--krapik-line);
}

.krapik-service-row__index,
.krapik-offer-card > span,
.krapik-principles > article > span {
  color: var(--krapik-muted);
  font-family: var(--krapik-font-display);
  font-size: .76rem;
  font-weight: 700;
  letter-spacing: .12em;
}

.krapik-service-row__body {
  max-width: 800px;
}

.krapik-service-row__body .krapik-eyebrow {
  margin-bottom: 1rem;
}

.krapik-service-row__body h2,
.krapik-about-note h2,
.krapik-contact-aside h2,
.krapik-empty-state h2 {
  max-width: 19ch;
  margin: 0;
  color: var(--krapik-ink);
  font-family: var(--krapik-font-display);
  font-size: clamp(1.9rem, 1.45rem + 1.9vw, 3.25rem);
  font-weight: 600;
  letter-spacing: -.06em;
  line-height: .98;
}

.krapik-service-row__body p {
  max-width: 60ch;
  margin: 1.15rem 0 0;
  color: var(--krapik-muted);
  font-size: clamp(1rem, .95rem + .3vw, 1.18rem);
  line-height: 1.66;
}

.krapik-tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  margin: 1.5rem 0 0;
  padding: 0;
  list-style: none;
}

.krapik-tag-list li {
  padding: .48rem .72rem;
  border: 1px solid var(--krapik-line);
  border-radius: 999px;
  color: var(--krapik-ink);
  font-size: .82rem;
  font-weight: 600;
}

.krapik-offer-grid {
  gap: 1px;
  background: rgba(247,246,241,.17);
  border: 1px solid rgba(247,246,241,.2);
  border-radius: var(--krapik-radius-md);
  overflow: hidden;
}

.krapik-offer-card {
  min-height: 250px;
  padding: var(--krapik-space-3);
  background: var(--krapik-ink);
}

.krapik-offer-card > span {
  color: rgba(247,246,241,.55);
}

.krapik-offer-card h3 {
  margin: 2.8rem 0 .7rem;
  color: var(--krapik-paper);
  font-size: clamp(1.35rem, 1.1rem + .9vw, 2rem);
  letter-spacing: -.045em;
}

.krapik-offer-card p {
  margin: 0;
  color: rgba(247,246,241,.7);
  line-height: 1.65;
}

.krapik-about-statement {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(250px, .8fr);
  gap: var(--krapik-space-5);
  align-items: start;
}

.krapik-about-statement .krapik-prose {
  color: var(--krapik-muted);
}

.krapik-about-statement .krapik-prose p {
  margin-top: 0;
}

.krapik-about-statement .krapik-prose p + p {
  margin-top: 1rem;
}

.krapik-principles {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  border-top: 1px solid var(--krapik-line);
}

.krapik-principles > article {
  min-height: 260px;
  padding: var(--krapik-space-3);
  border-bottom: 1px solid var(--krapik-line);
}

.krapik-principles > article:nth-child(odd) {
  border-right: 1px solid var(--krapik-line);
}

.krapik-principles h3 {
  max-width: 15ch;
  margin: 2.8rem 0 .7rem;
  color: var(--krapik-ink);
  font-family: var(--krapik-font-display);
  font-size: clamp(1.4rem, 1.15rem + 1vw, 2.1rem);
  font-weight: 600;
  letter-spacing: -.05em;
  line-height: 1.02;
}

.krapik-principles p {
  max-width: 46ch;
  margin: 0;
  color: var(--krapik-muted);
  line-height: 1.6;
}

.krapik-about-note {
  display: grid;
  grid-template-columns: minmax(0, .75fr) minmax(0, 1.25fr);
  gap: var(--krapik-space-5);
  padding: var(--krapik-space-4);
  border: 1px solid var(--krapik-line);
  border-radius: var(--krapik-radius-lg);
  background: var(--krapik-surface);
}

.krapik-about-note h2 {
  max-width: 17ch;
}

.krapik-about-note p {
  max-width: 55ch;
  margin: 1rem 0 0;
  color: var(--krapik-muted);
  font-size: clamp(1rem, .95rem + .3vw, 1.18rem);
  line-height: 1.65;
}

.krapik-contact-layout {
  display: grid;
  grid-template-columns: minmax(235px, .7fr) minmax(0, 1.3fr);
  gap: var(--krapik-space-5);
  align-items: start;
}

.krapik-contact-aside {
  position: sticky;
  top: 2rem;
}

.krapik-contact-aside h2 {
  margin-top: .85rem;
}

.krapik-contact-aside ul {
  display: grid;
  gap: .8rem;
  margin: var(--krapik-space-3) 0 1.2rem;
  padding: 0;
  list-style: none;
}

.krapik-contact-aside li {
  position: relative;
  padding-left: 1.25rem;
  color: var(--krapik-muted);
  line-height: 1.6;
}

.krapik-contact-aside li::before {
  position: absolute;
  top: .55rem;
  left: 0;
  width: .5rem;
  height: .5rem;
  border-radius: 50%;
  background: var(--krapik-lime-deep);
  content: '';
}

.krapik-contact-aside > p {
  color: var(--krapik-muted);
  font-size: .92rem;
}

.krapik-contact-panel {
  padding: clamp(1.35rem, 1rem + 2.5vw, 3rem);
  border: 1px solid var(--krapik-line);
  border-radius: var(--krapik-radius-lg);
  background: var(--krapik-surface);
  box-shadow: var(--krapik-shadow);
}

.krapik-contact-form p {
  margin: 0 0 1.05rem;
}

.krapik-contact-form__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0 1rem;
}

.krapik-contact-form label {
  display: block;
  margin-bottom: .5rem;
  color: var(--krapik-ink);
  font-family: var(--krapik-font-display);
  font-size: .86rem;
  font-weight: 600;
}

.krapik-contact-form input,
.krapik-contact-form select,
.krapik-contact-form textarea {
  width: 100%;
  min-height: 48px;
  padding: .78rem .85rem;
  border: 1px solid var(--krapik-line);
  border-radius: var(--krapik-radius-sm);
  background: var(--krapik-paper);
  color: var(--krapik-ink);
  font-size: .96rem;
  line-height: 1.45;
}

.krapik-contact-form textarea {
  min-height: 150px;
  resize: vertical;
}

.krapik-contact-form input:focus,
.krapik-contact-form select:focus,
.krapik-contact-form textarea:focus {
  border-color: var(--krapik-ink);
  outline: 2px solid var(--krapik-lime);
  outline-offset: 2px;
}

.krapik-contact-form__honeypot {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
}

.krapik-form-notice {
  margin-bottom: 1.2rem;
  padding: .9rem 1rem;
  border: 1px solid #d2ac9d;
  border-radius: var(--krapik-radius-sm);
  background: #fff4ef;
  color: #742e17;
  font-size: .92rem;
  line-height: 1.5;
}

.krapik-form-notice--success {
  border-color: #a8be9e;
  background: #f1f7ef;
  color: #2e5d2a;
}

.krapik-form-note {
  margin: 1.15rem 0 0;
  color: var(--krapik-muted);
  font-size: .79rem;
  line-height: 1.55;
}

.krapik-insights-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1px;
  border: 1px solid var(--krapik-line);
  border-radius: var(--krapik-radius-md);
  overflow: hidden;
  background: var(--krapik-line);
}

.krapik-insight-card {
  display: flex;
  min-height: 290px;
  flex-direction: column;
  padding: var(--krapik-space-3);
  background: var(--krapik-surface);
}

.krapik-insight-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  color: var(--krapik-muted);
  font-family: var(--krapik-font-display);
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.krapik-insight-card h2 {
  margin: 2.8rem 0 .7rem;
  color: var(--krapik-ink);
  font-family: var(--krapik-font-display);
  font-size: clamp(1.35rem, 1.1rem + .8vw, 1.85rem);
  font-weight: 600;
  letter-spacing: -.045em;
  line-height: 1.03;
}

.krapik-insight-card h2 a {
  color: inherit;
  text-decoration: none;
}

.krapik-insight-card h2 a:hover {
  text-decoration: underline;
  text-decoration-color: var(--krapik-lime-deep);
  text-decoration-thickness: 2px;
  text-underline-offset: .16em;
}

.krapik-insight-card p {
  margin: 0;
  color: var(--krapik-muted);
  line-height: 1.62;
}

.krapik-inline-link {
  display: inline-flex;
  gap: .5rem;
  margin-top: auto;
  padding-top: 1.6rem;
  color: var(--krapik-ink);
  font-family: var(--krapik-font-display);
  font-size: .86rem;
  font-weight: 600;
  text-decoration: none;
}

.krapik-inline-link:hover {
  color: var(--krapik-lime-deep);
}

.krapik-empty-state {
  max-width: 660px;
  padding: clamp(1.5rem, 1rem + 3vw, 4rem);
  border: 1px solid var(--krapik-line);
  border-radius: var(--krapik-radius-lg);
  background: var(--krapik-surface);
}

.krapik-empty-state h2 {
  margin-top: 1rem;
}

.krapik-empty-state p {
  max-width: 48ch;
  margin: 1rem 0 0;
  color: var(--krapik-muted);
  line-height: 1.65;
}

.krapik-404-layout {
  display: grid;
  grid-template-columns: minmax(0, .55fr) minmax(0, 1.45fr);
  gap: var(--krapik-space-5);
  align-items: center;
}

.krapik-404-code {
  color: var(--krapik-lime);
  font-family: var(--krapik-font-display);
  font-size: clamp(7rem, 8vw + 3rem, 14rem);
  font-weight: 700;
  letter-spacing: -.12em;
  line-height: .8;
}

.krapik-404-layout .krapik-lead {
  margin: 1.3rem 0 0;
  color: rgba(247,246,241,.7);
}

.krapik-404-layout .krapik-button--ghost {
  border-color: var(--krapik-paper);
  color: var(--krapik-paper);
}

/* Krapik v1.3 — polished page copy and extended inquiry form */
.krapik-grid--4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

.krapik-featured-work__intro {
  max-width: 62ch;
  margin: calc(-1 * var(--krapik-space-2)) 0 var(--krapik-space-4);
  color: rgba(247,246,241,.7);
  line-height: 1.65;
}

.krapik-work-intro {
  max-width: 64ch;
  margin: 0 0 var(--krapik-space-4);
  color: var(--krapik-muted);
  font-size: clamp(1.05rem, .98rem + .35vw, 1.24rem);
  line-height: 1.65;
}

.krapik-contact-panel__title {
  margin: 0;
  color: var(--krapik-ink);
  font-family: var(--krapik-font-display);
  font-size: clamp(1.7rem, 1.35rem + 1vw, 2.45rem);
  font-weight: 600;
  letter-spacing: -.055em;
  line-height: 1;
}

.krapik-contact-panel__intro {
  max-width: 46ch;
  margin: .8rem 0 1.7rem;
  color: var(--krapik-muted);
  line-height: 1.6;
}

.krapik-contact-email {
  display: grid;
  gap: .3rem;
  margin-top: 2.2rem;
  padding-top: 1.1rem;
  border-top: 1px solid var(--krapik-line);
}

.krapik-contact-email span {
  color: var(--krapik-muted);
  font-family: var(--krapik-font-display);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.krapik-contact-email a {
  color: var(--krapik-ink);
  font-family: var(--krapik-font-display);
  font-size: 1rem;
  font-weight: 600;
  text-decoration-color: var(--krapik-lime-deep);
  text-underline-offset: .18em;
}

/* Krapik v1.4 — Work inventory and real-project presentation */
.krapik-work-index__intro {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--krapik-space-3);
  align-items: end;
  margin-bottom: var(--krapik-space-4);
}

.krapik-work-intro {
  max-width: 61ch;
  margin: 0;
  color: var(--krapik-muted);
  font-size: clamp(1.12rem, 1rem + .35vw, 1.35rem);
  line-height: 1.55;
}

.krapik-work-index__count {
  margin: 0;
  color: var(--krapik-muted);
  font-size: .76rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  white-space: nowrap;
}

.krapik-work-grid { gap: clamp(1rem, 1rem + 1.7vw, 2.15rem); }

.krapik-project-card {
  min-height: 100%;
  border: 1px solid transparent;
  box-shadow: 0 0 0 rgba(0,0,0,0);
  transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
}

.krapik-project-card:hover {
  border-color: rgba(255,255,255,.15);
  box-shadow: 0 20px 36px rgba(14, 16, 17, .18);
  transform: translateY(-5px);
}

.krapik-project-card__media { background: #202526; }

.krapik-project-card__placeholder {
  position: relative;
  display: grid;
  width: 100%;
  height: 100%;
  min-height: 100%;
  overflow: hidden;
  isolation: isolate;
  place-items: center;
  background: var(--krapik-project-accent, var(--krapik-lime));
  color: var(--krapik-ink);
}

.krapik-project-card__placeholder::before,
.krapik-project-card__placeholder::after {
  position: absolute;
  z-index: -1;
  border-radius: 50%;
  background: rgba(255,255,255,.18);
  content: '';
}

.krapik-project-card__placeholder::before { width: 110%; aspect-ratio: 1; top: -64%; right: -38%; }
.krapik-project-card__placeholder::after { width: 54%; aspect-ratio: 1; bottom: -30%; left: -8%; background: rgba(16,22,23,.14); }

.krapik-project-card__placeholder-number,
.krapik-project-card__placeholder-domain {
  position: absolute;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .11em;
  text-transform: uppercase;
}

.krapik-project-card__placeholder-number { top: 1rem; left: 1rem; }
.krapik-project-card__placeholder-domain { right: 1rem; bottom: 1rem; max-width: calc(100% - 2rem); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.krapik-project-card__placeholder-mark {
  font-size: clamp(5rem, 6vw, 8.7rem);
  font-weight: 700;
  letter-spacing: -.1em;
  line-height: .76;
}

.krapik-project-card__body { display: flex; min-height: 232px; flex-direction: column; }
.krapik-project-card__labels { display: flex; flex-wrap: wrap; gap: .5rem .85rem; }
.krapik-project-card__industry { color: rgba(247,246,241,.48); font-size: .72rem; font-weight: 600; }
.krapik-project-card__body p { margin: .85rem 0 1.2rem; color: rgba(247,246,241,.72); font-size: .98rem; line-height: 1.55; }
.krapik-project-card__link { margin-top: auto; color: var(--krapik-lime); font-size: .84rem; font-weight: 700; }

.krapik-project-single__eyebrow-row { display: flex; flex-wrap: wrap; gap: .65rem 1rem; align-items: center; margin-bottom: 1rem; }
.krapik-project-single__industry { color: rgba(247,246,241,.62); font-size: .78rem; font-weight: 700; }
.krapik-project-single__hero .krapik-lead { margin: 1.75rem 0 0; }
.krapik-project-single__visual-wrap { padding-top: var(--krapik-space-4); }
.krapik-project-single__image { display: block; width: 100%; height: auto; border-radius: var(--krapik-radius-lg); }

.krapik-project-single__visual-placeholder {
  position: relative;
  display: grid;
  min-height: min(59vw, 630px);
  overflow: hidden;
  place-items: center;
  border-radius: var(--krapik-radius-lg);
  background: var(--krapik-project-accent, var(--krapik-lime));
  color: var(--krapik-ink);
}

.krapik-project-single__visual-placeholder::before {
  position: absolute;
  width: 72%;
  aspect-ratio: 1;
  top: -46%;
  left: -13%;
  border: 1px solid rgba(16,22,23,.22);
  border-radius: 50%;
  box-shadow: 0 0 0 72px rgba(255,255,255,.12), 0 0 0 144px rgba(16,22,23,.06);
  content: '';
}

.krapik-project-single__visual-mark { position: relative; font-size: clamp(7rem, 18vw, 17rem); font-weight: 700; letter-spacing: -.12em; line-height: .72; }
.krapik-project-single__visual-label { position: absolute; right: 1.25rem; bottom: 1.15rem; font-size: .74rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
.krapik-project-meta--four { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.krapik-project-meta dd a { color: var(--krapik-ink); text-decoration-thickness: 1px; text-underline-offset: 3px; }
.krapik-project-single__content { margin-top: clamp(2.5rem, 2rem + 3vw, 5rem); }

/* Krapik v1.5 — launch foundations */
.krapik-studio-footer {
  padding: clamp(3rem, 4vw, 5.5rem) 0;
  background: var(--krapik-ink);
  color: var(--krapik-paper);
}
.krapik-studio-footer__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.65fr) minmax(150px, .6fr) minmax(180px, .7fr);
  gap: var(--krapik-space-4);
}
.krapik-studio-footer__intro { max-width: 35ch; }
.krapik-studio-footer__brand {
  display: inline-block;
  margin-bottom: 1rem;
  color: var(--krapik-paper);
  font-family: var(--krapik-font-display);
  font-size: clamp(1.8rem, 1.3rem + 1vw, 2.6rem);
  font-weight: 700;
  letter-spacing: -.07em;
  text-decoration: none;
}
.krapik-studio-footer__intro p { margin: 0; color: rgba(247,246,241,.67); line-height: 1.6; }
.krapik-studio-footer__email { display: inline-block; margin-top: 1.4rem; color: var(--krapik-lime); font-weight: 700; text-decoration: none; }
.krapik-studio-footer__nav { display: grid; align-content: start; gap: .65rem; }
.krapik-studio-footer__nav span { margin-bottom: .35rem; color: rgba(247,246,241,.52); font-size: .72rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
.krapik-studio-footer__nav a { color: var(--krapik-paper); font-weight: 600; text-decoration: none; }
.krapik-studio-footer__nav a:hover, .krapik-studio-footer__email:hover { color: var(--krapik-lime); }
.krapik-thank-you-layout { display: grid; gap: 1.25rem; max-width: 850px; }
.krapik-thank-you-layout .krapik-lead { max-width: 58ch; }
.krapik-legal-layout { display: grid; grid-template-columns: minmax(0, 1fr) minmax(230px, .32fr); gap: var(--krapik-space-5); align-items: start; }
.krapik-legal-content { max-width: 760px; font-size: 1rem; line-height: 1.75; }
.krapik-legal-content h2 { margin: 2.5rem 0 .75rem; color: var(--krapik-ink); font-size: clamp(1.45rem, 1.2rem + .9vw, 2.15rem); letter-spacing: -.05em; }
.krapik-legal-content h2:first-child { margin-top: 0; }
.krapik-legal-content p, .krapik-legal-content ul { margin: 0 0 1.1rem; }
.krapik-legal-content ul { padding-left: 1.25rem; }
.krapik-legal-content li + li { margin-top: .45rem; }
.krapik-legal-content a { color: var(--krapik-ink); font-weight: 700; text-decoration-color: var(--krapik-lime-deep); text-underline-offset: .18em; }
.krapik-legal-aside { position: sticky; top: 1.5rem; padding: 1.35rem; border: 1px solid var(--krapik-line); border-radius: var(--krapik-radius-md); background: var(--krapik-surface); }
.krapik-legal-aside p { margin: .9rem 0 1.1rem; color: var(--krapik-muted); line-height: 1.6; }
.krapik-legal-aside a { color: var(--krapik-ink); font-weight: 700; }


/* Krapik v1.5.1 — header interaction safeguard
   Keeps all header controls above visual/page layers and prevents decorative
   elements from swallowing taps/clicks. */
.krapik-site #masthead {
  position: relative;
  z-index: 1000;
  isolation: isolate;
  pointer-events: auto;
}

.krapik-site #masthead .site-header-wrap,
.krapik-site #masthead .site-header-inner-wrap,
.krapik-site #masthead .site-header-row-container,
.krapik-site #masthead .site-header-row-container-inner,
.krapik-site #masthead .site-header-row,
.krapik-site #masthead .site-header-item,
.krapik-site #masthead nav,
.krapik-site #masthead a,
.krapik-site #masthead button {
  position: relative;
  z-index: 1;
  pointer-events: auto;
}

.krapik-site #inner-wrap {
  position: relative;
  z-index: 1;
}

.krapik-site .krapik-home-signal::before,
.krapik-site .krapik-project-card__placeholder::before,
.krapik-site .krapik-project-card__placeholder::after,
.krapik-site .krapik-project-single__visual-placeholder::before {
  pointer-events: none;
}

/* Krapik v1.5.2 — header CTA alignment and active-state contrast
   Keeps the project CTA vertically centered with the navigation and prevents
   Kadence's general current-menu rule from overriding button text color. */
.krapik-site .main-navigation .primary-menu-container > ul {
  align-items: center;
}

.krapik-site .main-navigation .primary-menu-container > ul > li.krapik-menu-cta {
  display: flex;
  align-items: center;
}

.krapik-site .main-navigation .primary-menu-container > ul > li.krapik-menu-cta > a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 42px;
  box-sizing: border-box;
  padding: 0 1rem;
  line-height: 1;
}

.krapik-site .main-navigation .primary-menu-container > ul > li.krapik-menu-cta > a::after {
  display: none !important;
}

.krapik-site .main-navigation .primary-menu-container > ul > li.krapik-menu-cta.current-menu-item > a,
.krapik-site .main-navigation .primary-menu-container > ul > li.krapik-menu-cta.current_page_item > a,
.krapik-site .main-navigation .primary-menu-container > ul > li.krapik-menu-cta > a[aria-current="page"] {
  background: var(--krapik-ink);
  color: var(--krapik-paper);
}

.krapik-site .main-navigation .primary-menu-container > ul > li.krapik-menu-cta > a:hover,
.krapik-site .main-navigation .primary-menu-container > ul > li.krapik-menu-cta > a:focus,
.krapik-site .main-navigation .primary-menu-container > ul > li.krapik-menu-cta > a:focus-visible {
  background: var(--krapik-lime);
  color: var(--krapik-ink);
}
