/* ============================================================
   Punditz Design & Build — main.css
   Tokens, type (Courier New), staggered gallery, album, pages
   ============================================================ */

:root {
  --ink: #141414;
  --graphite: #5c5b58;
  --gray: #9b9a97;
  --mortar: #d9d7d3;
  --paper: #f5f4f2;
  --accent: #e8590c;
  --mono: "Courier New", Courier, monospace;
  --pad: 60px;
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  background: #fff;
  color: var(--ink);
  font-family: var(--mono);
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }

/* ---------- Header / nav ---------- */
.site-hdr {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 54px var(--pad) 0;
}
.wm {
  font-weight: 700;
  font-size: 24px;
  letter-spacing: 2px;
  color: var(--ink);
  line-height: 1;
}
.wm small {
  display: block;
  font-weight: 400;
  font-size: 9px;
  letter-spacing: 6px;
  text-transform: uppercase;
  color: var(--gray);
  margin-top: 11px;
  height: 12px;
}
.caret {
  color: var(--accent);
  font-weight: 700;
  animation: blink 1s steps(1) infinite;
}
@keyframes blink { 0%, 50% { opacity: 1; } 50.01%, 100% { opacity: 0; } }

.nav {
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  padding-top: 6px;
}
.nav a {
  margin-left: 26px;
  color: var(--ink);
  transition: color 0.2s;
}
.nav a:first-child { margin-left: 0; }
.nav a:hover { color: var(--accent); }
.nav a.on {
  color: var(--accent);
  border-bottom: 2px solid var(--accent);
  padding-bottom: 4px;
}

/* ---------- Gallery head / filters ---------- */
.gallery-head {
  display: flex;
  justify-content: flex-end;
  padding: 84px var(--pad) 48px;
}
.filters {
  font-size: 11px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  text-align: right;
}
.filters button {
  margin-left: 24px;
  color: #bdbdbd;
  cursor: pointer;
  background: none;
  border: none;
  font: inherit;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  transition: color 0.2s;
  padding: 0 0 4px;
  border-bottom: 2px solid transparent;
}
.filters button:hover { color: #666; }
.filters button.on { color: var(--accent); border-bottom-color: var(--accent); }

/* ---------- Staggered gallery ----------
   Columns are built by JS (layoutGallery): 3 cols desktop / 2 tablet / 1 mobile.
   The margin-top on c2/c3 creates the dropped "cascade". */
.cols {
  display: flex;
  gap: 46px;
  padding: 0 var(--pad) 40px;
  align-items: flex-start;
}
.col { flex: 1; min-width: 0; }
.col.c2 { margin-top: 130px; }
.col.c3 { margin-top: 60px; }

.item {
  display: block;
  margin-bottom: 74px;
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.item.in { opacity: 1; transform: none; }
.item.hide { display: none; }

.thumb { overflow: hidden; background: #ececec; }
.thumb picture { display: block; width: 100%; height: 100%; }
.thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(100%) contrast(1.03);
  transform: scale(1);
  transition: filter 0.55s ease, transform 0.8s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.item:hover .thumb img { filter: grayscale(0%); transform: scale(1.04); }

.r-portrait { aspect-ratio: 3 / 4; }
.r-landscape { aspect-ratio: 4 / 3; }
.r-square { aspect-ratio: 1 / 1; }

.cap { padding-top: 15px; display: flex; align-items: baseline; gap: 10px; }
.cap .idx { color: var(--accent); font-size: 10px; letter-spacing: 1px; flex: none; }
.cap .nm { font-size: 13px; color: var(--ink); letter-spacing: 0.4px; }
.cap .mt {
  font-size: 9.5px;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: #a8a8a8;
  margin-top: 6px;
}

/* ---------- "View earlier work" link + page intro ---------- */
.more-link {
  text-align: center;
  padding: 30px var(--pad) 70px;
}
.more-link a {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gray);
  border-bottom: 1px solid transparent;
  padding-bottom: 4px;
  transition: color 0.2s, border-color 0.2s;
}
.more-link a:hover { color: var(--accent); border-color: var(--accent); }
.page-intro {
  padding: 80px var(--pad) 0;
  max-width: 680px;
}

/* ---------- Album / project detail ---------- */
.album { padding: 70px var(--pad) 40px; max-width: 980px; margin: 0 auto; }
.back {
  display: inline-block;
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gray);
  margin-bottom: 40px;
  transition: color 0.2s;
}
.back:hover { color: var(--accent); }
.album-head { max-width: 560px; margin-bottom: 44px; }
.atitle { font-weight: 700; font-size: 24px; letter-spacing: 1px; margin: 0; }
.ameta {
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--accent);
  margin-top: 12px;
}
.adesc { font-size: 13px; line-height: 1.9; color: var(--graphite); margin-top: 20px; }
.agrid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.agrid picture { display: contents; }
.agrid img { width: 100%; border-radius: 1px; }
.agrid img.tall { grid-row: span 2; height: 100%; object-fit: cover; }

