/* ============================================================
   Inner page shared styles
   ============================================================ */

/* Page hero (smaller than home hero) */
.page-hero {
  padding: 64px 0 32px;
  text-align: center;
}
.page-hero__title {
  font-size: clamp(56px, 8vw, 96px);
  margin: 16px 0 12px;
  letter-spacing: 0.04em;
}
.page-hero__sub {
  font-size: 18px;
  color: var(--ink-soft);
  margin: 0 auto 16px;
  max-width: 560px;
}
.page-hero__ornament {
  display: flex; align-items: center; justify-content: center;
  gap: 12px; color: var(--gold);
  margin: 24px 0 8px;
}
.page-hero__ornament::before,
.page-hero__ornament::after {
  content: ""; display: block; width: 48px; height: 1px; background: currentColor;
}
.page-hero__ornament svg { width: 14px; height: 14px; }

.page-section { padding: 56px 0 96px; }

/* ============================================================
   ESMORZARS
   ============================================================ */
.esmorzars-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px 80px;
  margin: 32px 0;
}
.esm-cat__title {
  font-family: var(--font-display);
  font-size: 32px;
  font-weight: 400;
  margin: 0 0 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--ink);
  letter-spacing: 0.04em;
}
.esm-cat__sub {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 15px;
  color: var(--ink-muted);
  margin: -8px 0 16px;
}
.esm-list { list-style: none; padding: 0; margin: 0; }
.esm-list li {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 16px;
  padding: 12px 0;
  border-bottom: 1px solid var(--line);
  font-size: 15.5px;
}
.esm-list li:last-child { border-bottom: none; }
.esm-list .price { font-variant-numeric: tabular-nums; white-space: nowrap; }
.esm-banner {
  background: var(--ink);
  color: var(--cream);
  padding: 48px;
  margin: 80px 0 40px;
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 48px;
  align-items: center;
}
.esm-banner__title {
  font-family: var(--font-display);
  font-size: 40px;
  margin: 0;
  letter-spacing: 0.04em;
  color: var(--cream);
}
.esm-banner__body {
  color: var(--cream);
  opacity: 0.85;
  font-size: 16px;
  margin: 0;
}

@media (max-width: 880px) {
  .esmorzars-grid { grid-template-columns: 1fr; gap: 40px; }
  .esm-banner { grid-template-columns: 1fr; padding: 32px; gap: 16px; }
  .esm-banner__title { font-size: 28px; }
}

/* ============================================================
   EVENTS PAGE
   ============================================================ */
.events-list {
  display: flex; flex-direction: column;
  border-top: 1px solid var(--line);
}
.event-row {
  display: grid;
  grid-template-columns: 140px 1fr auto;
  gap: 48px;
  align-items: center;
  padding: 32px 0;
  border-bottom: 1px solid var(--line);
}
.event-row__date {
  font-family: var(--font-display);
  text-align: left;
}
.event-row__day { font-size: 56px; line-height: 1; color: var(--ink); display: block; }
.event-row__month {
  font-family: var(--font-body);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--bronze-deep);
  margin-top: 6px;
  display: block;
}
.event-row__body { }
.event-row__tag {
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: 6px;
}
.event-row__title {
  font-family: var(--font-display);
  font-size: 28px;
  font-weight: 400;
  margin: 0 0 4px;
  color: var(--ink);
}
.event-row__meta { font-size: 14px; color: var(--ink-muted); margin: 0; }
.event-row__meta strong { color: var(--ink); font-weight: 500; }
.event-row__cta { white-space: nowrap; }

.events-cycle {
  background: var(--cream-soft);
  border: 1px solid var(--line);
  padding: 40px 48px;
  margin: 64px 0;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 32px;
  align-items: center;
}
.events-cycle__badge {
  width: 96px; height: 96px;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--ink);
  border-radius: 999px;
  font-family: var(--font-display);
  font-size: 14px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-align: center;
  line-height: 1.2;
}
.events-cycle__title { font-family: var(--font-display); font-size: 28px; margin: 0 0 4px; }
.events-cycle__body { margin: 0; font-size: 15px; color: var(--ink-soft); }

@media (max-width: 720px) {
  .event-row { grid-template-columns: 80px 1fr; gap: 24px; }
  .event-row__day { font-size: 36px; }
  .event-row__title { font-size: 22px; }
  .event-row__cta { grid-column: 2; margin-top: 8px; }
  .events-cycle { grid-template-columns: 1fr; padding: 28px; gap: 16px; }
}

/* ============================================================
   ABOUT
   ============================================================ */
