/* plugbloom — home page layout (scoped to .page-home) */

.page-home .hero { padding-top: clamp(1.5rem, 4vw, 3.5rem); padding-bottom: clamp(3.5rem, 7vw, 6rem); position: relative; }
.page-home .hero__inner { display: grid; grid-template-columns: 1.04fr .96fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: center; }
.page-home .hero__copy { position: relative; z-index: 2; max-width: 36rem; }
.page-home .hero h1 { font-size: var(--fs-hero); margin: 1.2rem 0 0; }
.page-home .hero h1 .grow { position: relative; white-space: nowrap; }
.page-home .hero h1 .grow::after { content: ""; position: absolute; left: 0; right: 0; bottom: .08em; height: .14em; background: var(--mint); border-radius: 2px; z-index: -1; transform: scaleX(0); transform-origin: left; animation: underlineGrow 1s var(--ease) .5s forwards; }
@keyframes underlineGrow { to { transform: scaleX(1); } }
.page-home .hero .lead { margin-top: 1.4rem; max-width: 34ch; }
.page-home .hero__actions { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: 1.9rem; }

.page-home .trust { display: flex; flex-wrap: wrap; gap: .5rem 1.4rem; margin-top: 2.2rem; padding-top: 1.6rem; border-top: 1px solid var(--line); }
.page-home .trust span { display: inline-flex; align-items: center; gap: .5em; font-family: var(--font-mono); font-size: var(--fs-mono); letter-spacing: .08em; text-transform: uppercase; color: var(--ink-3); }
.page-home .trust span::before { content: ""; width: 5px; height: 5px; border-radius: 50%; background: var(--mint-ink); }

/* hero visual — the product, framed as a living specimen */
.page-home .hero__visual { position: relative; z-index: 1; }
.page-home .hero__bloom { position: absolute; z-index: 0; top: -13%; right: -7%; width: min(56%, 290px); color: var(--mint-ink); opacity: .16; pointer-events: none; }
.page-home .frame {
  position: relative; z-index: 1; border-radius: 16px; background: #060A0E;
  border: 1px solid rgba(255,255,255,.08); box-shadow: 0 2px 4px rgba(12,26,20,.1), 0 50px 80px -40px rgba(12,26,20,.5);
  overflow: hidden; transform: rotate(-1.1deg); transition: transform .6s var(--ease);
}
.page-home .hero__visual:hover .frame { transform: rotate(0); }
.page-home .frame__bar { display: flex; align-items: center; gap: .5rem; padding: .7rem .9rem; border-bottom: 1px solid rgba(255,255,255,.07); }
.page-home .frame__bar i { width: 10px; height: 10px; border-radius: 50%; background: rgba(255,255,255,.16); display: block; }
.page-home .frame__bar .u { margin-left: .6rem; font-family: var(--font-mono); font-size: .68rem; letter-spacing: .06em; color: rgba(243,245,241,.42); }
.page-home .frame__shot { display: block; width: 100%; height: 420px; object-fit: cover; object-position: top center; }
.page-home .live-badge {
  position: absolute; z-index: 2; top: 1rem; right: 1rem;
  display: inline-flex; align-items: center; gap: .5em; padding: .45em .8em; border-radius: 100px;
  background: rgba(6,10,14,.78); backdrop-filter: blur(6px); border: 1px solid rgba(22,226,160,.4);
  font-family: var(--font-mono); font-size: .66rem; letter-spacing: .16em; text-transform: uppercase; color: var(--mint);
}
.page-home .live-badge .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--mint); box-shadow: 0 0 0 3px rgba(22,226,160,.25); animation: pulse 2.4s var(--ease) infinite; }
.page-home .chip {
  position: absolute; z-index: 2; left: -1.4rem; bottom: 2rem; padding: .7rem .9rem;
  background: var(--paper); border: 1px solid var(--line); border-radius: 12px; box-shadow: var(--shadow);
  font-family: var(--font-mono); font-size: .72rem;
}
.page-home .chip b { display: block; font-family: var(--font-display); font-size: 1.5rem; color: var(--mint-ink); letter-spacing: -0.02em; }
.page-home .chip span { color: var(--ink-3); letter-spacing: .08em; text-transform: uppercase; font-size: .6rem; }

/* collection */
.page-home .collection__head { display: flex; align-items: flex-end; justify-content: space-between; gap: 2rem; flex-wrap: wrap; margin-bottom: 2.4rem; }
.page-home .collection__head h2 { font-size: var(--fs-h2); }

/* principles — a real, ordered way of working, so numbering carries meaning */
.page-home .principles { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: var(--r-plate); overflow: hidden; margin-top: 2.6rem; }
.page-home .principle { background: var(--paper); padding: 2rem clamp(1.5rem,2.5vw,2.4rem); }
.page-home .principle__n { font-family: var(--font-mono); font-size: var(--fs-mono); letter-spacing: .12em; color: var(--mint-ink); }
.page-home .principle h3 { font-size: 1.4rem; margin: .9rem 0 .5rem; }
.page-home .principle p { color: var(--ink-2); font-size: var(--fs-sm); }

/* featured (dark) */
.page-home .featured__inner { display: grid; grid-template-columns: .92fr 1.08fr; gap: clamp(2rem,5vw,4rem); align-items: center; }
.page-home .featured__copy { max-width: 40ch; }
.page-home .featured h2 { font-size: var(--fs-h2); margin: 1rem 0 0; }
.page-home .featured ul.checks { margin: 1.6rem 0; display: grid; gap: .7rem; }
.page-home .featured ul.checks li { display: flex; gap: .7rem; align-items: flex-start; color: rgba(243,245,241,.82); font-size: var(--fs-sm); }
.page-home .featured ul.checks li::before { content: "✦"; color: var(--mint); flex: none; }
.page-home .featured__actions { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: 1.4rem; }
.page-home .featured__shot { border-radius: 14px; overflow: hidden; border: 1px solid rgba(255,255,255,.1); box-shadow: 0 50px 90px -50px rgba(0,0,0,.8); }
.page-home .featured__shot img { width: 100%; height: auto; display: block; }

/* updates */
.page-home .updates__inner { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,5vw,4rem); align-items: center; }
.page-home .updates h2 { font-size: var(--fs-h2); margin-top: 1rem; }

@media (max-width: 940px) {
  .page-home .hero__inner { grid-template-columns: 1fr; gap: 3rem; }
  .page-home .hero__visual { order: 2; }
  .page-home .hero__bloom { top: -18%; right: -6%; width: 360px; }
  .page-home .frame { transform: none; }
  .page-home .featured__inner, .page-home .updates__inner { grid-template-columns: 1fr; }
  .page-home .chip { left: 1rem; }
}
@media (max-width: 560px) {
  .page-home .principles { grid-template-columns: 1fr; }
  .page-home .frame__shot { height: 320px; }
}