/* ---------- Lightbox ---------- */
.lb {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(15, 15, 15, 0.95);
}
.lb.open { display: flex; }
.lb-img {
  max-width: 90vw;
  max-height: 88vh;
  object-fit: contain;
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.55);
  animation: lbfade 0.3s ease;
}
@keyframes lbfade { from { opacity: 0; } to { opacity: 1; } }
.lb-close, .lb-prev, .lb-next {
  position: absolute;
  background: none;
  border: none;
  color: #d6d6d6;
  cursor: pointer;
  font-family: var(--mono);
  transition: color 0.2s;
  line-height: 1;
  user-select: none;
}
.lb-close:hover, .lb-prev:hover, .lb-next:hover { color: var(--accent); }
.lb-close { top: 22px; right: 28px; font-size: 30px; }
.lb-prev, .lb-next { top: 50%; transform: translateY(-50%); font-size: 54px; padding: 10px 20px; }
.lb-prev { left: 10px; }
.lb-next { right: 10px; }
.lb-count {
  position: absolute;
  bottom: 24px;
  left: 0;
  right: 0;
  text-align: center;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 2px;
  color: #aaa;
}
@media (max-width: 640px) {
  .lb-prev, .lb-next { font-size: 40px; padding: 8px 12px; }
  .lb-close { top: 14px; right: 16px; }
}

/* ---------- Content pages (About / Services / Contact) ---------- */
.sheet { padding: 80px var(--pad) 70px; max-width: 780px; }
.eyebrow {
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 26px;
}
.lead { font-size: 19px; line-height: 1.6; letter-spacing: 0.3px; margin: 0; }
.body { font-size: 13px; line-height: 1.95; color: var(--graphite); margin-top: 22px; }

/* Founder portrait (About) */
.founder { margin: 50px 0 0; max-width: 300px; }
.founder img {
  width: 100%; height: auto; display: block; background: #ececec;
  filter: grayscale(100%) contrast(1.03);
}
.founder figcaption { padding-top: 14px; }
.founder-name { display: block; font-size: 14px; color: var(--ink); letter-spacing: 0.4px; }
.founder-role {
  display: block; font-size: 9.5px; letter-spacing: 1.4px;
  text-transform: uppercase; color: var(--gray); margin-top: 5px;
}

/* Services — practice groups with full descriptions */
.svc-group { margin-top: 56px; }
.svc-group-title {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gray);
  padding-bottom: 16px;
  border-bottom: 1px solid #eee;
  margin: 0 0 30px;
}
.svc-item { margin-bottom: 38px; }
.svc-item:last-child { margin-bottom: 0; }
.svc-name {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.5px;
  color: var(--ink);
  margin: 0 0 12px;
}
.svc-name::before {
  content: "";
  display: inline-block;
  width: 9px;
  height: 9px;
  background: var(--accent);
  margin-right: 12px;
  vertical-align: middle;
}
.svc-desc {
  font-size: 13px;
  line-height: 1.95;
  color: var(--graphite);
  margin: 0;
  max-width: 680px;
}

.contact-grid { display: flex; gap: 60px; margin-top: 50px; flex-wrap: wrap; }
.cblock { min-width: 190px; }
.ck { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--gray); margin-bottom: 12px; }
.cv { font-size: 14px; line-height: 1.8; }
.cv a { color: var(--accent); }
.btn {
  display: inline-block;
  margin-top: 8px;
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #fff;
  background: var(--accent);
  padding: 13px 22px;
  border-radius: 2px;
  transition: opacity 0.2s;
}
.btn:hover { opacity: 0.88; }

/* ---------- Album prev/next nav ---------- */
.album-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-top: 56px;
  padding-top: 26px;
  border-top: 1px solid #f0f0f0;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
}
.album-nav a { color: var(--graphite); transition: color 0.2s; }
.album-nav a:hover { color: var(--accent); }
.album-nav .album-nav-all { color: var(--gray); }
.album-nav > span { flex: 1; }
.album-nav a:first-child { flex: 1; }
.album-nav a:last-child { flex: 1; text-align: right; }
.album-nav .album-nav-all { flex: 0; white-space: nowrap; }

