/* ============================================================
   ENERSCRIPT — Components (hero, marquee, process, etc.)
   ============================================================ */

/* ---------- Hero ---------- */
.hero {
  position: relative;
  padding-top: clamp(8rem, 16vh, 12rem);
  padding-bottom: clamp(4rem, 8vw, 7rem);
  overflow: hidden;
}
.hero-bg { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
.hero-grid {
  position: absolute; inset: -2px;
  background-image:
    linear-gradient(to right, oklch(0.17 0.02 265 / 0.045) 1px, transparent 1px),
    linear-gradient(to bottom, oklch(0.17 0.02 265 / 0.045) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(120% 90% at 70% 0%, #000 30%, transparent 78%);
  -webkit-mask-image: radial-gradient(120% 90% at 70% 0%, #000 30%, transparent 78%);
}
.hero-orb {
  position: absolute; top: -18%; right: -8%;
  width: 60vw; max-width: 760px; aspect-ratio: 1;
  background: radial-gradient(circle at 50% 50%, oklch(0.56 0.19 264 / 0.20), transparent 62%);
  border-radius: 50%;
  filter: blur(8px);
  transition: transform 0.6s var(--ease-out);
}
.hero-orb.two {
  top: auto; bottom: -28%; right: auto; left: -12%;
  width: 46vw; max-width: 560px;
  background: radial-gradient(circle at 50% 50%, oklch(0.80 0.14 200 / 0.16), transparent 62%);
}
.hero .wrap { position: relative; z-index: 1; }
.hero h1 { max-width: 16ch; }
.hero .lead { max-width: 50ch; margin-top: var(--s-5); font-size: clamp(1.12rem, 1.6vw, 1.45rem); }
.hero-actions { margin-top: var(--s-6); }
.hero-meta { margin-top: var(--s-7); display: flex; align-items: center; gap: clamp(1.2rem,3vw,2.4rem); flex-wrap: wrap; color: var(--text-soft); }
.hero-meta .rule { width: 1px; height: 34px; background: var(--line); }
.stars { color: var(--accent); letter-spacing: 0.1em; }

/* rotator */
.rot {
  position: relative; display: inline-block;
  color: var(--accent);
}
.rot-word { display: inline-block; transition: transform 0.42s var(--ease), opacity 0.42s var(--ease); }
.rot-word.out { transform: translateY(-0.55em) rotateX(40deg); opacity: 0; }
.rot-word.in-word { animation: rotIn 0.5s var(--ease); }
@keyframes rotIn { from { transform: translateY(0.55em); opacity: 0; } to { transform: none; opacity: 1; } }

/* ---------- Marquee ---------- */
.marquee { overflow: hidden; -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); }
.marquee-track { display: flex; gap: 0; width: max-content; animation: marquee 38s linear infinite; }
.marquee:hover .marquee-track { animation-play-state: paused; }
@keyframes marquee { to { transform: translateX(-50%); } }
.chip {
  display: inline-flex; align-items: center; gap: 0.6em;
  padding: 0.7em 1.4em; margin: 0 0.5rem;
  font-family: "JetBrains Mono", monospace; font-size: 0.9rem; font-weight: 500;
  white-space: nowrap; color: var(--text-soft);
  border: 1px solid var(--line); border-radius: 100px;
  background: var(--paper);
}
.chip .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent); }
.dark .chip { background: var(--ink-2); border-color: var(--ink-3); color: var(--on-dark-soft); }
.dark .chip .dot { background: var(--signal); }
@media (prefers-reduced-motion: reduce) { .marquee-track { animation: none; flex-wrap: wrap; width: auto; justify-content: center; } }

/* ---------- Value props (expect) ---------- */
.expect { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border: 1px solid var(--line); border-radius: var(--radius-lg); overflow: hidden; background: var(--paper); }
.expect > div { padding: clamp(1.8rem, 3vw, 2.6rem); border-right: 1px solid var(--line); transition: background 0.4s var(--ease); }
.expect > div:last-child { border-right: none; }
.expect > div:hover { background: var(--paper-2); }
.expect .big { font-family: "Space Grotesk"; font-size: clamp(2.4rem, 4vw, 3.4rem); font-weight: 600; letter-spacing: -0.03em; line-height: 1; color: var(--accent); }
.expect h3 { margin: 1rem 0 0.5rem; }
.expect p { color: var(--text-soft); }
@media (max-width: 820px) { .expect { grid-template-columns: 1fr; } .expect > div { border-right: none; border-bottom: 1px solid var(--line); } .expect > div:last-child { border-bottom: none; } }

/* ---------- Services list ---------- */
.svc-row {
  display: grid; grid-template-columns: 0.5fr 1.4fr 1fr auto; gap: var(--s-4);
  align-items: start; padding: clamp(1.6rem, 3vw, 2.4rem) 0;
  border-top: 1px solid var(--line);
  transition: padding-left 0.4s var(--ease);
}
.svc-row:last-child { border-bottom: 1px solid var(--line); }
.svc-row:hover { padding-left: 0.6rem; }
.svc-row .svc-no { font-family: "JetBrains Mono", monospace; color: var(--text-faint); font-size: 0.85rem; padding-top: 0.4em; }
.svc-row h3 { font-size: clamp(1.5rem, 2.4vw, 2.1rem); }
.svc-row p { color: var(--text-soft); }
.svc-row .svc-tags { display: flex; flex-wrap: wrap; gap: 0.4rem; }
.svc-tag { font-family: "JetBrains Mono", monospace; font-size: 0.72rem; padding: 0.3em 0.7em; border: 1px solid var(--line); border-radius: 100px; color: var(--text-soft); white-space: nowrap; }
.svc-row .svc-go { width: 46px; height: 46px; border-radius: 50%; display: grid; place-items: center; box-shadow: inset 0 0 0 1.5px var(--line); transition: 0.4s var(--ease); align-self: center; }
.svc-row:hover .svc-go { background: var(--accent); color: var(--paper); box-shadow: none; transform: rotate(-45deg); }
@media (max-width: 860px) {
  .svc-row { grid-template-columns: auto 1fr; }
  .svc-row .svc-desc { grid-column: 1 / -1; }
  .svc-row .svc-go { display: none; }
}

/* ---------- Process ---------- */
.process-track { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-4); counter-reset: step; }
.step {
  position: relative; padding: var(--s-5) var(--s-4); border-radius: var(--radius-lg);
  background: var(--ink-2); border: 1px solid var(--ink-3);
  opacity: 0.5; transform: translateY(10px);
  transition: opacity 0.6s var(--ease), transform 0.6s var(--ease), background 0.4s, border-color 0.4s;
}
.step.step-on { opacity: 1; transform: none; }
.step:hover { background: oklch(0.26 0.03 265); border-color: var(--accent); }
.step .step-no { font-family: "JetBrains Mono", monospace; font-size: 0.78rem; color: var(--signal); letter-spacing: 0.15em; }
.step h3 { color: var(--on-dark); margin: 0.7rem 0 0.5rem; font-size: 1.3rem; }
.step p { color: var(--on-dark-soft); font-size: 0.96rem; }
.step .bar { height: 2px; background: var(--ink-3); margin-top: 1.4rem; border-radius: 2px; overflow: hidden; }
.step .bar::after { content: ""; display: block; height: 100%; width: 0; background: linear-gradient(90deg, var(--accent), var(--signal)); transition: width 1s var(--ease) 0.2s; }
.step.step-on .bar::after { width: 100%; }
@media (max-width: 900px) { .process-track { grid-template-columns: 1fr; } }

