/* ===============================================================
   James Wagner — storefront
   ---------------------------------------------------------------
   A typographic system tuned for a fine-art publisher: a modular
   type scale, a golden-ratio-informed spacing scale, restrained
   colour, and generous, deliberate white space. The artwork is
   the only real colour on the page; everything else recedes.
   ===============================================================*/

:root {
  /* --- Palette: warm neutral, gallery-paper ------------------ */
  --paper:     #f6f4f0;   /* page */
  --paper-2:   #efece6;   /* recessed panels */
  --ink:       #15130f;   /* headings */
  --ink-body:  #2c2925;   /* running text */
  --ink-soft:  #6a655d;   /* secondary / labels */
  --line:      #e0dcd3;   /* hairlines */

  /* --- Type families ---------------------------------------- */
  --serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  /* --- Modular type scale (1.25 major third, base 17px) ------
     Display sizes jump by ~φ from the body for editorial drama. */
  --fs-label: 0.72rem;    /* nav, eyebrows, labels */
  --fs-meta:  0.82rem;    /* captions, prices */
  --fs-body:  1.0625rem;  /* 17px running text */
  --fs-md:    clamp(1.2rem, 1.6vw, 1.45rem);   /* lede */
  --fs-lg:    clamp(1.6rem, 3vw, 2.1rem);      /* h2 */
  --fs-xl:    clamp(2.1rem, 4.4vw, 3.1rem);    /* about h1 */
  --fs-2xl:   clamp(2.8rem, 7vw, 4.6rem);      /* hero name */

  /* --- Spacing scale (golden ratio: each step ≈ ×1.618) ------ */
  --sp-1: 0.5rem;
  --sp-2: 0.8rem;
  --sp-3: 1.3rem;
  --sp-4: 2.1rem;
  --sp-5: 3.4rem;
  --sp-6: 5.5rem;
  --sp-7: 8.9rem;

  /* --- Measure & rails -------------------------------------- */
  --measure: 42rem;       /* container; yields ~64-char text column after gutter */
  --max: 1280px;          /* gallery rail */
  --gutter: clamp(22px, 5vw, 72px);
}

* { box-sizing: border-box; }

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

body {
  margin: 0;
  background: var(--paper);
  color: var(--ink-body);
  font-family: var(--sans);
  font-size: var(--fs-body);
  line-height: 1.5;
  font-feature-settings: "kern" 1, "liga" 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

img { display: block; max-width: 100%; }

a { color: inherit; }

::selection { background: #d9d3c6; }

h1, h2, h3 {
  color: var(--ink);
  font-family: var(--serif);
  font-weight: 500;
  text-wrap: balance;          /* avoid orphans in display lines */
}

/* ---------------------------------------------------------------
   Header — sigil crest, centred, with breathing room
----------------------------------------------------------------*/
.site-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(var(--sp-3), 3vw, var(--sp-4));
  padding: clamp(var(--sp-4), 5vw, var(--sp-6)) var(--gutter) clamp(var(--sp-3), 3vw, var(--sp-4));
}

.sigil img {
  height: clamp(56px, 8.25vw, 84px);
  width: auto;
}

.nav {
  display: flex;
  gap: clamp(var(--sp-3), 4vw, var(--sp-5));
  font-size: var(--fs-label);
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.nav a {
  text-decoration: none;
  color: var(--ink-soft);
  padding-bottom: 4px;
  border-bottom: 1px solid transparent;
  transition: color 0.3s ease, border-color 0.3s ease;
}

.nav a:hover { color: var(--ink); }

.nav a.active {
  color: var(--ink);
  border-color: var(--ink);
}

/* ---------------------------------------------------------------
   Intro / hero
----------------------------------------------------------------*/
.intro {
  max-width: 44rem;
  margin: clamp(var(--sp-5), 7vw, var(--sp-7)) auto clamp(var(--sp-5), 6vw, var(--sp-6));
  padding: 0 var(--gutter);
  text-align: center;
}

.intro h1 {
  font-size: var(--fs-2xl);
  line-height: 1.0;
  letter-spacing: -0.018em;
  margin: 0 0 0.42em;
}

.lede {
  font-family: var(--serif);
  font-size: var(--fs-md);
  font-style: italic;
  font-weight: 400;
  line-height: 1.42;
  color: var(--ink-soft);
  text-wrap: balance;
  margin: 0 auto;
  max-width: 30rem;
}

/* ---------------------------------------------------------------
   Works grid — let the images carry the colour
----------------------------------------------------------------*/
.works {
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(var(--sp-5), 5vw, var(--sp-6)) clamp(var(--sp-4), 3.5vw, var(--sp-5));
}

.card {
  display: block;
  text-decoration: none;
  color: inherit;
}

.card-frame {
  overflow: hidden;
  background: var(--paper-2);
}

.card-frame img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  transition: transform 1.1s cubic-bezier(0.16, 1, 0.3, 1);
}

.card:hover .card-frame img { transform: scale(1.035); }

.card-meta {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--sp-3);
  margin-top: var(--sp-3);
  padding-top: var(--sp-2);
  border-top: 1px solid var(--line);
}

