/* ─────────────────────────────────────────────────────────────────────────────
   At Origin — faithful to atorigin.ca, refined
   ----------------------------------------------------------------------------
   This stylesheet rebuilds the existing WordPress site as a clean static site:
   white background, dark hero images with centered uppercase white headlines,
   single-column centered body text, outlined buttons, a pale-grey "Cafe Hours"
   strip, and a dark footer. Spec fonts (Roboto + Roboto Condensed); spec
   colours (#FFFFFF, #03050F, #5A544D) hold.

   Refinements over the first pass:
     · larger, more confident headline scale
     · gradient hero overlay (top + bottom dark, middle clear) instead of flat
     · billing-style hero kicker with hairline brackets
     · "open today" status pill in the header (live via site.js)
     · outlined poster frames for exhibition + news cards
     · hairline rules above the hours strip and the footer
     · refined button hover (subtle ink fill-in from the left)
     · staggered fade-up motion on hero copy
   ──────────────────────────────────────────────────────────────────────── */

@font-face {
  font-family: 'Roboto';
  src: url('fonts/roboto-flex-latin.woff2') format('woff2-variations'),
       url('fonts/roboto-flex-latin.woff2') format('woff2');
  font-weight: 100 1000;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Roboto Condensed';
  src: url('fonts/roboto-condensed-latin.woff2') format('woff2-variations'),
       url('fonts/roboto-condensed-latin.woff2') format('woff2');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

/* ── tokens ───────────────────────────────────────────────────────────── */
:root {
  --paper:     #FFFFFF;          /* spec background */
  --paper-2:   #F4F3F0;          /* a touch warmer for the hours strip */
  --paper-3:   #FAF9F6;          /* card-inset surface */
  --ink:       #1A1B20;          /* body text, slightly softer than pure */
  --ink-deep:  #03050F;          /* spec primary — headings */
  --muted:     #5A544D;          /* spec muted */
  --rule:      #D9D8D3;          /* hairline divider */
  --rule-soft: #E8E7E2;          /* even quieter divider */
  --dark:      #0E0E13;          /* footer + hero overlay base */
  --accent:    #C2A24B;          /* award-gold, used very sparingly */
  --hot:       #C5402B;          /* burnt-orange accent — used on the map caption */
  --open:      #2EA85A;          /* status pill dot when the cafe is open */

  --body:    'Roboto', 'Helvetica Neue', Arial, sans-serif;
  --display: 'Roboto Condensed', 'Roboto', 'Helvetica Neue', Arial, sans-serif;

  --gutter:    clamp(20px, 4vw, 64px);
  --measure:   720px;            /* single-column body width */
  --shell-max: 1280px;
}

/* ── reset ────────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
img, svg, video { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
ul, ol { padding: 0; margin: 0; list-style: none; }
h1, h2, h3, h4, h5, p { margin: 0; }
button { font: inherit; cursor: pointer; background: none; border: 0; color: inherit; padding: 0; }

/* ── canvas ──────────────────────────────────────────────────────────── */
html { background: var(--paper); color: var(--ink); -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--body);
  font-size: 16px;
  font-weight: 400;
  line-height: 1.7;
  color: var(--ink);
  background: var(--paper);
  overflow-x: hidden;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
::selection { background: var(--ink-deep); color: var(--paper); }

.skip {
  position: absolute; top: -40px; left: 8px;
  background: var(--ink-deep); color: var(--paper);
  padding: 8px 12px; font: 12px var(--display); letter-spacing: 0.2em;
  text-transform: uppercase; z-index: 100;
}
.skip:focus { top: 8px; }

/* ── top announcement banner (above the header on every page) ──────── */
:root { --banner-h: 38px; }
.banner {
  background: #000;
  color: var(--paper);
  min-height: var(--banner-h);
  display: flex; align-items: center; justify-content: center;
  padding: 9px var(--gutter);
  position: relative;
  z-index: 50;
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.banner__inner {
  max-width: 1100px; margin: 0 auto;
  font-family: var(--display);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 11.5px;
  font-weight: 500;
  line-height: 1.45;
  text-align: center;
  color: rgba(255,255,255,0.95);
}
.banner__inner a {
  color: inherit;
  border-bottom: 1px solid rgba(255,255,255,0.4);
  padding-bottom: 1px;
  transition: color .2s ease, border-color .2s ease;
}
.banner__inner a:hover {
  color: var(--accent);
  border-color: var(--accent);
}
.banner__star {
  color: var(--accent);
  margin: 0 8px;
  font-size: 0.9em;
  vertical-align: 1px;
}
@media (max-width: 980px) {
  :root { --banner-h: 56px; }
  .banner__inner { letter-spacing: 0.1em; font-size: 11px; }
}
@media (max-width: 560px) {
  :root { --banner-h: 78px; }
  .banner__inner { letter-spacing: 0.06em; font-size: 10.5px; line-height: 1.5; }
}

/* ── header (sits on top of the dark hero, below the banner) ────────── */
.head {
  position: absolute;
  top: var(--banner-h);   /* shift down by the banner height */
  left: 0; right: 0;
  z-index: 10;
  padding: 24px var(--gutter) 16px;
}
.head__inner {
  display: flex; flex-direction: column;
  align-items: center; gap: 16px;
  max-width: var(--shell-max); margin: 0 auto;
  position: relative;
}
.head__brand {
  /* On dark hero pages the dark logo would disappear, so we sit it on a
     small white circular plate — reads as a stamped seal on the photo
     rather than a flat white silhouette. On the light header variant the
     plate goes away and the logo sits on the paper as-is. */
  display: inline-flex; align-items: center; justify-content: center;
  width: 84px; height: 84px;
  background: var(--paper);
  border-radius: 50%;
  box-shadow: 0 2px 16px rgba(0,0,0,0.18);
  transition: transform .6s cubic-bezier(.2,.7,.2,1), box-shadow .25s ease;
}
.head__brand:hover { transform: rotate(8deg); }
.head__brand img {
  width: 64px; height: 64px;
  /* leave the actual seal artwork visible (dark on white plate) */
}
.head--light .head__brand {
  background: transparent;
  border-radius: 0;
  box-shadow: none;
  width: auto; height: auto;
}
.head--light .head__brand img { width: 64px; height: 64px; }
.nav {
  display: flex; flex-wrap: wrap; justify-content: center; align-items: center;
  gap: 24px;
}
.nav a {
  font-family: var(--display);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  font-size: 15.5px;
  color: var(--paper);
  padding: 6px 0;
  position: relative;
  white-space: nowrap;
  opacity: 0.88;
  transition: opacity .2s ease, color .2s ease;
}
.nav a:hover { opacity: 1; color: var(--accent); }
.nav a::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 1px;
  background: currentColor;
  transform: scaleX(0); transform-origin: center;
  transition: transform .25s ease;
  opacity: 0.7;
}
.nav a:hover::after { transform: scaleX(1); }

/* live "open today" pill — sits in the top-right corner of the header,
   off to the side so it doesn't crowd the centered nav row. */
.open-pill {
  position: absolute;
  top: 28px;
  right: var(--gutter);
  display: inline-flex; align-items: center; gap: 9px;
  font-family: var(--display);
  text-transform: uppercase; letter-spacing: 0.2em;
  font-size: 10.5px; font-weight: 500;
  padding: 8px 14px;
  color: var(--paper);
  border: 1px solid rgba(255,255,255,0.55);
  background: rgba(0,0,0,0.28);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: 11;
  white-space: nowrap;
}
.open-pill::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%;
  background: var(--open);
  box-shadow: 0 0 0 0 currentColor;
  animation: pulse 2.2s ease-out infinite;
}
.open-pill.is-closed { color: rgba(255,255,255,0.7); }
.open-pill.is-closed::before { background: rgba(255,255,255,0.4); animation: none; box-shadow: none; }
@keyframes pulse {
  0%   { box-shadow: 0 0 0 0 rgba(46, 168, 90, 0.55); }
  70%  { box-shadow: 0 0 0 8px rgba(46, 168, 90, 0); }
  100% { box-shadow: 0 0 0 0 rgba(46, 168, 90, 0); }
}
.head--light .open-pill {
  color: var(--ink-deep);
  border-color: var(--rule);
  background: var(--paper);
}
.head--light .open-pill.is-closed { color: var(--muted); }

