/* ============================================================
   HALA ALI — halaali.ca
   Stylesheet v1.0
   ============================================================ */

/* ---- Fonts ---- */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;1,9..144,300;1,9..144,400&family=Instrument+Sans:ital,wght@0,400;0,500;1,400&family=Instrument+Serif:ital@0;1&family=Aref+Ruqaa:wght@400;700&display=swap');

/* ---- Design tokens ---- */
:root {
  /* Color */
  --khat: #F2EDE4;          /* primary background — ink-paper */
  --paper: #FFFFFF;         /* product imagery backdrop */
  --lamp-black: #141210;    /* deep contrast — text, dark sections */
  --gilded: #A78A4F;        /* antique gold accent */
  --gilded-soft: rgba(167, 138, 79, 0.4);
  --oxblood: #3D1F1F;       /* editorial deep tone */
  --smoke: #A89E92;         /* secondary text, fine lines */
  --smoke-line: rgba(20, 18, 16, 0.12);

  /* Type */
  --font-display: 'Fraunces', Georgia, serif;
  --font-editorial: 'Instrument Serif', 'Fraunces', serif;
  --font-ui: 'Instrument Sans', system-ui, sans-serif;
  --font-arabic: 'Aref Ruqaa', serif;

  /* Spacing scale (base 8) */
  --space-1: 8px;
  --space-2: 16px;
  --space-3: 24px;
  --space-4: 32px;
  --space-5: 48px;
  --space-6: 64px;
  --space-7: 96px;
  --space-8: 128px;
  --space-9: 160px;
  --space-10: 200px;

  /* Layout */
  --max-width: 1440px;
  --gutter: clamp(24px, 5vw, 80px);

  /* Motion */
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --slow: 700ms;
  --med: 400ms;
  --fast: 200ms;
}

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

* { margin: 0; padding: 0; }

html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

body {
  background: var(--khat);
  color: var(--lamp-black);
  font-family: var(--font-ui);
  font-weight: 400;
  font-size: 17px;
  line-height: 1.6;
  overflow-x: hidden;
}

img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { background: none; border: none; cursor: pointer; font: inherit; color: inherit; }
ul, ol { list-style: none; }

/* ---- Type system ---- */

.eyebrow {
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--smoke);
}

.eyebrow--gold { color: var(--gilded); }

h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 300;
  line-height: 1.05;
  letter-spacing: -0.01em;
}

h1 {
  font-size: clamp(48px, 8vw, 112px);
  font-weight: 300;
}

h2 {
  font-size: clamp(36px, 5.5vw, 72px);
}

h3 {
  font-size: clamp(24px, 3vw, 40px);
}

h4 {
  font-size: clamp(20px, 2vw, 26px);
}

.editorial {
  font-family: var(--font-editorial);
  font-style: italic;
  font-weight: 400;
}

.arabic {
  font-family: var(--font-arabic);
  direction: rtl;
}

p { max-width: 62ch; }

.lead {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(22px, 2.5vw, 32px);
  line-height: 1.4;
  letter-spacing: -0.005em;
  max-width: 32ch;
}

/* ---- Layout primitives ---- */

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

.section {
  padding: var(--space-9) 0;
}

@media (max-width: 768px) {
  .section { padding: var(--space-7) 0; }
}

.divider {
  height: 1px;
  background: var(--smoke-line);
  border: 0;
  width: 100%;
}

/* ============================================================
   NAVIGATION
   ============================================================ */

.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  padding: var(--space-3) var(--gutter);
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: background var(--med) var(--ease), padding var(--med) var(--ease);
  mix-blend-mode: normal;
}

.nav.is-scrolled {
  background: rgba(242, 237, 228, 0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding: var(--space-2) var(--gutter);
  border-bottom: 1px solid var(--smoke-line);
}

.nav.is-dark {
  color: var(--khat);
}

.nav.is-dark.is-scrolled {
  color: var(--lamp-black);
}

.nav__logo {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 22px;
  letter-spacing: 0.01em;
  font-style: italic;
  font-family: var(--font-editorial);
}

.nav__logo .editorial {
  font-size: 13px;
  display: block;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--smoke);
  font-style: normal;
  font-family: var(--font-ui);
  margin-top: -2px;
}

.nav__links {
  display: flex;
  gap: var(--space-5);
}

.nav__links a {
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  position: relative;
  padding: 4px 0;
  transition: color var(--fast) var(--ease);
}

.nav__links a::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0;
  width: 0;
  height: 1px;
  background: var(--gilded);
  transition: width var(--med) var(--ease);
}

.nav__links a:hover::after,
.nav__links a.is-active::after {
  width: 100%;
}

.nav__cta {
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border: 1px solid var(--gilded);
  color: var(--gilded);
  padding: 12px 22px;
  transition: background var(--med) var(--ease), color var(--med) var(--ease);
}

.nav__cta:hover {
  background: var(--gilded);
  color: var(--khat);
}

