/* =========================================================================
   One Person Company — Homepage Module
   Uses only tokens defined in /assets/design-system.css.
   No inline colors, no local spacing values — everything via var(--*).
   ========================================================================= */

/* -------------------------------------------------------------------------
   Hero
   ------------------------------------------------------------------------- */
.hero {
  position: relative;
  padding-block: var(--s-32) var(--s-24);
  overflow: hidden;
  isolation: isolate;
}
.hero::before {
  content: "";
  position: absolute;
  inset: -10% -10% auto -10%;
  height: 80%;
  background:
    radial-gradient(60% 60% at 30% 30%, rgba(255,90,31,0.16) 0%, transparent 60%),
    radial-gradient(50% 50% at 80% 20%, rgba(120, 70, 240, 0.10) 0%, transparent 60%);
  filter: blur(40px);
  z-index: -1;
  pointer-events: none;
}
.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse at 50% 0%, black 0%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse at 50% 0%, black 0%, transparent 75%);
  z-index: -1;
  pointer-events: none;
}

.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--s-12);
  align-items: center;
}
@media (min-width: 980px) {
  .hero-grid { grid-template-columns: 1.05fr 0.95fr; gap: var(--s-16); }
}

.hero-copy { display: flex; flex-direction: column; gap: var(--s-6); max-width: 640px; }
.hero h1 {
  font-size: var(--fs-display);
  line-height: var(--lh-display);
  letter-spacing: var(--tracking-display);
  font-weight: var(--weight-semibold);
}
.hero h1 .accent { color: var(--ink); background: linear-gradient(180deg, var(--ink) 0%, #c4c4c8 100%); -webkit-background-clip: text; background-clip: text; color: transparent; }
.hero .lead { max-width: 560px; }
.hero-actions { display: flex; gap: var(--s-3); flex-wrap: wrap; margin-top: var(--s-2); }
.hero-meta {
  display: flex;
  gap: var(--s-6);
  margin-top: var(--s-6);
  padding-top: var(--s-6);
  border-top: 1px solid var(--line);
  color: var(--muted);
  font-size: var(--fs-sm);
  flex-wrap: wrap;
}
.hero-meta b { color: var(--ink); font-weight: var(--weight-semibold); }

/* hero visual — soft "product window" */
.hero-visual {
  position: relative;
  margin: 0;
  background: linear-gradient(180deg, var(--bg-3) 0%, var(--bg-2) 100%);
  border: 1px solid var(--line-2);
  border-radius: var(--r-2xl);
  box-shadow: var(--sh-3);
  overflow: hidden;
}
.hero-visual::before {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,90,31,0.06), transparent 40%);
  pointer-events: none;
}
.win-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 14px;
  border-bottom: 1px solid var(--line);
  background: rgba(255,255,255,0.02);
}
.win-bar span {
  width: 10px; height: 10px; border-radius: 50%;
  background: rgba(255,255,255,0.18);
}
.win-bar span:nth-child(1) { background: #ff5f57; }
.win-bar span:nth-child(2) { background: #febc2e; }
.win-bar span:nth-child(3) { background: #28c840; }
.win-title {
  margin-left: auto;
  color: var(--muted);
  font-size: var(--fs-xs);
  font-family: var(--font-mono);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 60%;
}
.win-body { padding: var(--s-6); display: grid; grid-template-columns: 160px 1fr; gap: var(--s-6); }
.win-side { display: flex; flex-direction: column; gap: 6px; padding-right: var(--s-4); border-right: 1px solid var(--line); }
.win-side .side-head { font-size: var(--fs-xs); color: var(--muted); text-transform: uppercase; letter-spacing: var(--tracking-eyebrow); margin-bottom: 6px; }
.win-side a { display: flex; align-items: center; justify-content: space-between; padding: 8px 10px; border-radius: var(--r-sm); color: var(--ink-2); font-size: var(--fs-sm); }
.win-side a:hover { background: rgba(255,255,255,0.04); color: var(--ink); }
.win-side a.is-active { background: rgba(255,90,31,0.14); color: #ffb18a; }
.win-side a small { color: var(--subtle); font-size: 11px; }

.win-main { display: flex; flex-direction: column; gap: var(--s-4); }
.win-tag { font-size: var(--fs-xs); color: var(--muted); text-transform: uppercase; letter-spacing: var(--tracking-eyebrow); }
.win-h { font-size: 22px; font-weight: var(--weight-semibold); letter-spacing: -0.02em; }
.win-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 6px; }
.win-card { padding: 12px; border: 1px solid var(--line); border-radius: var(--r-md); background: rgba(255,255,255,0.02); }
.win-card b { display: block; color: var(--ink); font-size: 13px; font-weight: var(--weight-semibold); margin-bottom: 2px; }
.win-card span { color: var(--muted); font-size: 12px; }

@media (max-width: 720px) {
  .hero { padding-block: var(--s-16) var(--s-12); }
  .hero h1 { font-size: clamp(40px, 11vw, 56px); }
  .win-body { grid-template-columns: 1fr; }
  .win-side { border-right: 0; border-bottom: 1px solid var(--line); padding: 0 0 var(--s-4); }
}

/* -------------------------------------------------------------------------
   Logo / social proof strip
   ------------------------------------------------------------------------- */
.proof-strip {
  padding-block: var(--s-12);
  border-block: 1px solid var(--line);
  background: var(--bg-2);
}
.proof-inner {
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--gutter);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-8);
  text-align: center;
}
.proof-stat .num { font-size: clamp(28px, 3vw, 36px); font-weight: var(--weight-semibold); letter-spacing: -0.02em; color: var(--ink); display: block; }
.proof-stat .lbl { color: var(--muted); font-size: var(--fs-sm); margin-top: 4px; }
@media (max-width: 720px) {
  .proof-inner { grid-template-columns: 1fr; gap: var(--s-4); }
}

/* -------------------------------------------------------------------------
   Section heading
   ------------------------------------------------------------------------- */
.section-head {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  max-width: 680px;
  margin-bottom: var(--s-12);
}
.section-head.center { margin-inline: auto; text-align: center; align-items: center; }
.section-head .lead { color: var(--ink-2); }

/* -------------------------------------------------------------------------
   Categories grid
   ------------------------------------------------------------------------- */
.cat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--s-4);
}
.cat-card {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  padding: var(--s-6);
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  color: inherit;
  transition: border-color var(--t-base), background var(--t-base), transform var(--t-base);
  position: relative;
  overflow: hidden;
}
.cat-card:hover { border-color: var(--line-strong); background: var(--bg-4); transform: translateY(-2px); }
.cat-card .top { display: flex; align-items: center; justify-content: space-between; gap: var(--s-3); }
.cat-card .num {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--accent);
  background: var(--accent-soft);
  border-radius: var(--r-sm);
  padding: 4px 8px;
  letter-spacing: 0;
}
.cat-card h3 { font-size: 22px; }
.cat-card p { color: var(--ink-2); font-size: var(--fs-sm); line-height: 1.55; flex: 1; }
.cat-card .link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: var(--s-2);
  font-size: var(--fs-sm);
  color: var(--ink);
  font-weight: var(--weight-medium);
}
.cat-card .link::after { content: "→"; transition: transform var(--t-base); }
.cat-card:hover .link::after { transform: translateX(4px); }