/* page header variant: pages without a dark hero use a light header */
.head--light .head__brand img { filter: none; }
.head--light .nav a { color: var(--ink-deep); opacity: 1; }
.head--light .nav a:hover { color: var(--muted); }
.head--light .nav a::after { background: currentColor; }
.head--light {
  padding-bottom: 24px;
  border-bottom: 1px solid var(--rule);
  position: relative;  /* needed so the .open-pill is contained */
  background: var(--paper);
}

/* burger button (mobile) */
.burger {
  display: none;
  position: absolute; top: 18px; right: var(--gutter);
  width: 46px; height: 46px;
  z-index: 12;
  /* a subtle circular plate so the burger is discoverable on a busy photo */
  background: rgba(0,0,0,0.32);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.45);
}
.head--light .burger {
  background: var(--paper);
  border-color: var(--ink-deep);  /* darker outline so the circle is visible on white */
  backdrop-filter: none; -webkit-backdrop-filter: none;
}
.burger span {
  position: absolute; left: 12px; right: 12px; height: 2px;
  background: var(--paper);
  transition: top .25s, transform .25s, opacity .25s, background .25s;
}
.burger span:nth-child(1) { top: 16px; }
.burger span:nth-child(2) { top: 22px; }
.burger span:nth-child(3) { top: 28px; }
.head--light .burger span { background: var(--ink-deep); }
body.is-open .burger { background: var(--paper); border-color: var(--rule); backdrop-filter: none; }
body.is-open .burger span:nth-child(1) { top: 22px; transform: rotate(45deg); background: var(--ink-deep); }
body.is-open .burger span:nth-child(2) { opacity: 0; }
body.is-open .burger span:nth-child(3) { top: 22px; transform: rotate(-45deg); background: var(--ink-deep); }

@media (max-width: 960px) {
  .nav { display: none; }
  .open-pill { display: none; }
  .burger { display: block; }
  .head { padding-top: 18px; padding-bottom: 12px; }
}