.nav__menu-btn {
  display: none;
  font-size: 13px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

@media (max-width: 900px) {
  .nav__links, .nav__cta { display: none; }
  .nav__menu-btn { display: block; }
}

/* Mobile menu overlay */
.menu-overlay {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: var(--lamp-black);
  color: var(--khat);
  padding: var(--space-3) var(--gutter);
  display: none;
  flex-direction: column;
}

.menu-overlay.is-open { display: flex; }

.menu-overlay__top {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.menu-overlay__close {
  font-size: 13px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--khat);
}

.menu-overlay__nav {
  margin-top: auto;
  margin-bottom: auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.menu-overlay__nav a {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: 44px;
}

.menu-overlay__nav a .editorial {
  font-size: 14px;
  font-family: var(--font-ui);
  font-style: normal;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--smoke);
  display: block;
  margin-bottom: 4px;
}

/* ============================================================
   HERO
   ============================================================ */

.hero {
  position: relative;
  height: 100vh;
  min-height: 700px;
  width: 100%;
  overflow: hidden;
  background: var(--lamp-black);
}

.hero__bg {
  position: absolute;
  inset: 0;
  animation: heroDrift 18s var(--ease) infinite alternate;
}

@keyframes heroDrift {
  0%   { transform: scale(1.02) translate(-0.5%, -0.5%); }
  100% { transform: scale(1.08) translate(0.5%, 0.5%); }
}

.hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(20,18,16, 0.2) 0%,
    rgba(20,18,16, 0.1) 40%,
    rgba(20,18,16, 0.6) 100%
  );
}

.hero__content {
  position: absolute;
  bottom: clamp(60px, 12vh, 140px);
  left: var(--gutter);
  right: var(--gutter);
  max-width: 800px;
  color: var(--khat);
  z-index: 2;
}

.hero__eyebrow {
  display: inline-block;
  margin-bottom: var(--space-3);
  color: var(--gilded);
  opacity: 0;
  animation: rise 1.2s var(--ease) 0.2s forwards;
}

.hero__title {
  margin-bottom: var(--space-3);
  opacity: 0;
  animation: rise 1.4s var(--ease) 0.4s forwards;
}

.hero__title em {
  font-family: var(--font-editorial);
  font-style: italic;
  font-weight: 400;
}

.hero__sub {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(16px, 1.6vw, 20px);
  max-width: 38ch;
  margin-bottom: var(--space-5);
  opacity: 0;
  animation: rise 1.4s var(--ease) 0.7s forwards;
  color: rgba(242, 237, 228, 0.85);
}

.hero__cta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gilded);
  padding-bottom: 4px;
  border-bottom: 1px solid var(--gilded-soft);
  opacity: 0;
  animation: rise 1.4s var(--ease) 1s forwards;
  transition: gap var(--med) var(--ease), border-color var(--med) var(--ease);
}

.hero__cta:hover {
  gap: var(--space-3);
  border-color: var(--gilded);
}

@keyframes rise {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Page hero (smaller, used on inner pages) */

.page-hero {
  padding: calc(var(--space-9) + 80px) 0 var(--space-7);
  border-bottom: 1px solid var(--smoke-line);
}

.page-hero__eyebrow {
  margin-bottom: var(--space-3);
}

.page-hero__title {
  max-width: 14ch;
  margin-bottom: var(--space-4);
}

.page-hero__title em {
  font-family: var(--font-editorial);
  font-style: italic;
  font-weight: 400;
}

.page-hero__sub {
  max-width: 50ch;
  color: var(--lamp-black);
  opacity: 0.75;
}

/* ============================================================
   STATEMENT BLOCK (homepage section 2)
   ============================================================ */

.statement {
  text-align: center;
  padding: var(--space-9) var(--gutter);
}

.statement__lead {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(28px, 3.5vw, 44px);
  line-height: 1.35;
  max-width: 22ch;
  margin: 0 auto var(--space-5);
  letter-spacing: -0.01em;
}

.statement__lead em {
  font-family: var(--font-editorial);
  font-weight: 400;
}

.statement__mark {
  font-family: var(--font-arabic);
  font-size: 36px;
  color: var(--gilded);
  line-height: 1;
}

/* ============================================================
   FEATURED SERIES (alternating editorial blocks)
   ============================================================ */

.series {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-7);
  align-items: center;
  margin-bottom: var(--space-9);
}

.series:last-child { margin-bottom: 0; }

.series--reverse .series__media { order: 2; }
.series--reverse .series__content { order: 1; padding-right: 0; padding-left: var(--space-5); }

.series__media {
  aspect-ratio: 4 / 5;
  position: relative;
  overflow: hidden;
}

.series__media .placeholder-art {
  transition: transform 1.4s var(--ease);
}

.series:hover .series__media .placeholder-art {
  transform: scale(1.03);
}

.series__content {
  padding-right: var(--space-5);
}

.series__number {
  font-family: var(--font-editorial);
  font-style: italic;
  font-size: 14px;
  color: var(--gilded);
  margin-bottom: var(--space-3);
  display: block;
}

.series__title {
  margin-bottom: var(--space-3);
}

