/* ============================================================
   Home (dark v2)
   ============================================================ */

/* ---------- Hero ---------- */
.hero { position: relative; overflow: hidden; padding-top: clamp(36px, 5vw, 72px); }
.hero-inner { position: relative; z-index: 1; display: grid; grid-template-columns: 1.04fr 0.96fr; gap: 48px; align-items: center; padding-block: clamp(30px, 5vw, 64px); }
.hero-copy { max-width: 600px; }
.hero h1 { margin-bottom: 24px; }
.hero h1 .grad-text { display: inline; }
.hero-sub { display: flex; align-items: center; gap: 18px; margin-top: 40px; flex-wrap: wrap; }
.trust-row { display: flex; align-items: center; gap: 22px; margin-top: 44px; padding-top: 26px; border-top: 1px solid var(--line-soft); flex-wrap: wrap; }
.trust-row .tr-label { font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--faint); }
.trust-brands { display: flex; gap: 18px; flex-wrap: wrap; }
.trust-brands span { font-family: var(--font-display); font-weight: 600; font-size: 0.92rem; color: var(--muted); letter-spacing: -0.02em; }

/* Hero visual = Hermes console */
.hero-visual { position: relative; }
.hero-visual .mock { transform: perspective(1600px) rotateY(-7deg) rotateX(2deg); transition: transform 0.6s var(--ease); }
.hero-visual:hover .mock { transform: perspective(1600px) rotateY(-3deg) rotateX(1deg); }
.hero-visual .mock-badge.b1 { top: -18px; right: 18px; }
.hero-visual .mock-badge.b2 { bottom: 40px; left: -26px; }
@media (max-width: 960px) { .hero-visual .mock { transform: none; } .hero-visual .mock-badge { display: none; } }

/* ---------- Marquee ---------- */
.hero-marquee { position: relative; z-index: 1; border-top: 1px solid var(--line-soft); border-bottom: 1px solid var(--line-soft); padding-block: 18px; overflow: hidden; margin-top: 24px; }
.marquee-track { display: flex; gap: 26px; align-items: center; width: max-content; animation: marquee 40s linear infinite; }
.marquee-track span { font-family: var(--font-mono); font-size: 0.82rem; letter-spacing: 0.06em; color: var(--muted); text-transform: uppercase; white-space: nowrap; }
.marquee-track span:nth-child(even) { color: var(--blue-2); opacity: 0.6; }
@keyframes marquee { to { transform: translateX(-50%); } }

/* ---------- Cards w/ number ---------- */
.card-num { font-family: var(--font-mono); font-size: 0.8rem; color: var(--blue-2); margin-bottom: 18px; letter-spacing: 0.08em; }
.card h3 { margin-bottom: 12px; }
.card p { color: var(--muted); font-size: 0.98rem; }
.card-ico { width: 48px; height: 48px; border-radius: 13px; display: grid; place-items: center; margin-bottom: 20px; background: var(--grad-soft); border: 1px solid var(--line); color: var(--blue-2); }
.card-ico svg { width: 23px; height: 23px; }

/* ---------- Engine flow ---------- */
.engine-flow { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; position: relative; }
.engine-flow::before { content: ""; position: absolute; top: 46px; left: 8%; right: 8%; height: 1px; background: linear-gradient(90deg, transparent, var(--line-bright), transparent); z-index: 0; }
.flow-step { position: relative; z-index: 1; background: linear-gradient(180deg, var(--surface), oklch(0.175 0.02 264)); border: 1px solid var(--line); border-radius: var(--radius); padding: 26px 22px; transition: transform 0.35s var(--ease), border-color 0.3s; }
.flow-step:hover { transform: translateY(-4px); border-color: var(--line-bright); }
.flow-ico { width: 50px; height: 50px; border-radius: 14px; background: var(--grad-soft); border: 1px solid var(--line-bright); display: grid; place-items: center; color: var(--blue-2); margin-bottom: 18px; box-shadow: 0 8px 24px oklch(0.55 0.16 256 / 0.2); }
.flow-ico svg { width: 24px; height: 24px; }
.flow-kicker { font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--faint); }
.flow-step h3 { margin: 6px 0 9px; }
.flow-step p { color: var(--muted); font-size: 0.92rem; }
.engine-foot { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; margin-top: 50px; padding-top: 44px; border-top: 1px solid var(--line-soft); }
.ef-item p { color: var(--muted); font-size: 0.9rem; margin-top: 8px; max-width: 22ch; }