/* ---------- Work cards ---------- */
.work-card { display: block; border-radius: var(--radius-lg); overflow: hidden; background: var(--paper); border: 1px solid var(--line); transition: transform 0.5s var(--ease), box-shadow 0.5s var(--ease); }
.work-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-2); }
.work-card .ph { border-radius: 0; border: none; border-bottom: 1px solid var(--line); aspect-ratio: 16/10; }
.work-card .work-body { padding: 1.4rem 1.6rem 1.7rem; }
.work-card .work-tag { font-family: "JetBrains Mono", monospace; font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); }
.work-card h3 { margin: 0.5rem 0; }
.work-card .work-go { display: inline-flex; align-items: center; gap: 0.4em; color: var(--text-soft); font-weight: 600; font-size: 0.92rem; margin-top: 0.4rem; transition: gap 0.3s; }
.work-card:hover .work-go { gap: 0.8em; color: var(--accent); }

/* ---------- Stats band ---------- */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--s-4); }
.stat .stat-num { font-family: "Space Grotesk"; font-size: clamp(2.8rem, 5vw, 4.4rem); font-weight: 600; letter-spacing: -0.03em; line-height: 1; background: linear-gradient(120deg, var(--on-dark), var(--accent-300)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.stat .stat-label { color: var(--on-dark-soft); margin-top: 0.6rem; font-size: 0.98rem; }
@media (max-width: 760px) { .stats { grid-template-columns: 1fr 1fr; gap: var(--s-5); } }

/* ---------- CTA band ---------- */
.cta-band { position: relative; overflow: hidden; border-radius: clamp(20px, 3vw, 32px); background: var(--accent); color: var(--paper); padding: clamp(3rem, 6vw, 5.5rem); }
.cta-band::before { content: ""; position: absolute; inset: 0; background: radial-gradient(80% 140% at 100% 0%, oklch(1 0 0 / 0.16), transparent 60%); }
.cta-band .wrap-inner { position: relative; z-index: 1; max-width: 60ch; }
.cta-band h2 { color: var(--paper); }
.cta-band p { color: oklch(1 0 0 / 0.85); margin-top: var(--s-4); font-size: 1.15rem; }
.cta-band .wrap-btns { margin-top: var(--s-6); }

/* ---------- AI capabilities grid ---------- */
.cap { padding: clamp(1.5rem,2.5vw,2rem); border-radius: var(--radius-lg); background: var(--ink-2); border: 1px solid var(--ink-3); transition: transform .5s var(--ease), border-color .3s; }
.cap:hover { transform: translateY(-4px); border-color: var(--accent); }
.cap .cap-ico { width: 44px; height: 44px; border-radius: 11px; background: oklch(0.56 0.19 264 / 0.18); display: grid; place-items: center; color: var(--accent-300); margin-bottom: 1.1rem; }
.cap h3 { font-size: 1.18rem; margin-bottom: 0.4rem; }
.cap p { color: var(--on-dark-soft); font-size: 0.95rem; }

/* ---------- Team ---------- */
.team-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--s-4); }
.member .ph { aspect-ratio: 1; border-radius: var(--radius); margin-bottom: 1rem; }
.member h3 { font-size: 1.15rem; }
.member .role { font-family: "JetBrains Mono", monospace; font-size: 0.74rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent); margin-top: 0.3rem; }
.member p { color: var(--text-soft); font-size: 0.92rem; margin-top: 0.6rem; }
@media (max-width: 900px){ .team-grid{ grid-template-columns: repeat(2,1fr);} }
@media (max-width: 520px){ .team-grid{ grid-template-columns: 1fr;} }

