/* ===== Fonts (Quiet Gallery) ===== */
@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=Fira+Sans:ital,wght@0,400;0,500;0,600;1,400&display=swap');

/* ===== Tokens (Paper & Ink) ===== */
:root {
  --bg: #f5f3ee;            /* paper */
  --bg-alt: #e8e4dd;        /* warm stone */
  --ink: #0d0d0d;           /* deep ink — headings, brand */
  --text: #2d2d2d;          /* body ink */
  --muted: rgba(45, 45, 45, .55);
  --border: rgba(45, 45, 45, .18);   /* hairline */
  --rule: rgba(45, 45, 45, .10);     /* faint rule */
  --accent: #0d0d0d;        /* links/buttons are ink — no chroma */
  --accent-dark: #2d2d2d;
  --dot-live: #3a6b3a;
  --dot-soon: #8a6a2a;
  --dot-dev: rgba(45, 45, 45, .30);
  /* dark-band (Work) dots */
  --dot-live-dk: #9bd49b;
  --dot-soon-dk: #e6c479;
  --dot-dev-dk: rgba(245, 243, 238, .35);
  --paper-dim: rgba(245, 243, 238, .75);
  --paper-faint: rgba(245, 243, 238, .55);
  --maxw: 1120px;
  --radius: 0;
  --shadow: none;
  --serif: "DM Serif Display", "Iowan Old Style", Georgia, serif;
  --font: "Fira Sans", -apple-system, system-ui, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

/* ===== Reset ===== */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font);
  color: var(--text);
  background: var(--bg);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; display: block; }
a { color: var(--accent); text-decoration: none; transition: opacity .15s; }
a:hover { opacity: .6; }
h1, h2, h3 { font-family: var(--serif); color: var(--ink); line-height: 1.05; font-weight: 400; letter-spacing: -.01em; }
em { font-style: italic; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  * { transition: none !important; animation: none !important; }
}

/* ===== Layout helpers ===== */
.container { max-width: var(--maxw); margin: 0 auto; padding: 0 32px; }
.section-alt { background: var(--bg-alt); }

.eyebrow {
  display: inline-block; font-family: var(--font);
  text-transform: uppercase; letter-spacing: .28em; font-size: 10px;
  font-weight: 600; color: var(--muted);
}

/* ===== Buttons / link affordances ===== */
.btn-solid {
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--ink); color: var(--bg);
  font-family: var(--font); font-size: 14px; font-weight: 500; letter-spacing: .04em;
  padding: 16px 28px; border: 0; cursor: pointer;
}
.btn-solid:hover { opacity: .82; }
.link-underline {
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--ink); font-family: var(--font); font-size: 14px; font-weight: 500; letter-spacing: .04em;
  border-bottom: 1px solid var(--text); padding-bottom: 3px;
}

/* ===== Header (home + subpages) ===== */
.site-header, .subnav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(245, 243, 238, .85);
  backdrop-filter: saturate(120%) blur(10px);
  -webkit-backdrop-filter: saturate(120%) blur(10px);
}
.nav-bar, .subnav .container {
  display: flex; align-items: center; justify-content: space-between;
  height: 72px; border-bottom: 1px solid var(--rule);
}
.subnav .container { height: 72px; }
.brand {
  font-family: var(--serif); font-size: 20px; color: var(--ink); letter-spacing: -.01em;
}
.brand:hover { opacity: 1; }
.brand span { font-style: italic; margin-left: 5px; color: var(--ink); }
.nav-menu { display: flex; align-items: center; gap: 40px; }
.nav-menu a {
  color: var(--muted); font-family: var(--font);
  text-transform: uppercase; letter-spacing: .24em; font-size: 10px; font-weight: 500;
}
.nav-menu a:hover { opacity: 1; color: var(--ink); }
.nav-menu .nav-cta {
  color: var(--ink); border-bottom: 1px solid var(--ink); padding-bottom: 2px;
}
.nav-toggle { display: none; }
.subnav .back {
  font-family: var(--font); text-transform: uppercase; letter-spacing: .22em;
  font-size: 10px; font-weight: 500; color: var(--muted);
}
.subnav .back:hover { color: var(--ink); }

@media (max-width: 760px) {
  .nav-toggle {
    display: flex; flex-direction: column; gap: 5px; justify-content: center;
    width: 44px; height: 44px; background: none; border: 0; cursor: pointer;
  }
  .nav-toggle span { display: block; height: 1px; width: 24px; background: var(--ink); }
  .nav-menu {
    position: absolute; top: 72px; left: 0; right: 0;
    flex-direction: column; align-items: stretch; gap: 0;
    background: var(--bg); border-bottom: 1px solid var(--border);
    padding: 8px 32px 20px; display: none;
  }
  .nav-menu.open { display: flex; }
  .nav-menu a { padding: 14px 0; border-bottom: 1px solid var(--rule); }
  .nav-menu .nav-cta { margin-top: 14px; border-bottom: 0; }
}