.series__title em {
  font-family: var(--font-editorial);
  font-weight: 400;
}

.series__desc {
  color: var(--lamp-black);
  opacity: 0.75;
  margin-bottom: var(--space-4);
  max-width: 38ch;
}

.series__link {
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--smoke-line);
  padding-bottom: 4px;
  transition: border-color var(--med) var(--ease), color var(--med) var(--ease);
}

.series__link:hover {
  border-color: var(--gilded);
  color: var(--gilded);
}

@media (max-width: 768px) {
  .series, .series--reverse {
    grid-template-columns: 1fr;
    gap: var(--space-5);
    margin-bottom: var(--space-7);
  }
  .series--reverse .series__media { order: 0; }
  .series--reverse .series__content { order: 1; padding: 0; }
  .series__content { padding: 0; }
}

/* ============================================================
   WORKS GRID (selected works, masonry-feel)
   ============================================================ */

.section-head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  margin-bottom: var(--space-6);
  gap: var(--space-3);
  flex-wrap: wrap;
}

.section-head h2 {
  max-width: 16ch;
}

.section-head__link {
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gilded);
  border-bottom: 1px solid var(--gilded-soft);
  padding-bottom: 4px;
  transition: border-color var(--med) var(--ease);
  white-space: nowrap;
}

.section-head__link:hover { border-color: var(--gilded); }

.works-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--space-3);
}

/* asymmetric masonry — varied heights and column spans */
.work-card { position: relative; cursor: pointer; }

.work-card .placeholder-art {
  transition: transform 1s var(--ease), opacity var(--med) var(--ease);
}

.work-card:hover .placeholder-art {
  transform: scale(1.02);
}

.work-card__caption {
  margin-top: var(--space-2);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--space-2);
}

.work-card__title {
  font-family: var(--font-editorial);
  font-style: italic;
  font-size: 16px;
  line-height: 1.3;
}

.work-card__meta {
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--smoke);
  white-space: nowrap;
}

.work-card__detail {
  margin-top: 4px;
  font-size: 13px;
  font-family: var(--font-editorial);
  font-style: italic;
  color: var(--smoke);
  line-height: 1.5;
}

/* Layout positions (homepage selected works) */
.work-card--a { grid-column: 1 / span 5; }
.work-card--a .placeholder-art,
.work-card--a > .art-img { aspect-ratio: 4 / 5; }

.work-card--b { grid-column: 6 / span 7; margin-top: var(--space-7); }
.work-card--b .placeholder-art,
.work-card--b > .art-img { aspect-ratio: 16 / 11; }

.work-card--c { grid-column: 1 / span 4; margin-top: var(--space-5); }
.work-card--c .placeholder-art,
.work-card--c > .art-img { aspect-ratio: 3 / 4; }

.work-card--d { grid-column: 5 / span 4; }
.work-card--d .placeholder-art,
.work-card--d > .art-img { aspect-ratio: 1 / 1; }

.work-card--e { grid-column: 9 / span 4; margin-top: var(--space-6); }
.work-card--e .placeholder-art,
.work-card--e > .art-img { aspect-ratio: 4 / 5; }

/* When .art-img is the direct sizing element, height auto + width 100% */
.work-card > .art-img {
  height: auto;
  width: 100%;
  object-fit: cover;
}

@media (max-width: 768px) {
  .works-grid { grid-template-columns: 1fr 1fr; gap: var(--space-3); }
  .work-card--a, .work-card--b, .work-card--c,
  .work-card--d, .work-card--e {
    grid-column: span 1;
    margin-top: 0;
  }
  .work-card--a .placeholder-art,
  .work-card--b .placeholder-art,
  .work-card--c .placeholder-art,
  .work-card--d .placeholder-art,
  .work-card--e .placeholder-art,
  .work-card--a > .art-img,
  .work-card--b > .art-img,
  .work-card--c > .art-img,
  .work-card--d > .art-img,
  .work-card--e > .art-img {
    aspect-ratio: 4 / 5;
  }
  .work-card--b { grid-column: span 2; }
  .work-card--b .placeholder-art,
  .work-card--b > .art-img { aspect-ratio: 4 / 5; }
}

/* ============================================================
   STUDIO BLOCK (full-bleed dark moment)
   ============================================================ */

.studio {
  background: var(--lamp-black);
  color: var(--khat);
  padding: var(--space-9) 0;
  position: relative;
  overflow: hidden;
}

.studio__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-7);
  align-items: center;
  position: relative;
  z-index: 1;
}

.studio__media {
  aspect-ratio: 4 / 5;
  position: relative;
  overflow: hidden;
}

.studio__eyebrow {
  color: var(--gilded);
  margin-bottom: var(--space-3);
}

.studio__title {
  margin-bottom: var(--space-4);
}

.studio__title em {
  font-family: var(--font-editorial);
  font-weight: 400;
}

.studio__text {
  color: rgba(242, 237, 228, 0.75);
  margin-bottom: var(--space-5);
  max-width: 42ch;
}

.studio__link {
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gilded);
  border-bottom: 1px solid var(--gilded-soft);
  padding-bottom: 4px;
  display: inline-block;
}