/* mobile drawer */
.drawer {
  position: fixed; inset: 0;
  background: var(--paper);
  z-index: 9;
  padding: 96px var(--gutter) 60px;
  transform: translateY(-100%);
  transition: transform .35s ease;
  overflow-y: auto;
}
body.is-open .drawer { transform: translateY(0); }
.drawer a {
  display: block;
  font-family: var(--display); text-transform: uppercase; letter-spacing: 0.22em;
  font-size: 14px; color: var(--ink-deep);
  padding: 14px 0;
  border-bottom: 1px solid var(--rule-soft);
}
.drawer a:hover { color: var(--muted); }
.drawer a.sub { font-size: 12px; color: var(--muted); padding-left: 18px; }

/* ── hero ────────────────────────────────────────────────────────────── */
.hero {
  position: relative;
  min-height: 560px;
  display: flex; align-items: center; justify-content: center;
  background: var(--dark);
  color: var(--paper);
  text-align: center;
  padding: 200px var(--gutter) 120px;
  overflow: hidden;
}
.hero__media { position: absolute; inset: 0; z-index: 0; }
.hero__media img { width: 100%; height: 100%; object-fit: cover; }
.hero__media::after {
  /* gradient overlay: top heavy for nav legibility, then a lift in the middle,
     and a darker base under the CTAs. */
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(180deg,
      rgba(8,6,4,0.62) 0%,
      rgba(8,6,4,0.34) 22%,
      rgba(8,6,4,0.18) 50%,
      rgba(8,6,4,0.42) 78%,
      rgba(8,6,4,0.72) 100%);
}
.hero__copy { position: relative; z-index: 1; max-width: 880px; }

.hero__sub {
  /* billing line: small caps with hairlines on either side */
  display: inline-flex; align-items: center; gap: 14px;
  font-family: var(--display);
  text-transform: uppercase; letter-spacing: 0.28em;
  font-size: 11.5px; font-weight: 500;
  color: rgba(255,255,255,0.88);
  margin-bottom: 26px;
  flex-wrap: wrap; justify-content: center;
  max-width: 92%;
}
.hero__sub::before, .hero__sub::after {
  content: ""; width: 32px; height: 1px;
  background: rgba(255,255,255,0.55);
}
@media (max-width: 560px) {
  /* hide the hairline brackets on small screens — otherwise the long
     "single-origin specialty coffee · toronto" string overflows. */
  .hero__sub { letter-spacing: 0.22em; font-size: 10.5px; gap: 0; }
  .hero__sub::before, .hero__sub::after { display: none; }
}
.hero h1 {
  font-family: var(--display);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.045em;
  font-size: clamp(38px, 5.4vw, 72px);
  line-height: 1;
  color: var(--paper);
  text-shadow: 0 1px 30px rgba(0,0,0,0.2);
}
.hero h1 em { font-style: normal; }
.hero__cta {
  margin-top: 40px;
  display: flex; gap: 14px; justify-content: center; flex-wrap: wrap;
  max-width: 92%; margin-inline: auto;
}
@media (max-width: 560px) {
  /* stack CTAs full-width on phone so they don't run off the edge */
  .hero__cta { gap: 12px; }
  .hero__cta .btn { width: 100%; justify-content: center; max-width: 320px; }
}
.hero__scroll {
  position: absolute; left: 50%; bottom: 28px;
  transform: translateX(-50%);
  z-index: 1;
  font-family: var(--display); font-size: 10.5px; letter-spacing: 0.32em;
  text-transform: uppercase; color: rgba(255,255,255,0.7);
  display: inline-flex; flex-direction: column; align-items: center; gap: 10px;
}
.hero__scroll::after {
  content: ""; width: 1px; height: 28px;
  background: linear-gradient(180deg, rgba(255,255,255,0.8), rgba(255,255,255,0));
  animation: drip 2.4s ease-in-out infinite;
}
@keyframes drip {
  0%, 100% { transform: scaleY(0.4); transform-origin: top; opacity: 0.4; }
  50%      { transform: scaleY(1);   transform-origin: top; opacity: 1; }
}
@media (max-width: 700px) {
  .hero { min-height: 480px; padding-block: 140px 100px; }
  .hero__scroll { display: none; }
}

/* simple page header for inner content pages (exhibitions / news) */
.pagehead {
  padding: clamp(48px, 6vw, 80px) var(--gutter) clamp(40px, 5vw, 60px);
  max-width: var(--shell-max); margin: 0 auto;
  border-bottom: 1px solid var(--rule-soft);
  text-align: left;
}
.pagehead__kicker {
  font-family: var(--display); text-transform: uppercase; letter-spacing: 0.32em;
  font-size: 11px; color: var(--muted); font-weight: 500;
  display: inline-flex; align-items: center; gap: 12px;
  margin-bottom: 18px;
}
.pagehead__kicker::before { content: ""; width: 28px; height: 1px; background: var(--muted); }
.pagehead__title {
  font-family: var(--display); font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.04em;
  font-size: clamp(32px, 4vw, 52px);
  line-height: 1.02;
  color: var(--ink-deep);
}
.pagehead__sub {
  margin-top: 14px;
  font-family: var(--body); font-size: 15.5px; color: var(--muted);
  max-width: 60ch;
}