/* ===== Status (dot + label) ===== */
.status { display: inline-flex; align-items: center; gap: 10px; }
.status .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--dot-dev); flex: none; }
.status .label {
  font-family: var(--font); text-transform: uppercase; letter-spacing: .22em;
  font-size: 10px; color: var(--muted);
}
.is-live .dot { background: var(--dot-live); }
.is-soon .dot { background: var(--dot-soon); }
.is-dev .dot  { background: var(--dot-dev); }

/* Inline badge (used on app subpages) — quiet dot + label */
.badge {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font); text-transform: uppercase; letter-spacing: .22em;
  font-size: 10px; font-weight: 500; color: var(--muted);
}
.badge::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--dot-dev); flex: none; }
.badge-live::before { background: var(--dot-live); }
.badge-soon::before { background: var(--dot-soon); }
.badge-dev::before  { background: var(--dot-dev); }

/* ===== Section scaffolding (home) ===== */
.qg-section { padding: 128px 0; }
.qg-section--rule { border-top: 1px solid var(--hair, var(--border)); }
.qg-head { max-width: 48rem; }
.qg-head .display { margin-top: 24px; }
.qg-head .qg-lead { margin-top: 28px; max-width: 38rem; }
.qg-head--center { max-width: 760px; margin: 0 auto; text-align: center; }
.display { font-family: var(--serif); color: var(--ink); letter-spacing: -.01em; line-height: 1.05; }
.qg-lead { font-family: var(--font); color: var(--text); font-size: 18px; line-height: 1.7; }

/* ===== Hero ===== */
.qg-hero { padding: 128px 0 176px; }
.qg-hero .display { margin-top: 40px; max-width: 64rem; font-size: clamp(44px, 8vw, 88px); line-height: 1.02; }
.qg-hero .display em { color: var(--text); }
.qg-hero-sub { margin-top: 40px; max-width: 36rem; font-size: 19px; color: var(--text); line-height: 1.7; }
.qg-actions { margin-top: 48px; display: flex; flex-wrap: wrap; align-items: center; gap: 22px; }
.qg-actions--center { justify-content: center; }

.qg-studio { margin-top: 128px; padding-top: 40px; border-top: 1px solid var(--border); display: grid; gap: 80px; grid-template-columns: minmax(0,14rem) 1fr; }
.qg-studio-note { margin-top: 12px; max-width: 14rem; font-size: 14px; color: var(--muted); }
.qg-studio-list { list-style: none; padding: 0; display: grid; gap: 32px; grid-template-columns: repeat(3, 1fr); }
.qg-studio-list li { display: flex; flex-direction: column; gap: 12px; }
.qg-app-name { font-family: var(--serif); font-size: 24px; color: var(--ink); }
.qg-app-desc { font-size: 14px; color: var(--muted); line-height: 1.55; }

@media (max-width: 860px) {
  .qg-studio { grid-template-columns: 1fr; gap: 40px; }
  .qg-studio-list { grid-template-columns: 1fr; }
}

/* ===== Services ===== */
.qg-services { margin-top: 96px; display: grid; gap: 80px; grid-template-columns: repeat(3, 1fr); }
.qg-service { display: flex; flex-direction: column; gap: 24px; }
.qg-service .numeral { font-family: var(--serif); font-style: italic; font-size: 24px; color: var(--muted); }
.qg-service h3 { font-size: 24px; line-height: 1.25; }
.qg-service p { font-size: 15px; color: var(--text); line-height: 1.75; }

@media (max-width: 860px) { .qg-services { grid-template-columns: 1fr; gap: 56px; } }

/* ===== Leadership ===== */
.qg-grid2 { margin-top: 96px; display: grid; grid-template-columns: 1fr 1fr; column-gap: 80px; row-gap: 56px; border-top: 1px solid var(--border); }
.qg-grid2 .qg-item { padding-top: 40px; }
.qg-grid2 .qg-item:nth-child(n+3) { border-top: 1px solid var(--border); }
.qg-item h3 { font-size: 22px; line-height: 1.25; }
.qg-item p { margin-top: 20px; font-size: 15px; color: var(--text); line-height: 1.75; }

@media (max-width: 860px) {
  .qg-grid2 { grid-template-columns: 1fr; row-gap: 0; }
  .qg-grid2 .qg-item { border-top: 1px solid var(--border); }
  .qg-grid2 .qg-item:first-child { border-top: 0; }
}