/* ---------- Contact form ---------- */
.cform-wrap { margin-top: 60px; max-width: 620px; }
.cform .hp { position: absolute; left: -9999px; width: 1px; height: 1px; opacity: 0; }
.cf-row { display: flex; gap: 22px; flex-wrap: wrap; }
.cf-field { display: block; flex: 1; min-width: 200px; margin-bottom: 22px; }
.cf-field span {
  display: block;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gray);
  margin-bottom: 8px;
}
.cf-field input, .cf-field textarea {
  width: 100%;
  font-family: var(--mono);
  font-size: 16px; /* >=16px so iOS Safari doesn't auto-zoom on focus */
  color: var(--ink);
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 2px;
  padding: 11px 13px;
  transition: border-color 0.2s;
}
.cf-field input:focus, .cf-field textarea:focus {
  outline: none;
  border-color: var(--accent);
}
.cf-field textarea { resize: vertical; }
.cf-note {
  font-family: var(--mono);
  font-size: 12px;
  line-height: 1.6;
  padding: 14px 16px;
  border-radius: 2px;
  margin-bottom: 24px;
}
.cf-note.ok { color: #1a1a1a; background: #f4f4f2; border-left: 3px solid var(--accent); }
.cf-note.err { color: #1a1a1a; background: #fbeee8; border-left: 3px solid var(--accent); }

/* ---------- Footer ---------- */
.site-ft {
  border-top: 1px solid #eee;
  margin-top: 60px;
  padding: 44px var(--pad) 54px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 30px;
  flex-wrap: wrap;
  font-family: var(--mono);
}
.ft-wm {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 2px;
  color: var(--ink);
}
.ft-wm .hl { color: var(--accent); }
.ft-addr {
  font-size: 10px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--gray);
  margin-top: 12px;
}
.ft-meta { text-align: right; }
.ft-contact { font-size: 12px; letter-spacing: 0.5px; color: var(--graphite); }
.ft-contact a { color: var(--graphite); transition: color 0.2s; }
.ft-contact a:hover { color: var(--accent); }
.ft-contact .dot { color: #ccc; margin: 0 8px; }
.ft-social {
  display: flex;
  gap: 16px;
  justify-content: flex-end;
  margin-top: 16px;
}
.ft-social a {
  color: var(--ink);
  display: inline-flex;
  transition: color 0.2s, transform 0.2s;
}
.ft-social a:hover { color: var(--accent); transform: translateY(-2px); }
.ft-fine {
  font-size: 9px;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: #c0c0c0;
  margin-top: 18px;
}

/* ---------- Album / project detail ---------- */

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
  :root { --pad: 34px; }
  .cols { gap: 28px; }
  .col.c2 { margin-top: 70px; }
}
@media (max-width: 640px) {
  :root { --pad: 22px; }
  .site-hdr { flex-direction: column; gap: 20px; padding-top: 34px; }
  .nav a:first-child { margin-left: 0; }
  .nav a { margin-left: 0; margin-right: 20px; }
  .gallery-head { padding-top: 40px; justify-content: flex-start; }
  .filters { text-align: left; }
  .filters button:first-child { margin-left: 0; }
  /* single column, color shown (no hover on touch) */
  .cols { flex-direction: column; gap: 0; }
  .col.c2, .col.c3 { margin-top: 0; }
  .item { margin-bottom: 44px; }
  .thumb img { filter: none; }
  .agrid { grid-template-columns: 1fr; }
  .agrid img.tall { grid-row: auto; }
  .site-ft { flex-direction: column; gap: 10px; }
  /* contact: stack info blocks + form fields, drop min-widths that overflow */
  .contact-grid { flex-direction: column; gap: 30px; }
  .cblock { min-width: 0; }
  .cf-row { flex-direction: column; gap: 0; }
  .cf-field { min-width: 0; }
  /* larger touch targets (>=44px tap area) */
  .nav a { display: inline-block; padding: 15px 0; }
  .nav a.on { padding-bottom: 13px; }
  .filters button { padding: 14px 0; }
  .ft-contact a { display: inline-block; padding: 8px 0; }
  .ft-social { gap: 6px; }
  .ft-social a { padding: 13px; }
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; }
  .item { opacity: 1; transform: none; }
}