/* ── outlined CTA button ─────────────────────────────────────────────── */
.btn {
  position: relative;
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--display);
  text-transform: uppercase; letter-spacing: 0.2em;
  font-size: 11.5px; font-weight: 500;
  padding: 13px 22px;
  border: 1px solid currentColor;
  color: var(--paper);
  background: transparent;
  overflow: hidden;
  isolation: isolate;
  transition: color .25s ease;
  z-index: 0;
}
.btn::after {
  /* fill-in hover effect (subtle ink sweep from the left) */
  content: ""; position: absolute; inset: 0;
  background: var(--paper);
  transform: translateX(-101%);
  transition: transform .35s cubic-bezier(.7,.05,.25,1);
  z-index: -1;
}
.btn:hover { color: var(--ink-deep); }
.btn:hover::after { transform: translateX(0); }
.btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.btn--ink { color: var(--ink-deep); border-color: var(--ink-deep); }
.btn--ink::after { background: var(--ink-deep); }
.btn--ink:hover { color: var(--paper); }
.btn--ink:hover::after { transform: translateX(0); }
.btn--solid { background: var(--ink-deep); color: var(--paper); border-color: var(--ink-deep); }
.btn--solid::after { background: var(--paper); }
.btn--solid:hover { color: var(--ink-deep); }