/* -------------------------------------------------------------------------
   Featured / split CTA
   ------------------------------------------------------------------------- */
.feature-row {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: var(--s-12);
  align-items: center;
  padding: var(--s-12);
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: var(--r-2xl);
}
@media (max-width: 860px) {
  .feature-row { grid-template-columns: 1fr; padding: var(--s-8); gap: var(--s-6); }
}
.feature-row h2 { font-size: clamp(28px, 3vw, 40px); }
.feature-row .steps { display: grid; gap: 14px; }
.feature-row .step {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  padding: 14px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
}
.feature-row .step .n {
  flex-shrink: 0;
  width: 28px; height: 28px;
  border-radius: var(--r-pill);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--accent-soft);
  color: var(--accent);
  font-weight: var(--weight-semibold);
  font-size: var(--fs-xs);
}
.feature-row .step b { display: block; color: var(--ink); font-weight: var(--weight-semibold); margin-bottom: 2px; }
.feature-row .step span { color: var(--muted); font-size: var(--fs-sm); line-height: 1.5; }

/* -------------------------------------------------------------------------
   Final CTA band
   ------------------------------------------------------------------------- */
.cta-band {
  position: relative;
  text-align: center;
  padding: var(--s-20) var(--gutter);
  background:
    radial-gradient(60% 80% at 50% 0%, rgba(255,90,31,0.16) 0%, transparent 70%),
    var(--bg-2);
  border-block: 1px solid var(--line);
  overflow: hidden;
}
.cta-band h2 { font-size: clamp(32px, 4vw, 56px); max-width: 800px; margin-inline: auto; }
.cta-band p { color: var(--ink-2); max-width: 600px; margin: var(--s-4) auto 0; }
.cta-band .actions { display: inline-flex; gap: var(--s-3); margin-top: var(--s-8); flex-wrap: wrap; justify-content: center; }
