:root {
  --ink: #10110f;
  --ink-soft: #1a1c18;
  --paper: #f3f1e8;
  --paper-dark: #e8e5da;
  --lime: #c9ff55;
  --coral: #ff6846;
  --blue: #4567ff;
  --muted: #696b64;
  --line: rgba(16, 17, 15, 0.16);
  --light-line: rgba(255, 255, 255, 0.17);
  --mono: "DM Mono", monospace;
  --sans: "Manrope", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--paper); color: var(--ink); font-family: var(--sans); }
body.menu-open { overflow: hidden; }
a { color: inherit; }
.skip-link { background: var(--lime); left: 1rem; padding: .7rem 1rem; position: fixed; top: -5rem; z-index: 100; }
.skip-link:focus { top: 1rem; }

.site-header {
  align-items: center; background: rgba(243, 241, 232, .9); border-bottom: 1px solid var(--line);
  display: grid; gap: 2rem; grid-template-columns: 1fr auto 1fr; height: 76px; padding: 0 4vw;
  position: fixed; top: 0; transition: height .25s ease, box-shadow .25s ease; width: 100%; z-index: 30;
  backdrop-filter: blur(16px);
}
.site-header.is-scrolled { box-shadow: 0 12px 30px rgba(16,17,15,.08); height: 64px; }
.brand { align-items: center; display: flex; font-size: .87rem; font-weight: 800; gap: .7rem; letter-spacing: -.02em; text-decoration: none; }
.brand b { color: var(--muted); font-weight: 500; }
.brand-symbol { display: flex; flex-direction: column; gap: 3px; width: 28px; }
.brand-symbol i { background: currentColor; display: block; height: 2px; transform-origin: left; }
.brand-symbol i:nth-child(1) { width: 100%; }
.brand-symbol i:nth-child(2) { width: 72%; }
.brand-symbol i:nth-child(3) { width: 42%; }
.desktop-nav { display: flex; gap: 2rem; }
.desktop-nav a { font-size: .77rem; font-weight: 700; text-decoration: none; }
.desktop-nav a:hover { opacity: .55; }
.header-cta { justify-self: end; border-bottom: 1px solid var(--ink); font-size: .77rem; font-weight: 700; padding-bottom: .25rem; text-decoration: none; }
.header-cta span, .button span, .contact-link span { display: inline-block; transition: transform .2s ease; }
.header-cta:hover span, .button:hover span, .contact-link:hover span { transform: translate(3px, -3px); }
.menu-toggle { background: transparent; border: 0; display: none; height: 42px; padding: 8px; width: 42px; }
.menu-toggle span { background: var(--ink); display: block; height: 2px; margin: 6px auto; transition: transform .2s; width: 22px; }
.menu-toggle[aria-expanded="true"] span:first-child { transform: translateY(4px) rotate(45deg); }
.menu-toggle[aria-expanded="true"] span:last-child { transform: translateY(-4px) rotate(-45deg); }
.mobile-nav { display: none; }