@media (max-width: 768px) {
  .studio__inner { grid-template-columns: 1fr; gap: var(--space-5); }
}

/* ============================================================
   WORKSHOP CARD
   ============================================================ */

.workshop {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: var(--space-6);
  align-items: stretch;
  border-top: 1px solid var(--smoke-line);
  border-bottom: 1px solid var(--smoke-line);
  padding: var(--space-6) 0;
}

.workshop__media {
  aspect-ratio: 4 / 3;
}

.workshop__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.workshop__date {
  font-family: var(--font-editorial);
  font-style: italic;
  color: var(--gilded);
  margin-bottom: var(--space-2);
}

.workshop__title {
  margin-bottom: var(--space-3);
}

.workshop__desc {
  margin-bottom: var(--space-4);
  opacity: 0.75;
}

.workshop__cta {
  display: inline-flex;
  align-self: flex-start;
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  border: 1px solid var(--lamp-black);
  padding: 14px 24px;
  transition: background var(--med) var(--ease), color var(--med) var(--ease);
}

.workshop__cta:hover {
  background: var(--lamp-black);
  color: var(--khat);
}

@media (max-width: 768px) {
  .workshop { grid-template-columns: 1fr; gap: var(--space-4); }
}

/* ============================================================
   NEWSLETTER
   ============================================================ */

.newsletter {
  text-align: center;
  padding: var(--space-9) var(--gutter);
  background: var(--khat);
}

.newsletter__eyebrow { margin-bottom: var(--space-3); color: var(--gilded); }

.newsletter__title {
  margin-bottom: var(--space-3);
  max-width: 16ch;
  margin-left: auto;
  margin-right: auto;
}

.newsletter__title em { font-family: var(--font-editorial); font-weight: 400; }

.newsletter__text {
  margin: 0 auto var(--space-5);
  max-width: 44ch;
  color: var(--lamp-black);
  opacity: 0.75;
}

.newsletter__form {
  max-width: 480px;
  margin: 0 auto;
  display: flex;
  border-bottom: 1px solid var(--lamp-black);
}

.newsletter__input {
  flex: 1;
  background: transparent;
  border: 0;
  padding: 12px 0;
  font-family: var(--font-ui);
  font-size: 15px;
  color: var(--lamp-black);
  outline: none;
}

.newsletter__input::placeholder { color: var(--smoke); }

.newsletter__submit {
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gilded);
  padding: 12px 0 12px var(--space-3);
  transition: color var(--fast) var(--ease);
}

.newsletter__submit:hover { color: var(--lamp-black); }

.newsletter__note {
  font-family: var(--font-editorial);
  font-style: italic;
  font-size: 13px;
  color: var(--smoke);
  margin-top: var(--space-3);
}

/* ============================================================
   FOOTER
   ============================================================ */

.footer {
  background: var(--lamp-black);
  color: var(--khat);
  padding: var(--space-7) var(--gutter) var(--space-4);
}

.footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: var(--space-5);
  padding-bottom: var(--space-6);
  border-bottom: 1px solid rgba(242, 237, 228, 0.15);
}

.footer__brand .nav__logo { font-size: 24px; color: var(--khat); }
.footer__brand .nav__logo .editorial { color: rgba(242, 237, 228, 0.5); }

.footer__tag {
  font-family: var(--font-editorial);
  font-style: italic;
  margin-top: var(--space-2);
  color: rgba(242, 237, 228, 0.6);
  max-width: 28ch;
}

.footer__col h5 {
  font-family: var(--font-ui);
  font-weight: 500;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--gilded);
  margin-bottom: var(--space-3);
}

.footer__col ul { display: flex; flex-direction: column; gap: 8px; }

.footer__col a, .footer__col span {
  font-size: 14px;
  color: rgba(242, 237, 228, 0.75);
  transition: color var(--fast) var(--ease);
}

.footer__col a:hover { color: var(--khat); }

.footer__base {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: var(--space-3);
  font-size: 12px;
  color: rgba(242, 237, 228, 0.5);
  flex-wrap: wrap;
  gap: var(--space-2);
}

@media (max-width: 768px) {
  .footer__grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-4);
  }
  .footer__brand { grid-column: span 2; margin-bottom: var(--space-3); }
}

/* ============================================================
   IMAGE HANDLING — wrapper pattern
   Use .media wrapper to give images a fixed aspect ratio.
   ============================================================ */

.media {
  position: relative;
  overflow: hidden;
  display: block;
  background: var(--lamp-black);
}

.media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 1.4s var(--ease);
}

a:hover .media img,
.work-card:hover .media img,
.product:hover .media img,
.series:hover .media img {
  transform: scale(1.03);
}

/* Aspect ratios per card variant */
.media--4x5 { aspect-ratio: 4 / 5; }
.media--3x4 { aspect-ratio: 3 / 4; }
.media--1x1 { aspect-ratio: 1 / 1; }
.media--16x11 { aspect-ratio: 16 / 11; }
.media--4x3 { aspect-ratio: 4 / 3; }