.card-title {
  font-size: 1.45rem;
  line-height: 1.12;
  letter-spacing: -0.005em;
  margin: 0;
}

.card-medium {
  font-size: var(--fs-meta);
  color: var(--ink-soft);
  letter-spacing: 0.01em;
  margin: 0.35em 0 0;
}

.card-price {
  font-size: var(--fs-meta);
  letter-spacing: 0.03em;
  white-space: nowrap;
  font-feature-settings: "tnum" 1, "lnum" 1;   /* tabular, lining figures */
}

.card-price .sold {
  font-size: var(--fs-label);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-soft);
}

/* ---------------------------------------------------------------
   Inquiry / contact — a quiet closing gesture
----------------------------------------------------------------*/
.inquiry {
  max-width: 40rem;
  margin: clamp(var(--sp-6), 12vw, var(--sp-7)) auto clamp(var(--sp-5), 8vw, var(--sp-6));
  padding: 0 var(--gutter);
  text-align: center;
}

.inquiry h2 {
  font-size: var(--fs-lg);
  letter-spacing: -0.01em;
  margin: 0 0 0.5em;
}

.inquiry p {
  color: var(--ink-soft);
  margin: 0 auto var(--sp-3);
  max-width: 32rem;
}

.inquiry-link {
  font-family: var(--serif);
  font-size: clamp(1.3rem, 3vw, 1.7rem);
  font-style: italic;
  text-decoration: none;
  border-bottom: 1px solid var(--line);
  padding-bottom: 3px;
  transition: border-color 0.3s ease;
}

.inquiry-link:hover { border-color: var(--ink); }

/* ---------------------------------------------------------------
   About
----------------------------------------------------------------*/
.about-hero {
  max-width: 44rem;
  margin: clamp(var(--sp-4), 6vw, var(--sp-6)) auto clamp(var(--sp-4), 5vw, var(--sp-5));
  padding: 0 var(--gutter);
  text-align: center;
}

.about-hero h1 {
  font-size: var(--fs-xl);
  line-height: 1.04;
  letter-spacing: -0.015em;
  margin: 0 0 0.42em;
}

.about-figure {
  max-width: var(--measure);
  margin: 0 auto clamp(var(--sp-5), 7vw, var(--sp-6));
  padding: 0 var(--gutter);
}

.about-figure img {
  width: 100%;
  height: auto;
}

.about-body {
  max-width: var(--measure);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.about-body p {
  font-size: var(--fs-body);
  line-height: 1.75;
  color: var(--ink-body);
  margin: 0 0 1.4em;
  text-wrap: pretty;          /* tidy ragged edge, no runt lines */
}

.about-body h2 {
  font-size: var(--fs-lg);
  line-height: 1.1;
  letter-spacing: -0.01em;
  margin: var(--sp-6) 0 var(--sp-3);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--line);
}

/* ---------------------------------------------------------------
   Footer
----------------------------------------------------------------*/
.site-footer {
  border-top: 1px solid var(--line);
  margin-top: clamp(var(--sp-5), 8vw, var(--sp-7));
}

.footer-inner {
  max-width: var(--max);
  margin: 0 auto;
  padding: var(--sp-4) var(--gutter);
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  justify-content: space-between;
  align-items: center;
  font-size: var(--fs-meta);
  color: var(--ink-soft);
}

.footer-nav {
  display: flex;
  gap: var(--sp-4);
}

.footer-nav a {
  text-decoration: none;
  letter-spacing: 0.06em;
  transition: color 0.3s ease;
}

.footer-nav a:hover { color: var(--ink); }

/* ---------------------------------------------------------------
   Responsive
----------------------------------------------------------------*/
@media (max-width: 680px) {
  .grid { grid-template-columns: 1fr; gap: var(--sp-5); }
  .footer-inner { flex-direction: column; text-align: center; gap: var(--sp-3); }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .card-frame img { transition: none; }
}