/* button icons via ::before so existing body files don't need a child element */
.btn--cart::before, .btn--gift::before, .btn--bag::before {
  content: ""; display: inline-block;
  width: 14px; height: 14px;
  background-color: currentColor;
  -webkit-mask-size: contain; mask-size: contain;
  -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat;
  -webkit-mask-position: center; mask-position: center;
  position: relative; z-index: 1;
}
.btn--cart::before { -webkit-mask-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='currentColor' d='M7 18c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zM1 2v2h2l3.6 7.6-1.4 2.5C5.5 14.4 6.5 15 7.5 15h12v-2h-12l1.1-2h7.4c.8 0 1.5-.4 1.8-1l3.6-6.6-1.7-.9-3.6 6.5H8.5L4.3 2H1zm16 16c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='currentColor' d='M7 18c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zM1 2v2h2l3.6 7.6-1.4 2.5C5.5 14.4 6.5 15 7.5 15h12v-2h-12l1.1-2h7.4c.8 0 1.5-.4 1.8-1l3.6-6.6-1.7-.9-3.6 6.5H8.5L4.3 2H1zm16 16c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z'/%3E%3C/svg%3E"); }
.btn--gift::before { -webkit-mask-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='currentColor' d='M20 6h-2.2a3 3 0 0 0-4.8-3.4 3 3 0 0 0-4.8 3.4H4a2 2 0 0 0-2 2v3h9V8h2v3h9V8a2 2 0 0 0-2-2zm-9-1a1 1 0 1 1 2 0v1h-2V5zM4 13v8a2 2 0 0 0 2 2h5v-10H4zm15 0v8a2 2 0 0 0 2 2H13V13z'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='currentColor' d='M20 6h-2.2a3 3 0 0 0-4.8-3.4 3 3 0 0 0-4.8 3.4H4a2 2 0 0 0-2 2v3h9V8h2v3h9V8a2 2 0 0 0-2-2zm-9-1a1 1 0 1 1 2 0v1h-2V5zM4 13v8a2 2 0 0 0 2 2h5v-10H4zm15 0v8a2 2 0 0 0 2 2H13V13z'/%3E%3C/svg%3E"); }
.btn--bag::before { -webkit-mask-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='currentColor' d='M18 6h-2a4 4 0 0 0-8 0H6a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8a2 2 0 0 0-2-2zm-6-2a2 2 0 0 1 2 2h-4a2 2 0 0 1 2-2z'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='currentColor' d='M18 6h-2a4 4 0 0 0-8 0H6a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8a2 2 0 0 0-2-2zm-6-2a2 2 0 0 1 2 2h-4a2 2 0 0 1 2-2z'/%3E%3C/svg%3E"); }

/* ── shared layout primitives ───────────────────────────────────────── */
.wrap { padding: 0 var(--gutter); }
.wrap--narrow { max-width: 1100px; margin: 0 auto; }
.wrap--prose  { max-width: var(--measure); margin: 0 auto; }
.wrap--shell  { max-width: var(--shell-max); margin: 0 auto; }

.section { padding-block: clamp(60px, 8vw, 110px); }
.section--quiet { padding-block: clamp(40px, 5vw, 64px); }

/* kicker / eyebrow */
.kicker {
  display: flex; align-items: center; justify-content: center; gap: 14px;
  font-family: var(--display);
  text-transform: uppercase; letter-spacing: 0.28em;
  font-size: 11.5px; font-weight: 500;
  color: var(--muted);
  margin-bottom: 18px;
}
.kicker::before, .kicker::after {
  content: ""; flex: 0 0 32px; height: 1px; background: var(--ink-deep); opacity: 0.45;
}

/* centered section heading */
.section__title {
  font-family: var(--display);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: clamp(24px, 3vw, 36px);
  line-height: 1.06;
  color: var(--ink-deep);
  text-align: center;
}
.section__title em { font-style: normal; }

.hr { height: 1px; background: var(--rule); border: 0; margin: 0; }

/* ── prose ───────────────────────────────────────────────────────────── */
.prose {
  font-family: var(--body);
  font-size: 16px;
  line-height: 1.85;
  color: var(--ink);
  text-align: center;
}
.prose p + p { margin-top: 1em; }
.prose a {
  color: var(--ink-deep);
  border-bottom: 1px solid var(--muted);
  transition: border-color .2s, color .2s;
}
.prose a:hover { border-color: var(--accent); color: var(--accent); }
.prose strong { color: var(--ink-deep); font-weight: 500; }
.prose em { font-style: italic; }
.prose--left { text-align: left; }

/* ── home: award block + pull quote ──────────────────────────────────── */
.award {
  display: flex; flex-direction: column; align-items: center; gap: 36px;
  padding: clamp(56px, 7vw, 96px) var(--gutter) clamp(24px, 3vw, 32px);
}
.award__plate {
  max-width: 400px; width: 100%;
  display: block;
  border: 1px solid var(--rule);
  padding: 16px;
  background: var(--paper);
  box-shadow: 0 1px 0 var(--rule);
}
.award__plate img { width: 100%; height: auto; display: block; }
.award__caption {
  font-family: var(--display); text-transform: uppercase; letter-spacing: 0.28em;
  font-size: 11px; color: var(--muted); text-align: center;
}

.pull {
  text-align: center;
  padding: clamp(48px, 6vw, 80px) var(--gutter) clamp(56px, 7vw, 96px);
}
.pull blockquote {
  position: relative;
  font-family: var(--body);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(20px, 2.6vw, 30px);
  line-height: 1.4;
  color: var(--ink-deep);
  max-width: 680px; margin: 0 auto;
  padding: 36px 12px;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  word-wrap: break-word;
}
.pull blockquote strong { font-style: normal; font-weight: 700; }
.pull blockquote::before {
  content: "“"; position: absolute; top: -4px; left: 50%;
  transform: translateX(-50%);
  font-family: Georgia, serif;
  font-size: 56px; line-height: 1; color: var(--accent);
  background: var(--paper); padding: 0 14px;
}

/* ── alternating image+text rows (our coffee) ───────────────────────── */
.origins {
  max-width: 980px; margin: 0 auto;
  padding: 0 var(--gutter);
  display: flex; flex-direction: column; gap: clamp(36px, 6vw, 72px);
}
.origin-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px, 5vw, 64px);
  align-items: center;
}
.origin-row:nth-child(even) > :first-child { order: 2; }
.origin-row img {
  width: 100%; height: auto;
  border: 1px solid var(--rule); padding: 10px;
  background: var(--paper-3);
}
.origin-row p {
  font-family: var(--body);
  font-size: 16px; line-height: 1.75; color: var(--ink); text-align: left;
}
.origin-row strong {
  display: block;
  font-family: var(--display); text-transform: uppercase; letter-spacing: 0.22em;
  font-size: 13px; color: var(--ink-deep); margin-bottom: 8px; font-weight: 500;
}
@media (max-width: 760px) {
  .origin-row { grid-template-columns: 1fr; }
  .origin-row:nth-child(even) > :first-child { order: 0; }
}

/* ── exhibitions: stacked card with framed poster ───────────────────── */
.shows {
  max-width: 820px; margin: 0 auto;
  padding: 0 var(--gutter);
  display: flex; flex-direction: column;
}
.show {
  padding: clamp(40px, 5vw, 72px) 0;
  border-top: 1px solid var(--rule);
  text-align: left;
}
.show:first-child { border-top: 0; padding-top: clamp(20px, 2.5vw, 32px); }
.show__date {
  font-family: var(--display); text-transform: uppercase; letter-spacing: 0.26em;
  font-size: 11px; color: var(--muted);
  margin-bottom: 8px;
  display: inline-flex; align-items: center; gap: 10px;
}
.show__date::before { content: ""; width: 20px; height: 1px; background: var(--muted); }
.show__head {
  font-family: var(--display); font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.04em;
  font-size: clamp(18px, 2vw, 24px);
  line-height: 1.18; color: var(--ink-deep);
  margin-bottom: 6px;
}
.show__meta {
  font-family: var(--body); font-size: 13.5px; color: var(--muted);
  margin-bottom: 26px;
}
.show__media {
  display: flex; justify-content: center;
  background: var(--paper-3);
  border: 1px solid var(--rule);
  padding: 22px;
  margin-bottom: 24px;
  transition: background .25s ease;
}
.show__media img {
  max-height: 540px; width: auto; max-width: 100%;
  display: block;
  box-shadow: 0 2px 14px rgba(0,0,0,0.08);
}
.show__media:hover { background: var(--paper-2); }
.show__more {
  font-family: var(--display);
  text-transform: uppercase; letter-spacing: 0.22em;
  font-size: 11.5px; color: var(--ink-deep);
  border-bottom: 1px solid var(--ink-deep);
  padding-bottom: 4px;
  display: inline-flex; align-items: center; gap: 8px;
  transition: color .2s, border-color .2s, gap .25s;
}
.show__more:hover { color: var(--accent); border-color: var(--accent); gap: 12px; }
.show__noimg {
  background: var(--paper-3);
  border: 1px solid var(--rule);
  padding: 80px 24px; text-align: center;
  font-family: var(--display); font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.06em;
  font-size: 22px; color: var(--ink-deep);
  margin-bottom: 24px;
}

/* upcoming shows are typographic only — no image card */
.show--text-only { padding-block: clamp(28px, 3vw, 40px); }

/* ── workshops cards ────────────────────────────────────────────────── */
.workshops {
  max-width: var(--shell-max); margin: 0 auto;
  padding: 0 var(--gutter);
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 4vw, 64px);
}
.workshop {
  display: flex; flex-direction: column; align-items: center; text-align: center;
}
.workshop__img {
  width: 100%; max-width: 400px;
  border: 1px solid var(--rule); padding: 12px; margin-bottom: 22px;
  background: var(--paper);
  box-shadow: 0 1px 0 var(--rule);
}
.workshop__img img { width: 100%; height: auto; display: block; }
.workshop__title {
  font-family: var(--display); font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.05em;
  font-size: clamp(18px, 1.8vw, 22px); color: var(--ink-deep);
  margin-bottom: 14px;
}
.workshop p {
  font-size: 15px; line-height: 1.7; color: var(--ink); max-width: 50ch;
  margin: 0 0 24px;
}
@media (max-width: 760px) { .workshops { grid-template-columns: 1fr; } }