@media (max-width: 768px) {
  /* On mobile, force a sensible aspect ratio */
  .work-card .media,
  .works-editorial .work-card .media {
    aspect-ratio: 4 / 5 !important;
  }
}

/* ============================================================
   ARTWORK IMAGES
   Used everywhere a real artwork photo is shown.
   Sit inside aspect-ratio containers (.series__media, .work-card,
   .product__media, etc.) so they crop predictably.
   ============================================================ */

.art-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  background: var(--lamp-black); /* fallback while loading */
  transition: transform 1.4s var(--ease), opacity 600ms var(--ease);
}

/* When the artwork is photographed framed against a wall, contain
   so the full piece is visible inside its quiet field. */
.art-img--contain {
  object-fit: contain;
  background: var(--khat);
}

/* Slow zoom on hover for cards */
.work-card:hover .art-img,
.product:hover .art-img,
.series:hover .art-img {
  transform: scale(1.03);
}

/* Portrait image (about page) */
.portrait-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 20%; /* keep the face in frame on crop */
  display: block;
}

/* Hero artwork: subtle drift (replaces hero__bg div animation) */
.hero__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  animation: heroDrift 18s var(--ease) infinite alternate;
}

/* ============================================================
   PLACEHOLDER ART SYSTEM (kept as fallback)
   Each variant suggests a different work in the series.
   Built with layered SVG via background-image (no real artwork).
   ============================================================ */

.placeholder-art {
  width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden;
  background-color: var(--lamp-black);
}

.placeholder-art::after {
  content: '';
  position: absolute;
  inset: 0;
  /* Subtle paper noise via SVG */
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' 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.18 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity: 0.5;
  mix-blend-mode: overlay;
  pointer-events: none;
}

/* Variant 1 — deep ink with gold gesture */
.placeholder-art--ink {
  background:
    radial-gradient(ellipse at 30% 70%, rgba(167,138,79,0.25) 0%, transparent 45%),
    radial-gradient(ellipse at 70% 20%, rgba(167,138,79,0.1) 0%, transparent 50%),
    linear-gradient(135deg, #1a1815 0%, #0e0c0a 100%);
}

.placeholder-art--ink::before {
  content: '';
  position: absolute;
  top: 35%;
  left: 15%;
  width: 70%;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(167,138,79,0.6) 30%, rgba(167,138,79,0.3) 70%, transparent 100%);
  transform: rotate(-12deg);
}