.hero { min-height: 100svh; overflow: hidden; padding: clamp(9rem, 17vh, 13rem) 4vw 3.5rem; position: relative; }
.hero-copy { max-width: 960px; position: relative; z-index: 2; }
.eyebrow, .section-label, .service-tag { font-family: var(--mono); font-size: .69rem; font-weight: 500; letter-spacing: .07em; text-transform: uppercase; }
.eyebrow { align-items: center; display: flex; gap: .65rem; margin: 0 0 2rem; }
.eyebrow > span { background: var(--coral); border-radius: 50%; height: 7px; width: 7px; }
.hero h1 { font-size: clamp(4rem, 8.8vw, 9rem); letter-spacing: -.075em; line-height: .86; margin: 0; max-width: 1100px; }
.hero h1 em { color: var(--coral); font-family: Georgia, serif; font-weight: 400; }
.hero-lede { color: #44463f; font-size: clamp(1rem, 1.5vw, 1.25rem); line-height: 1.65; margin: 2rem 0 0; max-width: 700px; }
.hero-actions { align-items: center; display: flex; flex-wrap: wrap; gap: 1.7rem; margin-top: 2.2rem; }
.button { align-items: center; display: inline-flex; font-size: .82rem; font-weight: 800; gap: 2.5rem; justify-content: space-between; min-width: 245px; padding: 1rem 1.15rem; text-decoration: none; }
.button-primary { background: var(--ink); color: white; }
.text-link { border-bottom: 1px solid var(--ink); display: inline-flex; font-size: .8rem; font-weight: 700; gap: .7rem; padding-bottom: .25rem; text-decoration: none; }
.hero-note { align-items: flex-end; border-top: 1px solid var(--line); bottom: 2.2rem; display: flex; justify-content: space-between; left: 4vw; padding-top: 1rem; position: absolute; width: 45%; z-index: 2; }
.hero-note span { color: var(--muted); font-family: var(--mono); font-size: .65rem; text-transform: uppercase; }
.hero-note p { font-family: var(--mono); font-size: .63rem; margin: 0; text-align: right; }
.hero-orbit { height: min(45vw, 650px); position: absolute; right: -5vw; top: 18vh; width: min(45vw, 650px); }
.orbit { border: 1px solid var(--line); border-radius: 50%; inset: 0; position: absolute; }
.orbit-one { animation: rotate 25s linear infinite; }
.orbit-two { inset: 14%; }
.orbit-one span { align-items: center; background: var(--paper); border: 1px solid var(--ink); border-radius: 50%; display: flex; font-family: var(--mono); font-size: .68rem; height: 42px; justify-content: center; position: absolute; width: 42px; }
.orbit-one span:nth-child(1) { left: 48%; top: -21px; }
.orbit-one span:nth-child(2) { right: -21px; top: 48%; }
.orbit-one span:nth-child(3) { bottom: -21px; left: 48%; }
.orbit-one span:nth-child(4) { left: -21px; top: 48%; }
.orbit-core { align-items: center; background: var(--lime); border-radius: 50%; display: flex; flex-direction: column; height: 36%; justify-content: center; left: 32%; position: absolute; top: 32%; width: 36%; }
.orbit-core span { font-size: clamp(2rem, 5vw, 4.5rem); font-weight: 800; letter-spacing: -.08em; }
.orbit-core small { font-family: var(--mono); }
@keyframes rotate { to { transform: rotate(360deg); } }

.ticker { background: var(--lime); border-block: 1px solid var(--ink); overflow: hidden; padding: .8rem 0; }
.ticker-track { align-items: center; animation: ticker 28s linear infinite; display: flex; gap: 2rem; white-space: nowrap; width: max-content; }
.ticker span { font-size: .75rem; font-weight: 800; text-transform: uppercase; }
.ticker i { font-style: normal; }
@keyframes ticker { to { transform: translateX(-50%); } }

.section { padding: clamp(5rem, 9vw, 9rem) 4vw; }
.section-label { color: var(--muted); margin: 0; }
.intro { border-bottom: 1px solid var(--line); display: grid; gap: 4rem; grid-template-columns: 1fr 3fr; }
.intro > div { display: grid; gap: 3rem; grid-template-columns: 1.25fr .75fr; }
.intro h2, .section-head h2, .approach h2, .about h2, .contact h2 { font-size: clamp(2.7rem, 6vw, 6.7rem); letter-spacing: -.065em; line-height: .94; margin: 0; }
.intro > div > p { color: var(--muted); font-size: 1.02rem; line-height: 1.75; margin: .4rem 0 0; }
.section-head { display: grid; gap: 2rem; grid-template-columns: 1fr 2fr 1fr; margin-bottom: 4rem; }
.section-head h2 { grid-column: 2; }
.section-head > p:last-child { align-self: end; color: var(--muted); font-size: .92rem; line-height: 1.7; margin: 0; }
.service-list { border-top: 1px solid var(--line); }
.service-card { align-items: center; border-bottom: 1px solid var(--line); display: grid; gap: 3rem; grid-template-columns: .55fr 2fr 1fr; min-height: 360px; padding: 3rem 0; }
.service-number { align-self: start; font-family: var(--mono); font-size: .7rem; }
.service-tag { color: var(--coral); margin: 0 0 1rem; }
.service-copy h3 { font-size: clamp(1.8rem, 3.3vw, 3.5rem); letter-spacing: -.045em; line-height: 1.05; margin: 0; max-width: 800px; }
.service-copy > p:not(.service-tag) { color: var(--muted); line-height: 1.65; max-width: 640px; }
.service-copy ul { display: flex; flex-wrap: wrap; gap: .45rem; list-style: none; margin: 1.5rem 0 0; padding: 0; }
.service-copy li { border: 1px solid var(--line); border-radius: 100px; font-family: var(--mono); font-size: .58rem; padding: .5rem .7rem; text-transform: uppercase; }
.service-mark { height: 230px; justify-self: end; position: relative; width: 230px; }
.mark-launch { background: var(--coral); border-radius: 50%; overflow: hidden; }
.mark-launch::before, .mark-launch::after, .mark-launch span { background: var(--ink); content: ""; height: 1px; left: 12%; position: absolute; top: 50%; transform-origin: center; width: 76%; }
.mark-launch::before { transform: rotate(45deg); }.mark-launch::after { transform: rotate(-45deg); }.mark-launch span { transform: rotate(90deg); }
.mark-creators { align-items: center; display: flex; justify-content: center; }
.mark-creators i { border: 1px solid var(--ink); border-radius: 50%; height: 70%; position: absolute; width: 70%; }
.mark-creators i:nth-child(2) { transform: translateX(-30%); }.mark-creators i:nth-child(3) { transform: translateX(30%); }
.mark-community { align-items: center; background: var(--blue); border-radius: 50% 50% 8% 50%; color: white; display: flex; justify-content: center; }
.mark-community span { font-family: var(--mono); font-size: 4.5rem; }
.mark-social { align-items: flex-end; display: flex; gap: 10px; justify-content: center; }
.mark-social span { background: var(--lime); border: 1px solid var(--ink); width: 48px; }.mark-social span:nth-child(1){height:35%}.mark-social span:nth-child(2){height:62%}.mark-social span:nth-child(3){height:92%}

.approach { background: var(--ink); color: white; display: grid; gap: 8vw; grid-template-columns: 1fr 1fr; }
.approach-sticky { align-self: start; position: sticky; top: 120px; }
.section-label.light { color: rgba(255,255,255,.5); margin-bottom: 2rem; }
.approach h2 { font-size: clamp(2.7rem, 4.8vw, 5.5rem); }
.approach-sticky > p:not(.section-label) { color: rgba(255,255,255,.56); line-height: 1.75; max-width: 600px; }
.light-link { border-color: white; margin-top: 1.5rem; }
.process-list { list-style: none; margin: 0; padding: 0; }
.process-list li { border-top: 1px solid var(--light-line); display: grid; gap: 2rem; grid-template-columns: 60px 1fr; padding: 2.3rem 0 4rem; }
.process-list li > span { color: var(--lime); font-family: var(--mono); font-size: .68rem; }
.process-list h3 { font-size: clamp(1.6rem, 2.5vw, 2.6rem); letter-spacing: -.04em; margin: 0; }
.process-list p { color: rgba(255,255,255,.55); line-height: 1.65; max-width: 520px; }

.channels .section-head { grid-template-columns: 1fr 3fr; }
.channels .section-head h2 { grid-column: 2; }
.channel-grid { display: grid; gap: 1px; grid-template-columns: repeat(12, 1fr); background: var(--ink); border: 1px solid var(--ink); }
.channel-card { display: flex; flex-direction: column; justify-content: space-between; min-height: 330px; padding: 1.5rem; position: relative; }
.channel-card strong { font-size: 4rem; letter-spacing: -.08em; }
.channel-card p { font-size: .88rem; line-height: 1.55; max-width: 230px; }
.channel-card > span { font-family: var(--mono); font-size: .62rem; position: absolute; right: 1rem; top: 1rem; }
.x-card { background: var(--ink); color: white; grid-column: span 3; }.yt-card { background: var(--coral); grid-column: span 3; }.li-card { background: var(--blue); color: white; grid-column: span 3; }.reddit-card { background: var(--lime); grid-column: span 3; }.more-card { background: var(--paper-dark); grid-column: 4 / span 6; }
.principle { background: var(--coral); }
.principle .section-label { color: var(--ink); }
.principle blockquote { font-family: Georgia, serif; font-size: clamp(3rem, 7vw, 7.5rem); letter-spacing: -.055em; line-height: .96; margin: 5rem 0; max-width: 1300px; }
.principle-foot { border-top: 1px solid var(--ink); display: flex; justify-content: space-between; padding-top: 1rem; }
.principle-foot p { font-size: .82rem; line-height: 1.6; margin: 0; max-width: 560px; }
.principle-foot span { font-family: var(--mono); font-size: .62rem; text-transform: uppercase; }

.about { display: grid; gap: 7vw; grid-template-columns: 1fr 1fr; }
.about-visual { background: var(--blue); min-height: 650px; overflow: hidden; position: relative; }
.horizon-sun { background: var(--lime); border-radius: 50%; height: 290px; left: 50%; position: absolute; top: 26%; transform: translateX(-50%); width: 290px; }
.horizon-line { border-top: 1px solid var(--ink); border-radius: 50%; height: 330px; left: -15%; position: absolute; width: 130%; }
.line-one { bottom: 7%; }.line-two { bottom: -3%; }.line-three { bottom: -13%; }
.about-visual > span { bottom: 2rem; color: white; font-size: 2.5rem; font-weight: 800; left: 2rem; letter-spacing: -.05em; line-height: .9; position: absolute; }
.about-copy { align-self: center; }
.about-copy .section-label { margin-bottom: 2rem; }
.about-copy > p:not(.section-label) { color: var(--muted); font-size: 1.05rem; line-height: 1.8; max-width: 650px; }
.about-points { margin-top: 3rem; }
.about-points > div { border-top: 1px solid var(--line); display: grid; gap: 1rem; grid-template-columns: 1fr 2fr; padding: 1.25rem 0; }
.about-points strong { font-size: .8rem; }.about-points span { color: var(--muted); font-size: .78rem; line-height: 1.55; }

.contact { background: var(--lime); min-height: 80svh; position: relative; }
.contact h2 { font-size: clamp(4rem, 10vw, 11rem); line-height: .8; margin-top: 10vh; }
.contact-link { border-bottom: 2px solid var(--ink); bottom: 4rem; display: flex; font-size: clamp(1rem, 2vw, 1.8rem); font-weight: 700; justify-content: space-between; left: 4vw; padding-bottom: .8rem; position: absolute; right: 4vw; text-decoration: none; }
.site-footer { align-items: center; background: var(--ink); color: white; display: grid; gap: 2rem; grid-template-columns: 1fr 1fr 1fr; padding: 2rem 4vw; }
.site-footer > p { color: rgba(255,255,255,.5); font-size: .7rem; text-align: center; }.site-footer > div { display: flex; font-family: var(--mono); font-size: .58rem; gap: 1.5rem; justify-self: end; text-transform: uppercase; }.site-footer a { text-decoration: none; }

.reveal { opacity: 0; transform: translateY(28px); transition: opacity .7s ease, transform .7s ease; }
.reveal.is-visible { opacity: 1; transform: none; }

@media (max-width: 1000px) {
  .site-header { grid-template-columns: 1fr auto; }.desktop-nav,.header-cta { display: none; }.menu-toggle { display: block; }
  .mobile-nav { background: var(--ink); color: white; inset: 76px 0 auto; padding: 2rem 4vw 3rem; position: fixed; z-index: 29; }
  .mobile-nav.open { display: grid; }.mobile-nav a { border-bottom: 1px solid var(--light-line); font-size: 1.3rem; font-weight: 700; padding: 1rem 0; text-decoration: none; }
  .hero-orbit { opacity: .45; right: -15vw; top: 26vh; }
  .hero-note { width: 60%; }
  .intro,.intro > div,.section-head,.approach,.about { grid-template-columns: 1fr; }
  .section-head h2,.channels .section-head h2 { grid-column: 1; }.section-head > p:last-child { max-width: 550px; }
  .service-card { grid-template-columns: 60px 1fr; }.service-mark { display: none; }
  .approach-sticky { position: static; }.channel-card { grid-column: span 6; }.more-card { grid-column: 3 / span 8; }
  .about-visual { min-height: 520px; }.site-footer { grid-template-columns: 1fr 1fr; }.site-footer > p { display: none; }
}

@media (max-width: 640px) {
  .site-header { height: 64px; }.mobile-nav { inset-block-start: 64px; }.hero { min-height: 880px; padding-top: 8rem; }
  .hero h1 { font-size: clamp(3.7rem, 17vw, 5.4rem); }.hero-orbit { height: 350px; right: -120px; top: 500px; width: 350px; }.orbit-one span { height: 34px; width: 34px; }
  .hero-note { align-items: flex-start; bottom: 1.5rem; display: grid; gap: .7rem; width: 82%; }.hero-note p { text-align: left; }
  .section { padding-block: 5rem; }.intro,.intro > div { gap: 2rem; }.section-head { margin-bottom: 2.5rem; }
  .service-card { gap: 1rem; grid-template-columns: 1fr; min-height: auto; padding: 2.5rem 0; }.service-number { color: var(--muted); }.service-copy h3 { font-size: 2rem; }
  .approach { gap: 5rem; }.process-list li { grid-template-columns: 40px 1fr; padding-bottom: 3rem; }
  .channel-card { grid-column: span 12; min-height: 230px; }.more-card { grid-column: span 12; }
  .principle blockquote { margin: 3.5rem 0; }.principle-foot { gap: 2rem; flex-direction: column; }
  .about-visual { min-height: 420px; }.horizon-sun { height: 210px; width: 210px; }.about-points > div { grid-template-columns: 1fr; }
  .contact { min-height: 700px; }.contact h2 { margin-top: 18vh; }.contact-link { align-items: flex-end; gap: 1rem; }
  .site-footer { grid-template-columns: 1fr; }.site-footer > div { justify-self: start; flex-wrap: wrap; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; } *,*::before,*::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}
