/* ============================================
   HydeJekyll LLC — tokens
   ============================================ */
:root {
  --ink: #15110d;            /* barn-dark, near-black */
  --ink-soft: #241c14;
  --dusk-indigo: #2e3856;
  --ember: #d97d3d;
  --lantern: #c9a24b;
  --parchment: #f3ead2;
  --parchment-dim: #e3d8b8;
  --sage: #5f6b52;

  --font-display: "Fraunces", "Iowan Old Style", Georgia, serif;
  --font-body: "Inter", -apple-system, system-ui, sans-serif;
  --font-mono: "IBM Plex Mono", "SFMono-Regular", monospace;

  --radius: 3px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--parchment);
  color: var(--ink);
  font-family: var(--font-body);
  line-height: 1.55;
}

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

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

/* ============================================
   Hero — POV through open stable doors at dusk
   ============================================ */
.barn-frame {
  position: relative;
  background: var(--ink);
}

.site-header {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 5;
  padding: 1.6rem 2rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.wordmark {
  font-family: var(--font-mono);
  letter-spacing: 0.08em;
  font-size: 0.85rem;
  color: var(--parchment);
  text-transform: uppercase;
}
.wordmark .llc { color: var(--lantern); }

.hero {
  position: relative;
  height: 100vh;
  min-height: 560px;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}

/* Replace with a real photo: background-image: url("assets/hero-stable-dusk.jpg"); */
.hero-sky {
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(ellipse 70% 55% at 50% 62%, rgba(217,125,61,0.55) 0%, rgba(217,125,61,0) 60%),
    linear-gradient(to top, #1a2236 0%, #2e3856 32%, #6b6a7c 55%, #d8a06a 72%, #f3c98b 85%);
  background-size: cover;
  background-position: center;
  /* If a photo is supplied via assets/hero-stable-dusk.jpg, uncomment below and the gradient
     will act purely as a fallback while it loads. */
  /* background-image: url("assets/hero-stable-dusk.jpg"); */
}

.hero-sky::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 90% at 50% 100%, rgba(0,0,0,0) 0%, rgba(0,0,0,0.35) 100%);
}

/* Stable doors framing the view, swung open */
.barn-door {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 22%;
  min-width: 140px;
  background:
    repeating-linear-gradient(
      90deg,
      var(--ink-soft) 0px,
      var(--ink-soft) 26px,
      #1c150e 26px,
      #1c150e 30px
    );
  z-index: 2;
  box-shadow: 0 0 60px 10px rgba(0,0,0,0.6) inset;
}
.barn-door--left {
  left: 0;
  clip-path: polygon(0 0, 100% 0, 78% 100%, 0 100%);
}
.barn-door--right {
  right: 0;
  clip-path: polygon(22% 0, 100% 0, 100% 100%, 0 100%);
}
.barn-door::before {
  content: "";
  position: absolute;
  top: 18%;
  bottom: 18%;
  left: 50%;
  width: 6px;
  background: linear-gradient(var(--lantern), var(--ember));
  opacity: 0.55;
}

.hero-content {
  position: relative;
  z-index: 3;
  text-align: center;
  color: var(--parchment);
  padding: 0 1.5rem 9vh;
  max-width: 620px;
  animation: rise 0.9s ease-out both;
}

.eyebrow {
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 0.72rem;
  color: var(--lantern);
  margin: 0 0 0.9rem;
}

.hero h1 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(2.4rem, 6vw, 4rem);
  margin: 0 0 0.9rem;
  letter-spacing: -0.01em;
}

.tagline {
  font-size: 1.05rem;
  color: var(--parchment-dim);
  margin: 0 0 1.8rem;
}

.scroll-cue {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--lantern);
  padding-bottom: 3px;
  color: var(--lantern);
  transition: opacity 0.2s ease;
}
.scroll-cue:hover { opacity: 0.7; }

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

/* ============================================
   The Stable — company stalls
   ============================================ */
.stable {
  max-width: 1080px;
  margin: 0 auto;
  padding: 6.5rem 2rem 5rem;
}

.section-head {
  text-align: center;
  max-width: 560px;
  margin: 0 auto 3.2rem;
}
.section-head .eyebrow { color: var(--ember); }
.section-head h2 {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 3.4vw, 2.4rem);
  margin: 0 0 0.6rem;
}
.section-sub {
  color: #5a5246;
  margin: 0;
}

.stalls {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 1.6rem;
}

.stall {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid #e6dcc2;
  border-radius: var(--radius);
  overflow: hidden;
}

.plaque {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: center;
  padding: 0.7rem 0.8rem;
  background: var(--ink);
  color: var(--lantern);
}

.stall-door {
  height: 150px;
  background: repeating-linear-gradient(
    90deg,
    var(--dusk-indigo) 0px, var(--dusk-indigo) 22px,
    #25304a 22px, #25304a 25px
  );
  display: flex;
  align-items: center;
  justify-content: center;
}

.brand-mark {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--parchment);
  color: var(--ink);
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.3rem;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 14px rgba(0,0,0,0.35);
}

.stall-desc {
  font-size: 0.92rem;
  color: #43392c;
  padding: 1.1rem 1.2rem 0.4rem;
  margin: 0;
  flex-grow: 1;
}

.latch {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  padding: 1rem 1.2rem 1.2rem;
  color: var(--ember);
  transition: padding-left 0.2s ease;
}
.latch:hover { padding-left: 1.5rem; }

/* Locked / coming-soon stall */
.stall--locked .stall-desc { color: #6b6354; }
.stall-door--locked {
  background: repeating-linear-gradient(
    90deg,
    #3a3a3a 0px, #3a3a3a 22px,
    #2c2c2c 22px, #2c2c2c 25px
  );
}
.lock-icon { width: 28px; height: 28px; opacity: 0.8; }
.latch--muted { color: var(--sage); }

/* ============================================
   Footer
   ============================================ */
footer {
  text-align: center;
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.05em;
  color: #8a8170;
  padding: 2.2rem 1rem 3rem;
}

/* ============================================
   Laboratory (coming soon) page
   ============================================ */
.lab-page {
  min-height: 100vh;
  background: var(--ink);
  color: var(--parchment);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 2rem;
}
.lab-page h1 {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3rem);
  margin: 0.6rem 0;
}
.lab-page p { color: var(--parchment-dim); max-width: 480px; }
.lab-back {
  margin-top: 1.6rem;
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--lantern);
  border-bottom: 1px solid var(--lantern);
  padding-bottom: 3px;
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .hero-content { animation: none; }
}

@media (max-width: 640px) {
  .barn-door { width: 12%; min-width: 60px; }
  .hero-content { padding-bottom: 12vh; }
}