/* Variant 2 — cream / vellum with dark gestural mass */
.placeholder-art--vellum {
  background:
    radial-gradient(ellipse at 25% 30%, rgba(20,18,16,0.55) 0%, transparent 40%),
    radial-gradient(ellipse at 75% 65%, rgba(167,138,79,0.18) 0%, transparent 35%),
    linear-gradient(160deg, #ece4d3 0%, #e2d8c2 100%);
}

.placeholder-art--vellum::before {
  content: '';
  position: absolute;
  bottom: 12%;
  right: 15%;
  width: 28%;
  height: 18%;
  background: linear-gradient(135deg, rgba(167,138,79,0.4), rgba(167,138,79,0.15));
  transform: rotate(6deg);
}

/* Variant 3 — oxblood with vertical gold line */
.placeholder-art--oxblood {
  background:
    radial-gradient(ellipse at 60% 40%, rgba(167,138,79,0.2) 0%, transparent 50%),
    linear-gradient(140deg, #4a2424 0%, #2a1313 100%);
}

.placeholder-art--oxblood::before {
  content: '';
  position: absolute;
  top: 10%;
  left: 38%;
  width: 1px;
  height: 80%;
  background: linear-gradient(180deg, transparent, rgba(167,138,79,0.7) 30%, rgba(167,138,79,0.5) 70%, transparent);
}

/* Variant 4 — smoke / muted with diagonal gesture */
.placeholder-art--smoke {
  background:
    radial-gradient(ellipse at 50% 50%, rgba(20,18,16,0.45) 0%, transparent 60%),
    linear-gradient(170deg, #b8b0a4 0%, #8a8278 100%);
}

.placeholder-art--smoke::before {
  content: '';
  position: absolute;
  top: 20%;
  left: 25%;
  width: 50%;
  height: 60%;
  background: radial-gradient(ellipse at center, rgba(20,18,16,0.5) 0%, transparent 70%);
  transform: rotate(-8deg);
}

/* Variant 5 — ink with horizontal gold band (editorial) */
.placeholder-art--band {
  background:
    linear-gradient(180deg,
      #181513 0%,
      #181513 58%,
      rgba(167,138,79,0.4) 58.5%,
      rgba(167,138,79,0.5) 60%,
      rgba(167,138,79,0.3) 61%,
      #181513 62%,
      #0e0c0a 100%);
}

/* Variant 6 — cream square with off-center dark mark */
.placeholder-art--mark {
  background:
    radial-gradient(circle at 65% 55%, rgba(20,18,16,0.85) 0%, rgba(20,18,16,0.4) 8%, transparent 18%),
    linear-gradient(180deg, #ece4d3 0%, #d8cfb9 100%);
}

.placeholder-art--mark::before {
  content: '';
  position: absolute;
  top: 65%;
  left: 60%;
  width: 12%;
  height: 4px;
  background: var(--gilded);
  opacity: 0.7;
}

/* Variant 7 — dark with cluster of gold leaf rectangles */
.placeholder-art--leaf {
  background: linear-gradient(135deg, #1a1715 0%, #0e0c0a 100%);
}

.placeholder-art--leaf::before {
  content: '';
  position: absolute;
  top: 22%;
  left: 28%;
  width: 22%;
  height: 28%;
  background:
    linear-gradient(45deg, rgba(167,138,79,0.6), rgba(167,138,79,0.3));
  box-shadow:
    -8px 14px 0 rgba(167,138,79,0.4),
    18px -6px 0 rgba(167,138,79,0.5),
    32px 22px 0 rgba(167,138,79,0.25);
  transform: rotate(-4deg);
}

/* Variant 8 — muted oxblood field with fine lines */
.placeholder-art--field {
  background:
    repeating-linear-gradient(
      90deg,
      rgba(167,138,79,0) 0,
      rgba(167,138,79,0) 14px,
      rgba(167,138,79,0.07) 14px,
      rgba(167,138,79,0.07) 15px),
    linear-gradient(180deg, #3d1f1f 0%, #2a1414 100%);
}

/* Portrait placeholder (about page) */
.placeholder-portrait {
  background:
    radial-gradient(ellipse at 50% 35%, rgba(167,138,79,0.2) 0%, transparent 35%),
    linear-gradient(180deg, #2a2520 0%, #14110e 100%);
  position: relative;
}

.placeholder-portrait::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.2' numOctaves='3' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.25 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity: 0.6;
  mix-blend-mode: overlay;
}

.placeholder-portrait::after {
  content: 'Portrait';
  position: absolute;
  bottom: var(--space-3);
  left: var(--space-3);
  font-family: var(--font-editorial);
  font-style: italic;
  font-size: 13px;
  color: rgba(242,237,228, 0.4);
}

/* ============================================================
   WORKS PAGE
   ============================================================ */

.filters {
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
  margin-bottom: var(--space-7);
  border-bottom: 1px solid var(--smoke-line);
  padding-bottom: var(--space-3);
}

.filters__btn {
  font-size: 13px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding-bottom: 6px;
  color: var(--smoke);
  position: relative;
  transition: color var(--fast) var(--ease);
}

.filters__btn::after {
  content: '';
  position: absolute;
  bottom: -1px; left: 0;
  width: 0;
  height: 1px;
  background: var(--gilded);
  transition: width var(--med) var(--ease);
}

.filters__btn.is-active,
.filters__btn:hover {
  color: var(--lamp-black);
}

.filters__btn.is-active::after { width: 100%; }

.filters__count {
  margin-left: auto;
  font-family: var(--font-editorial);
  font-style: italic;
  color: var(--smoke);
}

/* Editorial works grid (all-works page) */
.works-editorial {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--space-3) var(--space-4);
}

.works-editorial .work-card {
  margin-bottom: var(--space-5);
}

.works-editorial .work-card--lg { grid-column: span 7; }
.works-editorial .work-card--lg .placeholder-art,
.works-editorial .work-card--lg > .art-img { aspect-ratio: 4 / 5; }

.works-editorial .work-card--md { grid-column: span 5; margin-top: var(--space-7); }
.works-editorial .work-card--md .placeholder-art,
.works-editorial .work-card--md > .art-img { aspect-ratio: 1 / 1; }

.works-editorial .work-card--wide { grid-column: span 8; }
.works-editorial .work-card--wide .placeholder-art,
.works-editorial .work-card--wide > .art-img { aspect-ratio: 16 / 11; }

.works-editorial .work-card--sm { grid-column: span 4; margin-top: var(--space-5); }
.works-editorial .work-card--sm .placeholder-art,
.works-editorial .work-card--sm > .art-img { aspect-ratio: 3 / 4; }

.works-editorial .work-card--col1 { grid-column: 1 / span 6; }
.works-editorial .work-card--col1 .placeholder-art,
.works-editorial .work-card--col1 > .art-img { aspect-ratio: 4 / 5; }

.works-editorial .work-card--col2 { grid-column: 8 / span 5; margin-top: var(--space-9); }
.works-editorial .work-card--col2 .placeholder-art,
.works-editorial .work-card--col2 > .art-img { aspect-ratio: 4 / 5; }

@media (max-width: 768px) {
  .works-editorial { grid-template-columns: 1fr; }
  .works-editorial .work-card,
  .works-editorial .work-card--lg,
  .works-editorial .work-card--md,
  .works-editorial .work-card--wide,
  .works-editorial .work-card--sm,
  .works-editorial .work-card--col1,
  .works-editorial .work-card--col2 {
    grid-column: span 1;
    margin-top: 0;
  }
  .works-editorial .work-card--lg .placeholder-art,
  .works-editorial .work-card--md .placeholder-art,
  .works-editorial .work-card--wide .placeholder-art,
  .works-editorial .work-card--sm .placeholder-art,
  .works-editorial .work-card--col1 .placeholder-art,
  .works-editorial .work-card--col2 .placeholder-art,
  .works-editorial .work-card--lg > .art-img,
  .works-editorial .work-card--md > .art-img,
  .works-editorial .work-card--wide > .art-img,
  .works-editorial .work-card--sm > .art-img,
  .works-editorial .work-card--col1 > .art-img,
  .works-editorial .work-card--col2 > .art-img {
    aspect-ratio: 4 / 5;
  }
}

/* ============================================================
   ABOUT PAGE
   ============================================================ */

.about-hero {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: var(--space-7);
  align-items: end;
  padding: calc(var(--space-9) + 80px) 0 var(--space-7);
}

.about-hero__portrait {
  aspect-ratio: 3 / 4;
}

.about-hero__title {
  margin-bottom: var(--space-4);
}

.about-hero__title em {
  font-family: var(--font-editorial);
  font-weight: 400;
}

.about-hero__lead {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(20px, 2vw, 28px);
  line-height: 1.4;
  max-width: 32ch;
  color: var(--lamp-black);
}

.about-bio {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--space-7);
  padding: var(--space-7) 0;
  border-top: 1px solid var(--smoke-line);
}

.about-bio h2 {
  font-size: clamp(28px, 3vw, 40px);
  max-width: 12ch;
}

.about-bio__text p {
  margin-bottom: var(--space-3);
  font-size: 17px;
  line-height: 1.7;
  max-width: 60ch;
}

.about-bio__text p:first-child::first-letter {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: 4em;
  float: left;
  line-height: 0.85;
  margin: 8px 12px 0 0;
  color: var(--gilded);
}

.cv-grid {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--space-7);
  padding: var(--space-7) 0;
  border-top: 1px solid var(--smoke-line);
}

.cv-grid h2 { font-size: clamp(28px, 3vw, 40px); }

.cv-list { display: flex; flex-direction: column; gap: var(--space-4); }

.cv-section h4 {
  font-family: var(--font-ui);
  font-weight: 500;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--gilded);
  margin-bottom: var(--space-2);
}

.cv-section ul { display: flex; flex-direction: column; gap: 10px; }

.cv-item {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: var(--space-3);
  padding: 8px 0;
  border-bottom: 1px solid var(--smoke-line);
  font-size: 15px;
}

.cv-item__year {
  font-family: var(--font-editorial);
  font-style: italic;
  color: var(--gilded);
}

@media (max-width: 768px) {
  .about-hero, .about-bio, .cv-grid {
    grid-template-columns: 1fr;
    gap: var(--space-5);
  }
}

/* ============================================================
   SHOP PAGE
   ============================================================ */

.shop-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5) var(--space-4);
}

.product {
  position: relative;
  cursor: pointer;
}

.product__media {
  aspect-ratio: 4 / 5;
  position: relative;
  overflow: hidden;
}

.product__media .placeholder-art {
  transition: transform 1.4s var(--ease);
}

.product:hover .product__media .placeholder-art { transform: scale(1.04); }

.product__badge {
  position: absolute;
  top: var(--space-2);
  left: var(--space-2);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  background: rgba(20,18,16,0.7);
  color: var(--khat);
  padding: 6px 10px;
  z-index: 2;
}

.product__badge--gold {
  background: var(--gilded);
  color: var(--lamp-black);
}

.product__sold {
  position: absolute;
  inset: 0;
  background: rgba(20,18,16,0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--khat);
  font-family: var(--font-editorial);
  font-style: italic;
  font-size: 26px;
  letter-spacing: 0.04em;
  z-index: 2;
}

.product__info {
  margin-top: var(--space-3);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-2);
  align-items: baseline;
}