/* ---------- Contact ---------- */
.contact-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(2rem, 5vw, 5rem); align-items: start; }
@media (max-width: 880px) { .contact-grid { grid-template-columns: 1fr; } }
.contact-info .info-item { padding: 1.3rem 0; border-top: 1px solid var(--line); }
.contact-info .info-item:last-child { border-bottom: 1px solid var(--line); }
.contact-info .info-item .k { font-family: "JetBrains Mono", monospace; font-size: 0.72rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--text-faint); }
.contact-info .info-item .v { font-size: 1.1rem; margin-top: 0.4rem; font-weight: 500; }
.form { display: grid; gap: 1.1rem; }
.field { display: grid; gap: 0.45rem; }
.field label { font-size: 0.82rem; font-weight: 600; color: var(--text-soft); }
.field input, .field textarea, .field select {
  font: inherit; padding: 0.85em 1em; border-radius: 12px;
  border: 1.5px solid var(--line); background: var(--paper); color: var(--text);
  transition: border-color 0.25s, box-shadow 0.25s;
}
.field input:focus, .field textarea:focus, .field select:focus {
  outline: none; border-color: var(--accent);
  box-shadow: 0 0 0 4px oklch(0.56 0.19 264 / 0.12);
}
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; }
@media (max-width: 520px) { .field-row { grid-template-columns: 1fr; } }
.form-note { font-size: 0.82rem; color: var(--text-faint); }
.form-success { padding: 1em 1.2em; border-radius: 12px; background: oklch(0.80 0.14 200 / 0.14); border: 1px solid var(--signal); color: var(--accent-700); font-weight: 600; display: none; }
.form-success.show { display: block; }

/* ---------- Page hero (inner pages) ---------- */
.page-hero { padding-top: clamp(7.5rem, 14vh, 11rem); padding-bottom: clamp(2.5rem, 5vw, 4rem); }
.page-hero h1 { font-size: clamp(2.6rem, 6vw, 5rem); max-width: 18ch; }
.page-hero .lead { max-width: 56ch; margin-top: var(--s-4); }
.breadcrumb { font-family: "JetBrains Mono", monospace; font-size: 0.75rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-faint); margin-bottom: var(--s-4); }