/* ---------- AI for your business (SMB) ---------- */
.agents-head { display: grid; grid-template-columns: 1.2fr 0.8fr; gap: 40px; align-items: end; margin-bottom: 48px; }
.agents-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.agent-card { position: relative; padding: 28px; border-radius: var(--radius-lg); background: linear-gradient(180deg, var(--surface), oklch(0.175 0.02 264)); border: 1px solid var(--line); overflow: hidden; transition: transform 0.4s var(--ease), border-color 0.3s, box-shadow 0.4s; }
.agent-card::before { content: ""; position: absolute; top: -40%; right: -20%; width: 180px; height: 180px; border-radius: 50%; background: radial-gradient(circle, oklch(0.62 0.17 256 / 0.18), transparent 70%); opacity: 0; transition: opacity 0.4s; }
.agent-card:hover { transform: translateY(-5px); border-color: var(--line-bright); box-shadow: var(--shadow-md); }
.agent-card:hover::before { opacity: 1; }
.agent-ico { width: 46px; height: 46px; border-radius: 12px; display: grid; place-items: center; margin-bottom: 18px; background: var(--grad-soft); border: 1px solid var(--line-bright); color: var(--blue-2); position: relative; }
.agent-ico svg { width: 22px; height: 22px; }
.agent-card h3 { font-size: 1.18rem; margin-bottom: 9px; position: relative; }
.agent-card p { color: var(--muted); font-size: 0.93rem; position: relative; }
.agent-card .agent-tags { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 16px; position: relative; }
.agent-tags small { font-family: var(--font-mono); font-size: 0.62rem; color: var(--faint); padding: 3px 8px; border-radius: 6px; border: 1px solid var(--line-soft); }
.smb-banner { margin-top: 28px; display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; padding: 26px 30px; border-radius: var(--radius-lg); background: var(--grad-soft); border: 1px solid var(--line-bright); }
.smb-banner p { color: var(--ink-2); }
.smb-banner strong { color: var(--ink); font-family: var(--font-display); }

/* ---------- Portfolio ---------- */
.portfolio-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; }
.vcard { display: flex; flex-direction: column; background: linear-gradient(180deg, var(--surface), oklch(0.175 0.02 264)); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 32px; transition: transform 0.4s var(--ease), box-shadow 0.4s, border-color 0.3s; position: relative; overflow: hidden; }
.vcard::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--accent); transform: scaleX(0); transform-origin: left; transition: transform 0.45s var(--ease); }
.vcard:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); border-color: var(--line-bright); }
.vcard:hover::before { transform: scaleX(1); }
.vcard-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; }
.vcard-mark { width: 50px; height: 50px; border-radius: 14px; background: var(--accent); color: #fff; display: grid; place-items: center; font-family: var(--font-display); font-weight: 700; font-size: 1.35rem; box-shadow: 0 10px 26px color-mix(in oklab, var(--accent), transparent 55%); }
.vcard h3 { margin-bottom: 2px; }
.vcard-domain { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.08em; text-transform: uppercase; color: color-mix(in oklab, var(--accent), white 25%); margin-bottom: 14px; }
.vcard p:not(.vcard-domain) { color: var(--muted); font-size: 0.96rem; margin-bottom: 20px; flex: 1; }
.vcard .link-arrow { color: color-mix(in oklab, var(--accent), white 25%); }
.next-up { display: flex; align-items: center; gap: 22px; flex-wrap: wrap; margin-top: 34px; padding: 22px 26px; background: oklch(0.5 0.04 264 / 0.08); border: 1px solid var(--line-soft); border-radius: var(--radius); }
.next-tags { display: flex; gap: 10px; flex-wrap: wrap; }

/* ---------- Split / model ---------- */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(36px, 6vw, 80px); align-items: center; }
.split-copy h2 { margin: 18px 0; }
.check-list { list-style: none; display: flex; flex-direction: column; gap: 13px; }
.check-list li { display: flex; gap: 12px; align-items: flex-start; font-size: 1rem; color: var(--ink-2); font-weight: 500; }
.check-list svg { width: 19px; height: 19px; flex: none; margin-top: 3px; color: var(--green); background: oklch(0.72 0.17 155 / 0.16); border-radius: 50%; padding: 3px; }