/* ===== Work — the dark gallery wall ===== */
.qg-work { padding: 128px 0; background: var(--ink); color: var(--bg); }
.qg-work .qg-head { max-width: 48rem; }
.qg-work .display { color: var(--bg); margin-top: 24px; font-size: clamp(40px, 6vw, 56px); }
.qg-work .eyebrow { color: var(--paper-faint); }
.qg-work .qg-lead { color: var(--paper-dim); margin-top: 28px; max-width: 38rem; }
.qg-work-list { list-style: none; padding: 0; margin-top: 96px; }
.qg-work-row {
  display: grid; grid-template-columns: 1fr 4fr 5fr 2fr; gap: 40px; align-items: baseline;
  padding: 40px 0; border-top: 1px solid rgba(245, 243, 238, .14); color: var(--bg);
}
.qg-work-list li:last-child .qg-work-row { border-bottom: 1px solid rgba(245, 243, 238, .14); }
.qg-work-num { font-family: var(--serif); font-style: italic; font-size: 14px; color: rgba(245, 243, 238, .45); }
.qg-work-name { font-family: var(--serif); color: var(--bg); font-size: clamp(40px, 6vw, 56px); line-height: 1.05; letter-spacing: -.01em; transition: font-style .15s; }
a.qg-work-row:hover { opacity: 1; }
a.qg-work-row:hover .qg-work-name { font-style: italic; }
.qg-work-desc { font-size: 15px; color: var(--paper-dim); line-height: 1.75; }
.qg-work-meta { text-align: right; }
.qg-work-meta .status .label { color: rgba(245, 243, 238, .65); }
.qg-work-meta .status .dot { background: var(--dot-dev-dk); }
.qg-work-meta .is-live .dot { background: var(--dot-live-dk); }
.qg-work-meta .is-soon .dot { background: var(--dot-soon-dk); }
.qg-work-more {
  display: inline-block; margin-top: 12px; font-family: var(--font);
  text-transform: uppercase; letter-spacing: .22em; font-size: 10px; color: rgba(245, 243, 238, .6);
  border-bottom: 1px solid rgba(245, 243, 238, .4); padding-bottom: 2px;
}

@media (max-width: 860px) {
  .qg-work-row { grid-template-columns: 1fr; gap: 14px; }
  .qg-work-meta { text-align: left; }
}

/* ===== About — centered museum portrait ===== */
.qg-about { text-align: center; }
.qg-about .qg-head--center .display { margin-top: 24px; font-size: clamp(40px, 6vw, 56px); }
.qg-portrait { margin: 80px auto 0; max-width: 420px; display: flex; flex-direction: column; align-items: center; }
.qg-portrait-img { width: 100%; aspect-ratio: 1; object-fit: cover; filter: grayscale(1) contrast(1.05); }
.qg-portrait figcaption {
  margin-top: 20px; font-family: var(--font); font-style: italic;
  text-transform: uppercase; letter-spacing: .22em; font-size: 11px; color: var(--muted);
}
.qg-bio { max-width: 640px; margin: 80px auto 0; text-align: left; }
.qg-bio p { font-size: 17px; line-height: 1.85; color: var(--text); }
.qg-bio p + p { margin-top: 28px; }
.qg-about .qg-actions { margin-top: 56px; }

/* ===== Track record ===== */
.qg-stats { margin-top: 80px; display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--border); }
.qg-stat { padding: 40px 24px 40px 0; border-bottom: 1px solid var(--border); border-right: 1px solid var(--border); }
.qg-stat:nth-child(n+2) { padding-left: 24px; }
.qg-stat:last-child { border-right: 0; }
.qg-stat dt { font-family: var(--font); text-transform: uppercase; letter-spacing: .28em; font-size: 10px; font-weight: 600; color: var(--muted); }
.qg-stat dd { margin-top: 16px; font-family: var(--serif); font-size: 22px; line-height: 1.25; color: var(--ink); }
.qg-brands { margin-top: 80px; }
.qg-brand-list { list-style: none; padding: 0; margin-top: 32px; display: flex; flex-wrap: wrap; align-items: baseline; gap: 12px 40px; }
.qg-brand-list li { font-family: var(--serif); font-size: clamp(22px, 3vw, 26px); color: var(--ink); }
.qg-disclaimer { margin-top: 40px; max-width: 42rem; font-size: 14px; font-style: italic; color: var(--muted); line-height: 1.6; }

@media (max-width: 860px) {
  .qg-stats { grid-template-columns: 1fr 1fr; }
  .qg-stat:nth-child(2n) { border-right: 0; }
}
@media (max-width: 480px) {
  .qg-stats { grid-template-columns: 1fr; }
  .qg-stat { border-right: 0; padding-left: 0; }
  .qg-stat:nth-child(n+2) { padding-left: 0; }
}