.about-intro {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 80px;
  align-items: center;
  margin: 32px 0 96px;
}
.about-intro__copy p {
  font-size: 17px;
  line-height: 1.75;
  color: var(--ink-soft);
  margin: 0 0 20px;
}
.about-intro__copy p:first-child::first-letter {
  font-family: var(--font-display);
  font-size: 64px;
  line-height: 0.85;
  float: left;
  padding: 8px 12px 0 0;
  color: var(--bronze-deep);
}
.about-intro__media img {
  width: 100%; aspect-ratio: 4/5;
  object-fit: cover;
}

.about-values {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  margin: 64px 0;
}
.about-value {
  border-top: 1px solid var(--ink);
  padding-top: 24px;
}
.about-value__num {
  font-family: var(--font-display);
  font-size: 12px;
  letter-spacing: 0.22em;
  color: var(--bronze-deep);
  display: block;
  margin-bottom: 8px;
}
.about-value__title {
  font-family: var(--font-display);
  font-size: 28px;
  margin: 0 0 12px;
}
.about-value__body { margin: 0; font-size: 15px; color: var(--ink-soft); line-height: 1.65; }

.about-quote {
  background: var(--ink);
  color: var(--cream);
  padding: 80px 48px;
  text-align: center;
  margin: 80px 0 0;
}
.about-quote__text {
  font-family: var(--font-display);
  font-size: clamp(28px, 3vw, 40px);
  line-height: 1.3;
  margin: 0 auto 24px;
  max-width: 720px;
  color: var(--cream);
}
.about-quote__attribution {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 15px;
  color: var(--bronze-soft);
}

@media (max-width: 880px) {
  .about-intro { grid-template-columns: 1fr; gap: 48px; }
  .about-values { grid-template-columns: 1fr; gap: 24px; }
}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 16px;
  margin: 40px 0 80px;
}
.gallery-cell {
  background: var(--cream-deep);
  overflow: hidden;
  position: relative;
}
.gallery-cell img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 600ms var(--ease);
}
.gallery-cell:hover img { transform: scale(1.03); }

.gc--tall  { grid-column: span 4; aspect-ratio: 3/4; }
.gc--wide  { grid-column: span 8; aspect-ratio: 16/10; }
.gc--sq    { grid-column: span 4; aspect-ratio: 1; }
.gc--port  { grid-column: span 6; aspect-ratio: 4/5; }
.gc--land  { grid-column: span 6; aspect-ratio: 5/4; }
.gc--big   { grid-column: span 8; aspect-ratio: 3/2; }
.gc--small { grid-column: span 4; aspect-ratio: 1; }

@media (max-width: 880px) {
  .gallery-grid { grid-template-columns: 1fr 1fr; }
  .gallery-cell { grid-column: span 1 !important; aspect-ratio: 4/5 !important; }
}

/* Placeholder cells for missing photos */
.gallery-cell--ph {
  display: flex; align-items: center; justify-content: center;
  background: var(--cream-soft);
  border: 1px solid var(--line);
  color: var(--ink-faint);
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 15px;
  text-align: center;
  padding: 24px;
}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 64px;
  margin: 32px 0 80px;
}
.contact-card {
  background: var(--cream-soft);
  border: 1px solid var(--line);
  padding: 40px;
}
.contact-card + .contact-card { margin-top: 24px; }
.contact-card__eyebrow {
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--bronze-deep);
}
.contact-card__title {
  font-family: var(--font-display);
  font-size: 32px;
  margin: 8px 0 16px;
}
.contact-card__body { font-size: 15px; color: var(--ink-soft); margin: 0 0 20px; line-height: 1.65; }
.contact-card__rows { display: grid; gap: 4px; }
.contact-card__row {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 16px;
  padding: 10px 0;
  border-bottom: 1px solid var(--line);
  font-size: 15px;
}
.contact-card__row:last-child { border-bottom: none; }
.contact-card__row strong { font-weight: 500; color: var(--ink); }
.contact-card__row span { color: var(--ink-soft); font-variant-numeric: tabular-nums; }
.contact-card__buttons { display: flex; gap: 12px; margin-top: 16px; flex-wrap: wrap; }

.contact-map {
  background: var(--cream-deep);
  border: 1px solid var(--line);
  height: 100%;
  min-height: 480px;
  position: relative;
  overflow: hidden;
}
.contact-map iframe { width: 100%; height: 100%; border: 0; display: block; }

@media (max-width: 880px) {
  .contact-grid { grid-template-columns: 1fr; gap: 32px; }
  .contact-map { min-height: 320px; }
  .contact-card { padding: 28px; }
}
