/* ==========================================================================
   Home page — Angell-inspired luxury-editorial.
   Cream/black section rhythm. Type-led hero, satellite capabilities,
   asymmetric bento "Built" row, full-bleed showcase, dark outro.
   Depends on tokens.css + global.css.
   ========================================================================== */

/* Placeholder media zones — clearly designed blocks where Kie.ai assets / real
   screenshots drop in. Remove .media-ph styling once real media lands. */
.media-ph {
  position: relative;
  background:
    repeating-linear-gradient(135deg, oklch(16% 0 0) 0 2px, transparent 2px 18px),
    linear-gradient(150deg, var(--color-black-soft), var(--color-black));
  overflow: hidden;
}
.media-ph::after {
  content: attr(data-ph);
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: ui-monospace, Menlo, Consolas, monospace;
  font-size: var(--text-xs); letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--color-on-dark-muted); text-align: center; padding: var(--space-md);
}

/* ============================ HERO ============================ */
.hero {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  /* Matched to the hero clip's warm-graded studio backdrop so the video sits flush
     with no seam. Sampled corner avg from the warmed 60fps clip: #ECEAD8.
     The warm-tan panel bridges with the cream body (#F4F0E9) — distinct enough
     to read as its own section, close enough to feel continuous. */
  background: #ecead8;
}
.hero__text {
  display: flex; flex-direction: column; justify-content: center;
  padding: clamp(5rem, 4rem + 6vw, 9rem) clamp(1.5rem, 0.5rem + 4vw, 4.5rem) var(--space-xl);
}
.hero__eyebrow { margin-bottom: var(--space-md); }
.hero__title {
  font-size: clamp(2.5rem, 1.4rem + 4.6vw, 5rem);
  margin-bottom: var(--space-lg);
  max-width: 16ch;
}
.hero__sub {
  font-size: var(--text-lg);
  color: var(--color-muted);
  max-width: 46ch;
  line-height: var(--leading-snug);
}
.hero__stats {
  display: flex; flex-wrap: wrap;
  gap: var(--space-xs);
  margin: var(--space-lg) 0 0;
  padding: 0; list-style: none;
}
.hero__stats li {
  display: inline-flex; align-items: baseline; gap: 0.55rem;
  padding: 0.5rem 0.95rem;
  border: 1px solid var(--color-line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.45);
}
.stat__num {
  font-family: var(--font-display);
  font-weight: 700; font-size: var(--text-base);
  letter-spacing: -0.01em;
  color: var(--color-ink);
}
.stat__label {
  font-size: var(--text-xs);
  color: var(--color-muted);
  letter-spacing: 0.02em;
}
/* CTA row sitting under the stats pills. Dark pill against the warm-tan panel
   gives the page its first decisive contrast — easy to find above the fold. */
.hero__cta-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-md);
  margin-top: var(--space-lg);
}
.hero__cta {
  display: inline-block;
  padding: 0.95rem 1.5rem;
  background: var(--color-black);
  color: var(--color-on-dark);
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-base);
  letter-spacing: -0.005em;
  border-radius: 2px;
  text-decoration: none;
  transition: transform 200ms cubic-bezier(0.16, 1, 0.3, 1),
              background-color 200ms ease;
}
.hero__cta:hover,
.hero__cta:focus-visible {
  transform: translateY(-1px);
  background: var(--color-ink);
}
.hero__cta-aside {
  font-size: var(--text-sm);
  color: var(--color-muted);
  line-height: var(--leading-snug);
}
.hero__geo-signal {
  margin-top: var(--space-md);
  font-size: var(--text-sm);
  color: var(--color-muted);
  line-height: var(--leading-snug);
  max-width: 52ch;
}
.hero__media {
  position: relative;
  min-height: 50vh;
  overflow: hidden;
  /* No border, no panel fill — the clip blends into the page so there is no
     visible "video block." The white backdrop dissolves via multiply. */
}
.hero__media .media-ph { position: absolute; inset: 0; }
.hero__video {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  /* The clip is rendered on the same backdrop colour as the page (set on .hero),
     so it sits seamlessly with no blend trick. */
}

/* ============================ CREDIBILITY CALLOUT ============================ */
.credibility {
  background: var(--color-cream);
  padding-block: var(--space-section);
  border-top: var(--border-hair);
  text-align: center;
}
.credibility__head {
  font-size: var(--text-2xl);
  max-width: 22ch;
  margin: 0 auto var(--space-md);
  line-height: var(--leading-tight);
}
.credibility__sub {
  font-size: var(--text-lg);
  color: var(--color-muted);
  max-width: 60ch;
  margin: 0 auto;
  line-height: var(--leading-snug);
}