/* ── bios (our story) ───────────────────────────────────────────────── */
.team {
  max-width: var(--shell-max); margin: 0 auto;
  padding: 0 var(--gutter);
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(36px, 5vw, 72px);
}
.bio { text-align: center; }
.bio__img {
  width: 100%; max-width: 400px; margin: 0 auto 24px;
  border: 1px solid var(--rule); padding: 12px;
  background: var(--paper);
}
.bio__img img { width: 100%; height: auto; display: block; }
.bio__role {
  font-family: var(--display); text-transform: uppercase; letter-spacing: 0.28em;
  font-size: 11px; color: var(--muted); margin-bottom: 8px;
}
.bio__name {
  font-family: var(--display); font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.05em;
  font-size: clamp(18px, 1.9vw, 22px);
  color: var(--ink-deep); margin-bottom: 14px;
}
.bio__name a { color: inherit; border-bottom: 1px solid var(--rule); }
.bio__name a:hover { color: var(--accent); border-color: var(--accent); }
.bio p { font-size: 15px; line-height: 1.75; color: var(--ink); max-width: 56ch; margin: 0 auto 0.9em; text-align: left; }
@media (max-width: 760px) { .team { grid-template-columns: 1fr; } }

/* ── contact ─────────────────────────────────────────────────────────── */
.contact {
  max-width: var(--shell-max); margin: 0 auto;
  padding: 0 var(--gutter);
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(36px, 5vw, 72px);
}
.contact__col h3 {
  font-family: var(--display); font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.06em;
  font-size: clamp(17px, 1.8vw, 20px); color: var(--ink-deep);
  margin-bottom: 24px; text-align: center;
}
.contact__row {
  display: flex; align-items: flex-start; gap: 16px;
  margin-bottom: 22px;
}
.contact__row svg { flex: 0 0 18px; margin-top: 5px; color: var(--muted); }
.contact__row .lbl {
  font-family: var(--display); text-transform: uppercase; letter-spacing: 0.22em;
  font-size: 11px; color: var(--ink-deep); margin-bottom: 4px; font-weight: 500;
}
.contact__row .val { font-size: 15px; color: var(--ink); line-height: 1.55; }
.contact__row .val a { color: var(--ink); border-bottom: 1px solid var(--rule); }
.contact__row .val a:hover { color: var(--accent); border-color: var(--accent); }
.contact__socials {
  display: flex; gap: 12px; justify-content: center; margin-top: 24px;
}
.contact__socials a {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--ink-deep);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--paper);
  transition: background .2s ease, transform .2s ease;
}
.contact__socials a:hover { background: var(--accent); transform: translateY(-2px); }
.map {
  width: 100%; aspect-ratio: 16/9; border: 1px solid var(--rule);
  background: var(--paper-3);
  margin: 0 0 28px;
  padding: 0;
  position: relative;
  overflow: hidden;
}
.map iframe {
  width: 100%; height: 100%;
  border: 0; display: block;
  /* slight muting filter so the green/yellow tile palette doesn't fight the cafe palette */
  filter: saturate(0.92) contrast(1.02);
}
.map__caption {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  background: linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0.95) 60%);
  padding: 22px 14px 10px;
  text-align: right;
  font-family: var(--display);
  text-transform: uppercase; letter-spacing: 0.2em;
  font-size: 10.5px; font-weight: 500;
  pointer-events: none;
}
.map__caption a {
  color: var(--ink-deep);
  border-bottom: 1px solid var(--ink-deep);
  padding-bottom: 2px;
  pointer-events: auto;
}
.map__caption a:hover { color: var(--hot); border-color: var(--hot); }

/* form */
.form { display: grid; gap: 18px; }
.form .row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form label {
  display: block;
  font-family: var(--display); text-transform: uppercase; letter-spacing: 0.22em;
  font-size: 11px; font-weight: 500; color: var(--ink-deep); margin-bottom: 8px;
}
.form input, .form textarea {
  width: 100%; padding: 12px 14px;
  background: var(--paper-3);
  border: 1px solid var(--rule);
  font: inherit; color: var(--ink); border-radius: 2px;
  transition: border-color .2s, background .2s;
}
.form input:focus, .form textarea:focus {
  outline: none; border-color: var(--ink-deep); background: var(--paper);
}
.form textarea { min-height: 140px; resize: vertical; }
.form button { width: auto; align-self: flex-start; }
@media (max-width: 700px) { .contact, .form .row2 { grid-template-columns: 1fr; } }