.product__title {
  font-family: var(--font-editorial);
  font-style: italic;
  font-size: 18px;
}

.product__title-arabic {
  font-family: var(--font-arabic);
  font-style: normal;
  margin-left: 8px;
  color: var(--gilded);
  font-size: 16px;
}

.product__price {
  font-size: 14px;
  color: var(--lamp-black);
  white-space: nowrap;
}

.product__meta {
  grid-column: 1 / -1;
  font-size: 12px;
  color: var(--smoke);
  margin-top: 4px;
  letter-spacing: 0.04em;
}

.product__cta {
  position: absolute;
  bottom: var(--space-3);
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  background: var(--khat);
  color: var(--lamp-black);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 12px 18px;
  opacity: 0;
  transition: opacity var(--med) var(--ease), transform var(--med) var(--ease);
  white-space: nowrap;
}

.product:hover .product__cta {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

@media (max-width: 768px) {
  .shop-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-4) var(--space-2); }
  .product__cta { display: none; } /* tap-to-view on mobile */
}

.shop-tier {
  margin-bottom: var(--space-8);
}

.shop-tier__head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  border-bottom: 1px solid var(--smoke-line);
  padding-bottom: var(--space-3);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
  gap: var(--space-2);
}

.shop-tier__title {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(28px, 3vw, 40px);
}

