/* Qwery — page-specific styles for index.html (cover) */

/* COVER */
.cover {
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid var(--rule);
}
.cover-bg {
  position: absolute; inset: -10% -10% -10% -10%;
  background:
    radial-gradient(ellipse at 70% 20%, color-mix(in oklab, var(--accent) 18%, transparent), transparent 55%),
    repeating-linear-gradient(135deg, transparent, transparent 14px,
      color-mix(in oklab, var(--ink) 8%, transparent) 14px,
      color-mix(in oklab, var(--ink) 8%, transparent) 15px),
    var(--surface);
  will-change: transform;
}
.cover-grain {
  position: absolute; inset: 0; pointer-events: none; opacity: .35; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.6 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}
.cover-content {
  position: relative; z-index: 2;
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 80px var(--pad-x) 56px;
  display: flex; flex-direction: column; gap: 32px;
  min-height: 720px;
}
.cover-top {
  display: flex; justify-content: space-between; align-items: center;
}
.cover-title {
  font-size: var(--fs-d1);
  margin: auto 0;
  text-shadow: 0 1px 0 color-mix(in oklab, var(--bg) 40%, transparent);
}
.cover-bottom {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 32px; align-items: end;
  border-top: 1px solid var(--rule-strong);
  padding-top: 28px;
}
.cover-ctas { display: flex; gap: 12px; }

/* STATS */
.stats {
  border-bottom: 1px solid var(--rule);
  padding: 80px 0;
}
.stats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}
.stat { display: flex; flex-direction: column; gap: 8px; align-items: center; text-align: center; }
.stat-num { font-size: clamp(48px, 6vw, 80px); line-height: 1; color: var(--ink); }
.stat:nth-child(2) .stat-num { color: var(--accent); }
.stat-label { font-size: var(--fs-label); letter-spacing: var(--ls-eyebrow); color: var(--ink-soft); }
@media (max-width: 700px) { .stats-grid { grid-template-columns: 1fr; gap: 24px; } }

/* SECTIONS — shared shell (overrides handled below) */
.section-title {
  font-size: var(--fs-d2);
  margin: 12px 0 56px;
}
.section-head {
  display: grid; grid-template-columns: 1.2fr 1fr; gap: 48px; align-items: end;
  margin-bottom: 56px;
}
.section-aside p { font-size: var(--fs-body); line-height: 1.55; color: var(--ink-soft); margin: 0 0 16px; max-width: 46ch; }
.section-aside .see-all {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: var(--fs-label); letter-spacing: var(--ls-label);
  border-bottom: 1px solid var(--rule-strong);
  padding-bottom: 4px;
}
.section-aside .see-all:hover { color: var(--accent); border-color: var(--accent); }

/* TOC */
.toc-grid {
  display: grid; grid-template-columns: 200px 1fr; gap: 64px;
}
.toc-head .eyebrow { border-top: 2px solid var(--ink); padding-top: 14px; }
.toc-list { border-top: 2px solid var(--ink); }
.toc-row {
  display: grid;
  grid-template-columns: 60px minmax(280px, 1.1fr) minmax(220px, 1.4fr) 60px;
  align-items: baseline;
  padding: 22px 0;
  border-bottom: 1px solid var(--rule);
  transition: padding 240ms cubic-bezier(.2,.8,.2,1), color 240ms;
  gap: 16px;
}
@media (max-width: 1100px) {
  .toc-row {
    grid-template-columns: 48px 1fr auto;
    grid-template-areas:
      "num title page"
      "num desc desc";
    row-gap: 6px;
  }
  .toc-row .num { grid-area: num; }
  .toc-row .title { grid-area: title; }
  .toc-row .desc { grid-area: desc; }
  .toc-row .page { grid-area: page; align-self: start; }
}
.toc-row:hover { padding-left: 16px; color: var(--accent); }
.toc-row .num { font-family: 'JetBrains Mono', monospace; font-size: var(--fs-sm); color: var(--ink-faint); }
.toc-row .title { font-family: 'Archivo Black', sans-serif; font-weight: 800; letter-spacing: -0.03em; font-size: var(--fs-d3); }
.toc-row .desc { font-size: var(--fs-sm); color: var(--ink-soft); margin-left: 0; }
.toc-row .page { font-size: var(--fs-label); text-align: right; letter-spacing: var(--ls-label); color: var(--ink-faint); }
.toc-row:hover .num, .toc-row:hover .desc, .toc-row:hover .page { color: var(--accent); }

