/* ============================================================
   Empire Premier Properties — shared brand tokens (subset)
   Mirrors brand/tokens.css from the source repo.
   ============================================================ */

:root {
  /* gold */
  --empire-gold:        #C09A05;
  --empire-gold-deep:   #A88404;
  --empire-gold-dark:   #8A6E04;
  --empire-gold-shadow: #6E5703;

  /* neutral spine */
  --empire-black:    #0A0A0A;
  --empire-charcoal: #1C1C1C;
  --empire-ink:      #2D2D2D;
  --empire-graphite: #4A4845;
  --empire-stone:    #8C8780;
  --empire-bone:     #D5CFC2;
  --empire-mist:     #E8E2D5;
  --empire-ivory:    #FBF9F4;
  --empire-sand:     #F5F0E6;

  /* translucents */
  --empire-ivory-90: rgba(251,249,244,.90);
  --empire-ivory-70: rgba(251,249,244,.70);
  --empire-ivory-50: rgba(251,249,244,.50);
  --empire-ivory-15: rgba(251,249,244,.15);
  --empire-black-50: rgba(10,10,10,.50);

  /* type */
  --empire-font: 'Hanken Grotesk', system-ui, sans-serif;
  --empire-track-display:  -0.04em;   /* 64+ */
  --empire-track-headline: -0.03em;   /* 40-56 */
  --empire-track-baseline: -0.02em;   /* 32-39 */
  --empire-track-normal:    0;
  --empire-track-eyebrow:   0.24em;

  /* spacing */
  --empire-space-1: 4px;
  --empire-space-2: 8px;
  --empire-space-3: 12px;
  --empire-space-4: 16px;
  --empire-space-5: 24px;
  --empire-space-6: 32px;
  --empire-space-7: 40px;
  --empire-space-8: 56px;
  --empire-space-9: 80px;
  --empire-space-10: 120px;

  /* radius — luxury reads as crisp corners */
  --empire-radius-none: 0;
  --empire-radius-sm:   2px;
  --empire-radius-md:   4px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--empire-font);
  background: var(--empire-ivory);
  color: var(--empire-ink);
  -webkit-font-smoothing: antialiased;
  line-height: 1.55;
}
img { display: block; max-width: 100%; }
a   { color: inherit; text-decoration: none; }

/* tracked caps — eyebrow / kicker */
.eyebrow {
  font-family: var(--empire-font);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: var(--empire-track-eyebrow);
  text-transform: uppercase;
  color: var(--empire-gold-dark);
  margin-left: calc(var(--empire-track-eyebrow) * -0.5); /* optical-left fix */
  display: inline-block;
}
.eyebrow.on-dark { color: var(--empire-gold); }

/* display tracking helpers */
.t-display  { letter-spacing: var(--empire-track-display); }
.t-headline { letter-spacing: var(--empire-track-headline); }
.t-baseline { letter-spacing: var(--empire-track-baseline); }

/* hairlines */
.rule-gold  { height: 1px; background: var(--empire-gold); border: 0; }
.rule-mist  { height: 1px; background: var(--empire-mist);  border: 0; }
.rule-dark  { height: 1px; background: var(--empire-ivory-15); border: 0; }

/* photo placeholder fallback (for listing tiles when no image set) */
.photo-fallback {
  background:
    linear-gradient(135deg, #E8E2D5 0%, #D5CFC2 60%, #B9B0A0 100%);
  position: relative;
  overflow: hidden;
}
.photo-fallback::after {
  content: attr(data-caption);
  position: absolute;
  left: 16px; bottom: 12px;
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(10,10,10,.45);
  font-weight: 600;
}