/* ---------- Split feature ---------- */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 5rem); align-items: center; }
.split.reverse > :first-child { order: 2; }
@media (max-width: 880px) { .split { grid-template-columns: 1fr; } .split.reverse > :first-child { order: 0; } }
.split .ph { aspect-ratio: 4/3; border-radius: var(--radius-lg); }

/* ---------- Logo strip ---------- */
.logos { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: clamp(1.5rem, 4vw, 3.5rem); }
.logos .logo-item { font-family: "Space Grotesk"; font-weight: 600; font-size: 1.25rem; letter-spacing: -0.02em; color: var(--text-faint); opacity: 0.75; transition: opacity 0.3s, color 0.3s; }
.logos .logo-item:hover { opacity: 1; color: var(--text); }

/* ---------- Real imagery ---------- */
.shot {
  width: 100%; display: block; object-fit: cover;
  aspect-ratio: 4 / 3;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-2);
  background: var(--paper-2);
}
.work-shot {
  width: 100%; display: block; object-fit: cover; object-position: top center;
  aspect-ratio: 16 / 10;
  border-bottom: 1px solid var(--line);
  background: var(--paper-2);
}
.member-shot {
  width: 100%; display: block; object-fit: cover; object-position: center 22%;
  aspect-ratio: 1;
  border-radius: var(--radius);
  margin-bottom: 1rem;
  background: var(--paper-2);
}
.clutch-badge { display: inline-flex; align-items: center; gap: 0.6rem; transition: opacity 0.25s; }
.clutch-badge img { height: 22px; width: auto; }
a.clutch-badge:hover { opacity: 0.78; }

/* ---------- Insights / articles ---------- */
.article-card { display: flex; flex-direction: column; min-height: 100%; }
.article-card .art-tag { font-family: "JetBrains Mono", monospace; font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); }
.article-card h3 { margin: 0.9rem 0 0; font-size: 1.28rem; line-height: 1.15; }
.article-card .art-foot { display: flex; align-items: center; justify-content: space-between; margin-top: auto; padding-top: 1.6rem; color: var(--text-faint); font-size: 0.85rem; }
.article-card .art-foot .src { font-family: "JetBrains Mono", monospace; letter-spacing: 0.06em; }
.article-card .art-foot .go { width: 38px; height: 38px; border-radius: 50%; display: grid; place-items: center; box-shadow: inset 0 0 0 1.5px var(--line); transition: 0.4s var(--ease); color: var(--text-soft); }
.article-card:hover .art-foot .go { background: var(--accent); color: var(--paper); box-shadow: none; transform: rotate(-45deg); }

/* ---------- Testimonials ---------- */
.quote-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s-4); }
@media (max-width: 820px) { .quote-grid { grid-template-columns: 1fr; } }
.quote-card {
  position: relative; display: flex; flex-direction: column;
  background: var(--paper); border: 1px solid var(--line);
  border-radius: var(--radius-lg); padding: clamp(1.8rem, 3vw, 2.6rem);
  transition: transform 0.5s var(--ease), box-shadow 0.5s var(--ease);
}
.quote-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-2); }
.quote-card .qmark { font-family: "Space Grotesk"; font-size: 3.4rem; line-height: 0.6; color: var(--accent); opacity: 0.25; height: 0.5em; }
.quote-card .qstars { color: var(--accent); letter-spacing: 0.12em; font-size: 0.95rem; margin-bottom: 1.1rem; }
.quote-card blockquote {
  font-family: "Space Grotesk"; font-weight: 500;
  font-size: clamp(1.25rem, 2vw, 1.55rem); line-height: 1.3;
  letter-spacing: -0.015em; color: var(--text); margin: 0;
}
.quote-card .qfoot { display: flex; align-items: flex-start; gap: 1rem; margin-top: auto; padding-top: 1.8rem; }
.quote-card .qavatar {
  width: 46px; height: 46px; border-radius: 50%; flex: none;
  display: grid; place-items: center; font-family: "Space Grotesk"; font-weight: 600;
  color: var(--paper); background: var(--accent); font-size: 1.05rem;
}
.quote-card .qname { font-weight: 600; color: var(--ink); }
.quote-card .qrole { display: block; font-size: 0.88rem; color: var(--text-soft); line-height: 1.3; margin-top: 0.15rem; }
.quote-card .qlink { margin-top: 1.4rem; font-size: 0.85rem; }

/* ---------- Filter buttons ---------- */
.btn-ghost.is-active { background: var(--ink); color: var(--paper); box-shadow: none; }
[data-workgrid] { transition: opacity 0.3s var(--ease); }