/* WORK */
.work-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
}
.work-grid > .work-card { grid-column: span 1; }
@media (max-width: 700px) {
  .work-grid { grid-template-columns: 1fr; }
}
.work-card { display: block; }
.work-card .work-thumb {
  width: 100%;
  aspect-ratio: 3/2;
  transition: transform 480ms cubic-bezier(.2,.8,.2,1), filter 480ms;
}
.work-card:hover .work-thumb {
  transform: translateY(-4px);
  filter: brightness(1.05);
}
.work-meta {
  margin-top: 16px;
  display: flex; justify-content: space-between; align-items: baseline;
  border-bottom: 1px solid var(--rule);
  padding-bottom: 10px;
}
.work-meta > div { display: flex; gap: 14px; align-items: baseline; }
.work-num { font-size: var(--fs-label); color: var(--ink-faint); }
.work-name { font-size: var(--fs-d3); }
.work-card:hover .work-name { color: var(--accent); }

/* SERVICES */
.services-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  border-top: 1px solid var(--ink);
}
.svc {
  padding: 32px 24px 28px;
  border-right: 1px solid var(--rule);
  min-height: 320px;
  position: relative;
  display: flex; flex-direction: column;
  transition: background 240ms;
}
.svc:last-child { border-right: 0; }
.svc:hover { background: var(--surface); }
.svc-num { font-size: var(--fs-label); letter-spacing: var(--ls-label); color: var(--ink-faint); margin-bottom: 24px; }
.svc-title { font-size: var(--fs-d3); line-height: 0.95; margin: 0 0 16px; }
.svc-desc { font-size: var(--fs-sm); color: var(--ink-soft); line-height: 1.55; margin: 0 0 24px; }
.svc-from {
  margin-top: auto;
  font-size: var(--fs-label); letter-spacing: var(--ls-label); color: var(--accent);
}
@media (max-width: 1100px) {
  .services-grid { grid-template-columns: repeat(2, 1fr); }
  .svc { border-bottom: 1px solid var(--rule); }
  .svc:nth-child(2n) { border-right: 0; }
}