/* ===== Contact ===== */
.qg-contact { text-align: center; padding: 176px 0; }
.qg-contact .display { margin: 24px auto 0; max-width: 48rem; font-size: clamp(44px, 7vw, 64px); }
.qg-contact .qg-lead { margin: 28px auto 0; max-width: 34rem; }
.qg-contact-actions { margin-top: 48px; display: flex; flex-direction: column; align-items: center; gap: 24px; }
.qg-email { font-family: var(--serif); font-size: clamp(28px, 5vw, 36px); color: var(--ink); border-bottom: 1px solid var(--text); padding-bottom: 6px; }

/* ===== Footer ===== */
.site-footer { border-top: 1px solid var(--border); }
.footer-row { display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; padding: 48px 0; }
.footer-meta, .footer-links a {
  font-family: var(--font); text-transform: uppercase; letter-spacing: .24em; font-size: 11px;
}
.footer-meta { color: var(--muted); }
.footer-links a { color: var(--ink); margin-left: 32px; }
.footer-links a:first-child { margin-left: 0; }

/* ===== Subpages: app landing ===== */
.app-hero { padding: 112px 0 8px; }
.app-icon {
  width: 84px; height: 84px; border-radius: 19px; margin-bottom: 28px;
  background: var(--bg-alt); display: flex; align-items: center; justify-content: center;
  color: var(--ink); font-family: var(--serif); font-size: 30px; border: 1px solid var(--border);
}
.app-logo {
  width: 84px; height: 84px; border-radius: 19px; margin-bottom: 28px;
  display: block; border: 1px solid var(--border);
}
.app-hero h1 { font-size: clamp(40px, 7vw, 60px); margin-bottom: 16px; }
.app-hero .tagline { font-size: 20px; color: var(--text); max-width: 50ch; margin-bottom: 24px; }
.app-meta { display: flex; gap: 16px; align-items: center; flex-wrap: wrap; margin-bottom: 18px; }
.store-badge {
  display: inline-block; background: var(--ink); color: var(--bg); font-family: var(--font);
  font-weight: 500; font-size: 14px; letter-spacing: .04em; padding: 14px 24px;
}
.store-badge:hover { opacity: .82; }
.store-link { display: inline-block; }
.store-link img { display: block; height: 52px; width: auto; }
.store-link:hover { opacity: .85; }
.app-section { padding: 56px 0; }
.app-section h2 { font-family: var(--serif); font-size: 28px; margin-bottom: 28px; }
.feature-grid { list-style: none; padding: 0; display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px 40px; }
.feature-grid h3 { font-family: var(--serif); font-size: 19px; margin-bottom: 6px; }
.feature-grid p { font-size: 15px; color: var(--text); line-height: 1.75; }
.app-req { font-size: 14px; color: var(--muted); }
.app-hero .lead { font-size: 17px; color: var(--text); line-height: 1.8; margin-top: 4px; }

/* ===== Subpages: legal / long-form ===== */
.legal { max-width: 720px; padding: 96px 0 32px; }
.legal h1 { font-size: clamp(36px, 6vw, 48px); margin-bottom: 8px; }
.legal .updated { font-family: var(--font); text-transform: uppercase; letter-spacing: .2em; color: var(--muted); font-size: 11px; margin-bottom: 36px; }
.legal h2 { font-family: var(--serif); font-size: 26px; margin: 44px 0 14px; }
.legal h3 { font-family: var(--serif); font-size: 19px; margin: 24px 0 8px; }
.legal p { margin-bottom: 16px; max-width: 72ch; line-height: 1.8; }
.legal ul { margin: 0 0 18px 22px; }
.legal li { margin-bottom: 8px; line-height: 1.75; }
.legal a { border-bottom: 1px solid var(--text); }
.legal .callout { background: var(--bg-alt); border: 1px solid var(--border); padding: 22px 24px; margin: 0 0 30px; }
.legal .callout p { margin: 0; }
.legal .q { font-family: var(--serif); color: var(--ink); margin: 30px 0 6px; font-size: 19px; }

/* ===== Subpage footer ===== */
.sub-footer { border-top: 1px solid var(--border); padding: 40px 0; margin-top: 72px; }
.sub-footer .container { display: flex; justify-content: space-between; align-items: center; gap: 16px; flex-wrap: wrap; }
.sub-footer .links a { font-family: var(--font); text-transform: uppercase; letter-spacing: .22em; font-size: 11px; color: var(--ink); margin-right: 28px; }
.sub-footer .meta { font-family: var(--font); text-transform: uppercase; letter-spacing: .2em; font-size: 10px; color: var(--muted); }

@media (max-width: 760px) {
  .feature-grid { grid-template-columns: 1fr; }
  .qg-hero { padding: 80px 0 96px; }
  .qg-section { padding: 88px 0; }
  .qg-work { padding: 88px 0; }
  .qg-contact { padding: 112px 0; }
}