/* ============================ OPERATOR ============================ */
.operator {
  background: var(--color-cream);
  padding-block: var(--space-section);
  border-top: var(--border-hair);
}
.operator__grid {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: clamp(2rem, 1rem + 3vw, 4.5rem);
  align-items: center;
}
.operator__media {
  margin: 0;
  border-radius: 4px;
  overflow: hidden;
  aspect-ratio: 3 / 4;
  background: var(--color-line);
}
.operator__media img {
  width: 100%; height: 100%; object-fit: cover;
  display: block;
}
.operator__body { max-width: 50ch; }
.operator__body .eyebrow { display: block; margin-bottom: var(--space-md); }
.operator__head {
  font-size: var(--text-2xl);
  margin-bottom: var(--space-sm);
  line-height: var(--leading-tight);
}
.operator__lede {
  font-size: var(--text-lg);
  color: var(--color-ink);
  margin-bottom: var(--space-md);
  font-weight: 500;
}
.operator__body p:not(.operator__lede):not(.eyebrow) {
  font-size: var(--text-base);
  color: var(--color-muted);
  line-height: var(--leading-normal);
  margin-bottom: var(--space-sm);
}
.operator__body p:last-child { margin-bottom: 0; }

/* ============================ SATELLITE ============================ */
.systems {
  background: var(--color-cream);
  padding-block: var(--space-section);
  border-top: var(--border-hair);
}
.systems__head { text-align: center; max-width: 40ch; margin: 0 auto var(--space-xl); }
.systems__title { font-size: var(--text-2xl); margin-bottom: var(--space-sm); }
.systems__intro { color: var(--color-muted); font-size: var(--text-lg); }

.systems__grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-md);
}
.cap {
  display: flex; flex-direction: column;
  padding: var(--space-md) var(--space-sm) var(--space-lg);
  border-top: 2px solid var(--color-ink);
}
.cap__num {
  font-family: ui-monospace, monospace; font-size: var(--text-xs);
  color: var(--color-muted); margin-bottom: var(--space-sm);
}
.cap__label {
  font-family: var(--font-display); font-weight: 700;
  font-size: var(--text-lg); margin-bottom: var(--space-xs);
}
.cap__desc { font-size: var(--text-sm); color: var(--color-muted); line-height: var(--leading-normal); }

/* ============================ BENTO "BUILT" ============================ */
.built {
  background: var(--color-cream);
  padding-block: var(--space-section);
  border-top: var(--border-hair);
}
.built__head {
  display: flex; align-items: baseline; justify-content: space-between;
  flex-wrap: wrap; gap: var(--space-sm); margin-bottom: var(--space-xl);
}
.built__title { font-size: var(--text-2xl); }
.built__link { font-size: var(--text-sm); border-bottom: 1px solid currentColor; padding-bottom: 2px; }

.bento {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: clamp(13rem, 9rem + 12vw, 20rem);
  gap: var(--space-md);
}
.bento__card {
  position: relative; display: block;
  border-radius: var(--radius); overflow: hidden;
  background: #0f0f0f;
  color: var(--color-on-dark);
}
.bento__card--a { grid-column: span 4; }
.bento__card--b { grid-column: span 2; }
.bento__card--c { grid-column: span 2; }
.bento__card--d { grid-column: span 4; }
.bento__card .media-ph { position: absolute; inset: 0; }
.bento__image {
  position: absolute; inset: 0; z-index: 1;
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform var(--duration-slow) var(--ease-out-expo);
}
.bento__overlay {
  position: absolute; inset: 0; z-index: 2;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: var(--space-md);
  background: linear-gradient(to top, rgba(0, 0, 0, 0.80) 0%, rgba(0, 0, 0, 0) 45%);
}
.bento__label {
  font-family: var(--font-display); font-weight: 600;
  font-size: var(--text-lg); line-height: var(--leading-snug);
  color: var(--color-on-dark);
  transform: translateY(0);
  transition: transform var(--duration-normal) var(--ease-out-expo);
}
.bento__card:hover .bento__image { transform: scale(1.03); }
.bento__card:hover .bento__label { transform: translateY(-4px); }
.bento__card:focus-visible { outline: 2px solid var(--color-cream); outline-offset: 3px; }

/* --- Logo workflow diagrams inside dark bento cards --- */
.flow {
  display: flex; align-items: center; justify-content: center;
  gap: clamp(0.4rem, 0.2rem + 0.5vw, 0.8rem);
  width: 100%; max-width: 100%;
  flex-wrap: nowrap;
}
.flow__icon {
  display: flex; align-items: center; justify-content: center;
  width: clamp(2.2rem, 1.6rem + 1.3vw, 3rem);
  height: clamp(2.2rem, 1.6rem + 1.3vw, 3rem);
  border: 1px solid rgba(232, 232, 229, 0.18);
  border-radius: 8px;
  background: rgba(232, 232, 229, 0.04);
  flex: 0 0 auto;
}
.flow__glyph {
  display: block;
  width: 55%; height: 55%;
  background-color: var(--color-on-dark);
  -webkit-mask: var(--icon, none) center / contain no-repeat;
          mask: var(--icon, none) center / contain no-repeat;
}
/* n8n shown as a text wordmark instead of SVG (more reliable across browsers) */
.flow__icon--text {
  font-family: var(--font-display); font-weight: 700;
  font-size: 0.78rem;
  color: var(--color-on-dark);
  letter-spacing: -0.02em;
}
.flow__line {
  flex: 1; height: 1px;
  background: linear-gradient(to right, rgba(232, 232, 229, 0.05) 0%, rgba(232, 232, 229, 0.32) 50%, rgba(232, 232, 229, 0.05) 100%);
  min-width: 0.8rem; max-width: 4rem;
}
.flow__stack {
  display: flex; flex-direction: column;
  gap: 0.45rem;
}
.flow__stack .flow__icon { width: 1.9rem; height: 1.9rem; }
.flow__frame {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, auto);
  gap: 0.7rem;
  padding: clamp(0.9rem, 0.5rem + 1.2vw, 1.5rem);
  border: 1px solid rgba(232, 232, 229, 0.22);
  border-radius: 12px;
  align-items: center; justify-items: center;
}
.flow__frame .flow__icon { width: 2rem; height: 2rem; }