/* TOOLS */
.tools { background: var(--surface); }
.tools-head {
  display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: end;
  margin-bottom: 40px;
}
.tools-lead { max-width: 40ch; }
.tools-list {
  list-style: none; padding: 0; margin: 0;
  border-top: 2px solid var(--ink);
}
.tools-list li {
  display: grid;
  grid-template-columns: 80px minmax(220px, 1fr) minmax(220px, 1.6fr);
  align-items: baseline;
  padding: 22px 0;
  border-bottom: 1px solid var(--rule);
  gap: 16px;
  transition: padding 240ms cubic-bezier(.2,.8,.2,1), color 240ms;
}
.tools-list li:hover { padding-left: 16px; color: var(--accent); }
.tools-list .num { font-size: var(--fs-label); color: var(--ink-faint); letter-spacing: var(--ls-label); }
.tools-list .name { font-size: var(--fs-d3); font-family: 'Archivo Black', sans-serif; }
.tools-list .role { font-family: 'JetBrains Mono', monospace; font-size: var(--fs-label); letter-spacing: var(--ls-label); text-transform: uppercase; color: var(--ink-soft); }
.tools-list li:hover .num, .tools-list li:hover .role { color: var(--accent); }
@media (max-width: 900px) {
  .tools-head { grid-template-columns: 1fr; }
  .tools-list li { grid-template-columns: 48px 1fr; }
  .tools-list .role { grid-column: 2; font-size: var(--fs-tiny); }
}
.process-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 80px;
  margin-top: 32px;
}
.process-quote blockquote {
  margin: 0;
  font-size: clamp(24px, 2.4vw, 32px);
  line-height: 1.3;
  border-left: 3px solid var(--accent);
  padding-left: 24px;
  color: var(--ink);
}
.process-quote .attr { font-size: var(--fs-label); letter-spacing: var(--ls-label); color: var(--ink-faint); margin-top: 24px; }
.process-steps .step {
  display: grid; grid-template-columns: 60px 140px 1fr;
  align-items: baseline;
  padding: 22px 0;
  border-top: 1px solid var(--rule);
  gap: 16px;
}
.process-steps .step .mono { font-size: var(--fs-label); color: var(--ink-faint); letter-spacing: var(--ls-label); }
.process-steps .step h4 { font-size: var(--fs-h); margin: 0; }
.process-steps .step p { font-size: var(--fs-sm); color: var(--ink-soft); margin: 0; line-height: 1.55; }

/* FEATURE */
.feature {
  background: var(--surface);
}
.feature-grid {
  display: grid; grid-template-columns: 1.2fr 1fr; gap: 56px; align-items: start;
  margin-top: 24px;
}
.feature-media .placeholder { border-color: var(--rule-strong); }
.feature-tags { display: flex; gap: 8px; margin-top: 16px; }
.feature-body { padding-top: 8px; }
.feature-title { font-size: var(--fs-d2); margin: 0 0 24px; }
.feature-list { list-style: none; padding: 0; margin: 24px 0 32px; }
.feature-list li { padding: 14px 0; border-top: 1px solid var(--rule); font-size: var(--fs-body); display: flex; gap: 16px; }
.feature-list li:last-child { border-bottom: 1px solid var(--rule); }
.feature-list .mono { color: var(--accent); }

/* LETTERS */
.letters-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px;
}
.letter { display: flex; flex-direction: column; gap: 24px; }
.letter-rule { height: 2px; background: var(--ink); width: 100%; }
.letter p { margin: 0; font-size: 22px; line-height: 1.35; }
.letter-attr { display: flex; flex-direction: column; gap: 4px; margin-top: auto; }
.letter-attr .h-display { font-size: 22px; }
.letter-attr .mono { font-size: 11px; color: var(--ink-faint); letter-spacing: 0.18em; }

/* BACK COVER */
.back-cover { background: var(--surface-2); }
.back-title { font-size: var(--fs-d2); margin: 12px 0 56px; }
.back-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 0;
  border-top: 2px solid var(--ink);
}
.back-card {
  padding: 32px 24px;
  border-right: 1px solid var(--rule);
  display: flex; flex-direction: column; gap: 8px;
  position: relative;
  transition: background 240ms, color 240ms, padding-left 240ms;
}
.back-card:last-child { border-right: 0; }
.back-card:hover { background: var(--accent); color: var(--accent-ink); padding-left: 36px; }
.back-card .label { font-size: 11px; letter-spacing: 0.18em; color: var(--ink-faint); }
.back-card:hover .label { color: var(--accent-ink); }
.back-card .value { font-size: 32px; }
.back-card .arrow { position: absolute; right: 24px; top: 50%; transform: translateY(-50%); font-size: 14px; opacity: .5; }
.back-card:hover .arrow { opacity: 1; }

/* responsive */
@media (max-width: 900px) {
  .toc-grid, .feature-grid, .process-grid, .letters-grid, .back-grid, .work-grid, .section-head, .cover-bottom {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
  .back-card { border-right: 0; border-bottom: 1px solid var(--rule); }
}