/* ── pale grey hours strip (every page) ─────────────────────────────── */
.hours {
  background: var(--paper-2);
  border-top: 1px solid var(--rule);
  padding: clamp(32px, 4vw, 56px) var(--gutter);
}
.hours__inner {
  max-width: var(--shell-max); margin: 0 auto;
  display: grid; grid-template-columns: auto 1fr 1fr;
  gap: clamp(24px, 4vw, 56px);
  align-items: center;
}
.hours__badges {
  display: flex; gap: 20px; align-items: center;
}
.hours__badges img {
  width: 72px; height: 72px;
  flex-shrink: 0;
  opacity: 0.92;
}
.hours__star {
  width: 72px; height: 72px;
  object-fit: contain;
  flex-shrink: 0;
}
.hours__title {
  font-family: var(--display); font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.28em;
  font-size: 13px; color: var(--ink-deep);
  margin-bottom: 8px; text-align: center;
  display: inline-flex; align-items: center; gap: 10px;
  width: 100%; justify-content: center;
}
.hours__title::before, .hours__title::after {
  content: ""; width: 22px; height: 1px; background: var(--muted);
}
.hours__body {
  font-family: var(--body); font-size: 14.5px; line-height: 1.55; color: var(--ink);
  text-align: center;
}
.hours__body strong { color: var(--ink-deep); font-weight: 500; }
.hours__addr {
  text-align: center;
  font-family: var(--body); font-size: 14.5px; line-height: 1.55; color: var(--ink);
}
.hours__addr a { color: var(--ink); border-bottom: 1px solid var(--rule); transition: color .2s, border-color .2s; }
.hours__addr a:hover { color: var(--accent); border-color: var(--accent); }

@media (max-width: 820px) {
  .hours__inner { grid-template-columns: 1fr; text-align: center; }
  .hours__badges { justify-content: center; }
}

/* ── dark footer ─────────────────────────────────────────────────────── */
/* Closing chord of the page. A confident sign-off, a hairline-and-star
   ornament, a four-column index (identity / the cafe / on the wall /
   elsewhere), and a quiet bottom row with copyright + social + an
   est-line in tracked gold. Roboto Condensed for all labels + sign-off
   so the type ties back to the rest of the site. */
.foot {
  background: var(--dark);
  color: var(--paper);
  padding: clamp(72px, 9vw, 120px) var(--gutter) clamp(28px, 3vw, 36px);
  border-top: 1px solid rgba(255,255,255,0.06);
  position: relative;
  overflow: hidden;
}
/* very subtle radial glow behind the sign-off — gives the footer
   atmosphere without introducing a new colour */
.foot::before {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(
    ellipse 60% 40% at 50% 18%,
    rgba(194, 162, 75, 0.06) 0%,
    rgba(194, 162, 75, 0) 60%);
  pointer-events: none;
}
.foot__inner {
  max-width: var(--shell-max); margin: 0 auto;
  position: relative;
}

/* ── the sign-off — the big closing line ── */
.foot__signoff {
  text-align: center;
  font-family: var(--display);
  text-transform: uppercase;
  font-weight: 300;
  font-size: clamp(28px, 4.6vw, 60px);
  line-height: 1.04;
  letter-spacing: 0.18em;
  color: var(--paper);
  margin: 0;
}
.foot__signoff .gold {
  color: var(--accent);
  font-weight: 500;
  margin-left: -0.02em;
}

/* ── hairline-and-star ornament under the sign-off ── */
.foot__orn {
  display: flex; align-items: center; justify-content: center;
  gap: 18px;
  margin: clamp(28px, 4vw, 44px) auto clamp(48px, 6vw, 72px);
  max-width: 320px;
  color: var(--accent);
}
.foot__orn::before, .foot__orn::after {
  content: ""; flex: 1; height: 1px;
  background: linear-gradient(90deg, rgba(194,162,75,0) 0%, rgba(194,162,75,0.45) 50%, rgba(194,162,75,0) 100%);
}
.foot__orn span { font-size: 14px; line-height: 1; }

/* ── four-column grid ── */
.foot__grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: clamp(32px, 4vw, 64px) clamp(28px, 3.6vw, 56px);
  padding-bottom: clamp(48px, 6vw, 72px);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.foot__col {
  min-width: 0; /* lets long links wrap inside narrow columns */
}
.foot__col h5 {
  font-family: var(--display);
  text-transform: uppercase;
  letter-spacing: 0.34em;
  font-size: 11px;
  font-weight: 500;
  color: var(--accent);
  margin: 0 0 22px;
  padding-bottom: 14px;
  position: relative;
}
.foot__col h5::after {
  content: ""; position: absolute; left: 0; bottom: 0;
  width: 22px; height: 1px;
  background: var(--accent);
}

