/*
Theme Name: Mohry
Author: Dorsa
Description: A quiet white gallery theme built around the Works Row block. Rows of works aligned top and bottom, centered, with fullscreen hover previews and a note top-left.
Version: 1.1.0
Requires at least: 6.2
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: mohry
*/

/* ---------- Tokens ---------- */
:root {
  --paper: #ffffff;
  --ink: #1d1d1b;
  --ink-soft: #6f6f6a;
  --coral: #e2836f; /* from the horses; hover only */

  --font-ui: 'Karla', sans-serif;
  --font-name: 'Instrument Serif', serif;

  --gutter: clamp(1.2rem, 4vw, 3.5rem);
  --row-gap: clamp(2rem, 5vw, 4.5rem);
}

/* ---------- Base ---------- */
*, *::before, *::after { box-sizing: border-box; }

body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-ui);
  font-size: 0.95rem;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}

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

a { color: inherit; text-decoration: none; }

::selection { background: var(--coral); color: var(--paper); }

h1, h2, h3 { font-weight: 400; line-height: 1.2; margin: 0 0 0.6em; }

/* ---------- Header ---------- */
.site-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 1.6rem var(--gutter);
}

.site-logo {
  font-family: var(--font-name);
  font-size: 1.45rem;
  letter-spacing: 0.01em;
}

.site-nav ul {
  display: flex;
  gap: 2.2rem;
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: 0.8rem;
  text-transform: lowercase;
  letter-spacing: 0.14em;
}

.site-nav a { padding-bottom: 2px; border-bottom: 1px solid transparent; transition: color 0.25s ease, border-color 0.25s ease; }

.site-nav a:hover,
.site-nav a:focus-visible,
.site-nav .current-menu-item a { color: var(--coral); border-color: var(--coral); }

/* ---------- Works Row block ---------- */
.works-row {
  --row-h: 180px;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: clamp(0.9rem, 2vw, 1.8rem);
  padding-inline: var(--gutter);
  margin: 0 0 var(--row-gap);
}

.works-row .wp-block-image,
.works-row figure {
  margin: 0;
  flex: 0 0 auto;
}

.works-row .wp-block-image,
.works-row figure { position: relative; }

.works-row img {
  height: var(--row-h);
  width: auto;
  cursor: zoom-in;
  transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform;
}

/* In-place zoom: a pure transform, so the row never reflows. */
.works-row .is-zoomed img {
  transform: scale(2);
  cursor: zoom-out;
}

.works-row .is-zoomed,
.works-row .is-shrinking { z-index: 60; }

/* Notes live in captions; hidden in the row, shown in the overlay. */
.works-row figcaption { display: none; }

/* First row breathes below the header. */
.front-canvas { padding-top: clamp(2rem, 6vw, 5rem); padding-bottom: var(--row-gap); }

/* ---------- Floating note (top-left while a work is enlarged) ---------- */
.work-note {
  position: fixed;
  top: clamp(4.5rem, 10vh, 7rem);
  left: var(--gutter);
  max-width: 24ch;
  font-size: 0.82rem;
  line-height: 1.7;
  color: var(--ink-soft);
  z-index: 70;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.35s ease;
}

.work-note.is-visible { opacity: 1; }

.work-note em,
.work-note i { font-family: var(--font-name); font-style: italic; font-size: 1rem; color: var(--ink); }

/* ---------- Pages (about / exhibitions) ---------- */
.entry { padding: clamp(2rem, 6vw, 5rem) var(--gutter); }

.entry-title { font-family: var(--font-name); font-size: clamp(1.6rem, 3vw, 2.4rem); }

.entry-content { max-width: 62ch; }

.entry-content a { border-bottom: 1px solid var(--ink); }
.entry-content a:hover { color: var(--coral); border-color: var(--coral); }

/* Works Row also works inside regular pages, e.g. exhibitions. */
.entry-content .works-row { padding-inline: 0; justify-content: flex-start; }

/* ---------- Footer ---------- */
.site-footer {
  padding: 2.5rem var(--gutter);
  font-size: 0.75rem;
  letter-spacing: 0.1em;
  text-transform: lowercase;
  color: var(--ink-soft);
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

/* ---------- Accessibility & motion ---------- */
:focus-visible { outline: 2px solid var(--ink); outline-offset: 3px; }

.skip-link {
  position: absolute;
  left: -999px;
  top: 0;
  background: var(--ink);
  color: var(--paper);
  padding: 0.6rem 1rem;
  z-index: 100;
}

.skip-link:focus { left: 0; }

@media (prefers-reduced-motion: reduce) {
  * { transition-duration: 0.01ms !important; }
}

/* ---------- Mobile ---------- */
@media (max-width: 720px) {
  .works-row {
    flex-wrap: wrap;
    align-items: flex-start;
  }
  .works-row img { height: calc(var(--row-h) * 0.75); }
  .works-row .is-zoomed img { transform: scale(1.6); }
  .work-note { top: auto; bottom: 1.2rem; max-width: none; right: var(--gutter); background: rgba(255, 255, 255, 0.92); padding: 0.6rem 0; }
}