/* Stack diagram */
.stack-diagram { background: linear-gradient(180deg, var(--surface), oklch(0.175 0.02 264)); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 26px; box-shadow: var(--shadow-lg); }
.stack-apps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.stack-apps span { font-family: var(--font-display); font-weight: 600; font-size: 0.82rem; text-align: center; padding: 14px 6px; border-radius: 10px; color: #fff; background: var(--c); letter-spacing: -0.02em; box-shadow: 0 6px 18px color-mix(in oklab, var(--c), transparent 60%); }
.stack-label { font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--faint); text-align: center; margin: 14px 0; }
.stack-core { display: flex; flex-direction: column; gap: 8px; padding: 16px; border-radius: 14px; background: var(--grad-soft); border: 1px solid var(--line-bright); }
.sc-row span { display: block; font-size: 0.86rem; font-weight: 500; color: var(--ink); padding: 11px 14px; background: oklch(0.5 0.05 264 / 0.18); border: 1px solid var(--line-soft); border-radius: 9px; }

/* ---------- Industries ---------- */
.ind-grid { gap: 18px; }
.ind { padding: 26px; border: 1px solid var(--line); border-radius: var(--radius); background: linear-gradient(180deg, var(--surface), oklch(0.175 0.02 264)); transition: border-color 0.3s, transform 0.3s; }
.ind:hover { border-color: var(--line-bright); transform: translateY(-3px); }
.ind-tag { display: inline-block; font-family: var(--font-display); font-weight: 600; font-size: 1.05rem; letter-spacing: -0.02em; margin-bottom: 8px; color: var(--ink); }
.ind p { color: var(--muted); font-size: 0.94rem; }

/* ---------- Case study teaser ---------- */
.cs-teaser { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(30px, 5vw, 64px); align-items: center; }
.cs-copy h2 { margin: 16px 0; }
.cs-stats { display: flex; gap: 40px; margin: 28px 0 4px; }
.cs-stats span { display: block; font-size: 0.86rem; color: var(--muted); margin-top: 4px; max-width: 16ch; }

/* ---------- CTA band ---------- */
.cta-band { padding-block: clamp(80px, 10vw, 140px); position: relative; overflow: hidden; text-align: center; }
.cta-band::before { content: ""; position: absolute; inset: 0; z-index: -1; background: radial-gradient(60% 80% at 50% 0%, oklch(0.5 0.17 270 / 0.35), transparent 65%); }
.cta-inner { position: relative; max-width: 760px; margin: 0 auto; }
.cta-phi { font-family: var(--font-display); font-weight: 700; font-size: 3.6rem; background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent; display: block; margin-bottom: 14px; }
.cta-inner h2 { margin-bottom: 18px; }
.cta-inner .lede { color: var(--muted); }

/* ---------- Responsive ---------- */
@media (max-width: 960px) {
  .hero-inner { grid-template-columns: 1fr; }
  .hero-visual { order: 2; margin-top: 10px; }
  .engine-flow { grid-template-columns: 1fr 1fr; }
  .engine-flow::before { display: none; }
  .engine-foot { grid-template-columns: repeat(2, 1fr); }
  .agents-head { grid-template-columns: 1fr; }
  .agents-grid { grid-template-columns: 1fr 1fr; }
  .split { grid-template-columns: 1fr; }
  .portfolio-grid { grid-template-columns: 1fr; }
  .cs-teaser { grid-template-columns: 1fr; }
  .cs-visual { order: -1; }
}
@media (max-width: 620px) {
  .engine-flow, .agents-grid, .engine-foot { grid-template-columns: 1fr; }
  .cs-stats { gap: 24px; }
}