.shop-tier__title em { font-family: var(--font-editorial); font-weight: 400; }

.shop-tier__price-range {
  font-family: var(--font-editorial);
  font-style: italic;
  color: var(--smoke);
  font-size: 15px;
}

/* ============================================================
   CONTACT PAGE
   ============================================================ */

.contact {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: var(--space-7);
  padding: calc(var(--space-9) + 60px) 0 var(--space-9);
  align-items: start;
}

.contact__intro h1 {
  font-size: clamp(40px, 5vw, 64px);
  margin-bottom: var(--space-4);
}

.contact__intro h1 em { font-family: var(--font-editorial); font-weight: 400; }

.contact__lead {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: 18px;
  line-height: 1.5;
  max-width: 32ch;
  margin-bottom: var(--space-5);
  color: rgba(20,18,16,0.75);
}

.contact__details {
  margin-top: var(--space-5);
  padding-top: var(--space-4);
  border-top: 1px solid var(--smoke-line);
  font-size: 14px;
  color: var(--smoke);
}

.contact__details a { color: var(--lamp-black); }
.contact__details > div { margin-bottom: var(--space-2); }

/* Form */
.form { display: flex; flex-direction: column; gap: var(--space-4); }

.form__row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3); }

.form__field { display: flex; flex-direction: column; }

.form__label {
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gilded);
  margin-bottom: var(--space-2);
}

.form__input,
.form__textarea,
.form__select {
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--smoke-line);
  padding: 10px 0;
  font-family: var(--font-ui);
  font-size: 16px;
  color: var(--lamp-black);
  outline: none;
  transition: border-color var(--med) var(--ease);
}

.form__input:focus,
.form__textarea:focus,
.form__select:focus {
  border-color: var(--lamp-black);
}

.form__textarea { min-height: 140px; resize: vertical; }

.form__select {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%23A78A4F' stroke-width='1.2' fill='none'/></svg>");
  background-repeat: no-repeat;
  background-position: right 4px center;
  padding-right: 24px;
}

.form__submit {
  align-self: flex-start;
  border: 1px solid var(--lamp-black);
  padding: 16px 28px;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  background: var(--lamp-black);
  color: var(--khat);
  transition: background var(--med) var(--ease), color var(--med) var(--ease);
  margin-top: var(--space-3);
}

.form__submit:hover {
  background: var(--gilded);
  color: var(--lamp-black);
  border-color: var(--gilded);
}

@media (max-width: 768px) {
  .contact { grid-template-columns: 1fr; gap: var(--space-5); }
  .form__row { grid-template-columns: 1fr; }
}

/* ============================================================
   UTILITIES
   ============================================================ */

.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  border: 0;
}

/* Reveal-on-scroll baseline (JS adds .is-in-view).
   IMPORTANT: We default to visible. JS may add .is-in-view to retain
   a subtle entrance, but content must always render even if JS doesn't fire. */
.reveal {
  opacity: 1;
  transform: none;
  transition: opacity 1s var(--ease), transform 1s var(--ease);
}

/* Optional: if JS adds .reveal-init to <html>, then content starts hidden
   and fades in on intersection. */
html.reveal-init .reveal {
  opacity: 0;
  transform: translateY(20px);
}

html.reveal-init .reveal.is-in-view,
.reveal.is-in-view {
  opacity: 1;
  transform: translateY(0);
}

/* ============================================================
   GALLERY MOMENTS (homepage + about)
   ============================================================ */
.gallery-moments {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--space-3);
}

.gallery-moment {
  position: relative;
  display: block;
  overflow: hidden;
}

.gallery-moment img {
  width: 100%;
  height: auto;
  object-fit: cover;
  transition: transform 1s var(--ease);
}

.gallery-moment:hover img { transform: scale(1.02); }

.gallery-moment--lg { grid-column: span 7; }
.gallery-moment--lg img { aspect-ratio: 3 / 2; }

.gallery-moment--md { grid-column: span 5; margin-top: var(--space-5); }
.gallery-moment--md img { aspect-ratio: 3 / 2; }

.gallery-moment__cap {
  margin-top: var(--space-2);
  font-family: var(--font-editorial);
  font-style: italic;
  font-size: 14px;
  color: var(--smoke);
}

@media (max-width: 768px) {
  .gallery-moments { grid-template-columns: 1fr; gap: var(--space-4); }
  .gallery-moment--lg, .gallery-moment--md {
    grid-column: span 1;
    margin-top: 0;
  }
}

/* Workshop photo strip — secondary supporting images */
.workshop-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-2);
  margin-top: var(--space-5);
}

.workshop-strip__item {
  overflow: hidden;
  aspect-ratio: 4 / 5;
}

.workshop-strip__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1s var(--ease);
}

.workshop-strip__item:hover img { transform: scale(1.04); }

@media (max-width: 768px) {
  .workshop-strip { grid-template-columns: repeat(2, 1fr); }
}