/* ── identity column (the calling card) ── */
.foot__id {
  font-family: var(--body);
  font-size: 14px; line-height: 1.7;
  color: rgba(255,255,255,0.78);
}
.foot__id strong {
  color: var(--paper);
  font-weight: 500;
  display: block;
  margin-bottom: 8px;
  font-size: 15px;
  letter-spacing: 0.005em;
}
.foot__id .blurb { margin: 0 0 22px; max-width: 36ch; }
.foot__id .meta { display: grid; gap: 10px; }
.foot__id .meta-row {
  display: flex; align-items: center; gap: 12px;
  font-size: 14px;
  color: rgba(255,255,255,0.88);
  line-height: 1.4;
}
.foot__id .meta-row svg {
  width: 14px; height: 14px;
  flex-shrink: 0;
  color: var(--accent);
  opacity: 0.85;
}
.foot__id .meta-row a {
  color: inherit;
  border-bottom: 1px solid transparent;
  transition: color .2s ease, border-color .2s ease;
}
.foot__id .meta-row a:hover {
  color: var(--accent);
  border-color: rgba(194,162,75,0.5);
}

/* ── link columns (the cafe / on the wall / elsewhere) ── */
.foot__col ul {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: 11px;
}
.foot__col ul a {
  position: relative;
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--body);
  font-size: 14.5px;
  font-weight: 400;
  color: rgba(255,255,255,0.86);
  text-decoration: none;
  letter-spacing: 0.005em;
  line-height: 1.35;
  transition: color .2s ease;
}
.foot__col ul a::after {
  content: ""; position: absolute;
  left: 0; right: 0; bottom: -2px;
  height: 1px; background: var(--accent);
  transform: scaleX(0); transform-origin: left center;
  transition: transform .25s ease;
}
.foot__col ul a:hover {
  color: var(--accent);
}
.foot__col ul a:hover::after {
  transform: scaleX(1);
}
.foot__col ul a.sub {
  padding-left: 18px;
  font-size: 13.5px;
  color: rgba(255,255,255,0.6);
}
.foot__col ul a.sub::before {
  content: "";
  position: absolute; left: 0; top: 50%;
  width: 10px; height: 1px;
  background: rgba(255,255,255,0.35);
  transform: translateY(-0.5px);
}
.foot__col ul a.sub::after { left: 18px; }
.foot__col ul a.ext { padding-right: 14px; }
.foot__col ul a.ext::before {
  content: "↗";
  position: absolute; right: 0; top: 0;
  font-size: 11px;
  color: var(--accent);
  opacity: 0.6;
  transition: opacity .2s ease, transform .25s ease;
}
.foot__col ul a.ext:hover::before {
  opacity: 1;
  transform: translate(2px, -2px);
}

/* ── bottom row — copyright | social | est-line ── */
.foot__bottom {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 24px;
  padding-top: clamp(28px, 3vw, 40px);
}
.foot__bottom .copy {
  text-align: left;
  font-family: var(--display);
  text-transform: uppercase;
  letter-spacing: 0.22em;
  font-size: 10.5px;
  color: rgba(255,255,255,0.52);
}
.foot__bottom .social {
  display: flex; gap: 10px; justify-content: center;
}
.foot__bottom .social a {
  width: 34px; height: 34px;
  border: 1px solid rgba(255,255,255,0.22);
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,0.82);
  transition: background .25s ease, color .25s ease, border-color .25s ease, transform .25s ease;
}
.foot__bottom .social a:hover {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--ink-deep);
  transform: translateY(-2px);
}
.foot__bottom .tag {
  text-align: right;
  font-family: var(--display);
  text-transform: uppercase;
  letter-spacing: 0.3em;
  font-size: 10.5px;
  color: var(--accent);
  opacity: 0.85;
}
.foot__bottom .tag::before {
  content: "✦";
  margin-right: 10px;
  opacity: 0.75;
}

/* ── responsive ── */
@media (max-width: 980px) {
  .foot__grid { grid-template-columns: 1fr 1fr; gap: 44px 36px; }
  .foot__grid .foot__col:first-child { grid-column: 1 / -1; }
}
@media (max-width: 600px) {
  .foot__grid { grid-template-columns: 1fr; gap: 36px; }
  .foot__grid .foot__col:first-child { grid-column: auto; }
  .foot__bottom { grid-template-columns: 1fr; gap: 18px; }
  .foot__bottom .copy, .foot__bottom .tag { text-align: center; }
}

/* ── tiny helpers ────────────────────────────────────────────────────── */
.center { text-align: center; }
.muted { color: var(--muted); }
.row { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; justify-content: center; }

/* on-load fade-up — used on hero copy + section heads */
@keyframes fade-up {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: none; }
}
.fade { animation: fade-up .9s cubic-bezier(.2,.7,.2,1) both; }
.fade--1 { animation-delay: .06s; }
.fade--2 { animation-delay: .18s; }
.fade--3 { animation-delay: .32s; }
.fade--4 { animation-delay: .46s; }
@media (prefers-reduced-motion: reduce) { .fade { animation: none !important; opacity: 1; transform: none; } }

/* image hover lift for award + workshop frames */
.award__plate, .workshop__img, .bio__img {
  transition: transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease;
}
.award__plate:hover, .workshop__img:hover, .bio__img:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 18px rgba(0,0,0,0.08);
}