/* Icon mask sources */
.icon-gmail      { --icon: url('/media/icons/gmail.svg'); }
.icon-instagram  { --icon: url('/media/icons/instagram.svg'); }
.icon-discord    { --icon: url('/media/icons/discord.svg'); }
.icon-claude     { --icon: url('/media/icons/anthropic.svg'); }
.icon-openai     { --icon: url('/media/icons/openai.svg'); }
.icon-meta       { --icon: url('/media/icons/meta.svg'); }
.icon-quickbooks { --icon: url('/media/icons/quickbooks.svg'); }
.icon-intuit     { --icon: url('/media/icons/intuit.svg'); }

/* ============================ SHOWCASE ============================ */
.showcase { background: var(--color-cream); padding-block: var(--space-section) 0; }
.showcase__media {
  position: relative; width: 100%;
  aspect-ratio: 16 / 7; min-height: 18rem;
  border-radius: var(--radius); overflow: hidden;
}
.showcase__media .media-ph { position: absolute; inset: 0; }
.showcase__caption {
  text-align: center; max-width: 52ch; margin: var(--space-lg) auto 0;
  font-family: var(--font-display); font-weight: 500;
  font-size: var(--text-xl); line-height: var(--leading-snug);
}
.showcase__eyebrow { display: block; text-align: center; margin-top: var(--space-section); }

/* ============================ PROCESS ============================ */
.process {
  background: var(--color-cream);
  padding-block: var(--space-section);
  border-top: var(--border-hair);
}
.process__intro {
  margin-bottom: var(--space-xl);
  max-width: 40ch;
}
.process__intro .eyebrow { display: block; margin-bottom: var(--space-xs); }
.process__head {
  font-size: var(--text-2xl);
  line-height: var(--leading-tight);
}
.process__grid {
  list-style: none; padding: 0; margin: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-lg);
}
.step {
  padding-top: var(--space-md);
  border-top: 2px solid var(--color-ink);
}
.step__num {
  display: block;
  font-family: ui-monospace, Menlo, Consolas, monospace;
  font-size: var(--text-xs);
  color: var(--color-muted);
  margin-bottom: var(--space-sm);
}
.step__head {
  font-family: var(--font-display); font-weight: 700;
  font-size: var(--text-lg);
  margin: 0 0 var(--space-xs);
  line-height: var(--leading-snug);
}
.step p {
  font-size: var(--text-sm);
  color: var(--color-muted);
  line-height: var(--leading-normal);
}

/* ============================ OUTRO ============================ */
.outro {
  background: var(--color-black);
  color: var(--color-on-dark);
  padding-block: var(--space-section);
  margin-top: var(--space-section);
}
.outro__inner { max-width: 30ch; }
.outro__eyebrow { color: var(--color-on-dark-muted); margin-bottom: var(--space-md); }
.outro__title { font-size: var(--text-2xl); margin-bottom: var(--space-md); }
.outro__text { font-size: var(--text-lg); color: var(--color-on-dark-muted); margin-bottom: var(--space-lg); max-width: 40ch; }
.outro__cta {
  display: inline-flex; align-items: center; gap: 0.5em;
  font-family: var(--font-display); font-weight: 600; font-size: var(--text-lg);
  color: var(--color-black); background: var(--color-cream);
  padding: var(--space-sm) var(--space-lg); border-radius: var(--radius);
  transition: transform var(--duration-fast) var(--ease-out-expo);
}
.outro__cta:hover { transform: translateY(-3px); }
.outro__cta:focus-visible { outline: 2px solid var(--color-cream); outline-offset: 3px; }

/* ============================ RESPONSIVE ============================ */
@media (max-width: 900px) {
  .hero { grid-template-columns: 1fr; min-height: auto; }
  .hero__media { min-height: 42vh; }
  .systems__grid { grid-template-columns: repeat(2, 1fr); }
  .bento { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 14rem; }
  .bento__card--a, .bento__card--b, .bento__card--c, .bento__card--d { grid-column: span 1; }
  .operator__grid { grid-template-columns: 1fr; }
  .operator__media { max-width: 26rem; }
  .process__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px) {
  .systems__grid { grid-template-columns: 1fr; }
  .bento { grid-template-columns: 1fr; }
  .process__grid { grid-template-columns: 1fr; }
}
