:root {
  --ink: #08111f;
  --ink-soft: #101d2f;
  --paper: #f5f2eb;
  --white: #fffdf8;
  --coral: #ff704d;
  --blue: #55c9ff;
  --muted: #687181;
  --line: rgba(8, 17, 31, .16);
  --display: "Unbounded", Arial, sans-serif;
  --body: "Manrope", Arial, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; overflow-x: hidden; background: var(--paper); color: var(--ink); font-family: var(--body); }
body.menu-open { overflow: hidden; }
a { color: inherit; }
button, input, textarea, select { font: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
.skip-link { position: fixed; z-index: 1000; top: 10px; left: 10px; padding: 12px 16px; transform: translateY(-160%); background: var(--coral); color: var(--ink); }
.skip-link:focus { transform: translateY(0); }

.site-header {
  position: fixed;
  z-index: 50;
  inset: 0 0 auto;
  height: 84px;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 0 clamp(22px, 5vw, 76px);
  color: var(--white);
  border-bottom: 1px solid rgba(255,255,255,.16);
  transition: height .25s ease, background .25s ease, backdrop-filter .25s ease;
}
.site-header.is-scrolled { height: 70px; background: rgba(8,17,31,.88); backdrop-filter: blur(16px); }
.brand { display: inline-flex; align-items: center; gap: 12px; width: max-content; color: inherit; font-size: .74rem; font-weight: 700; letter-spacing: .12em; text-decoration: none; }
.brand-dot { color: var(--coral); }
.brand-mark { position: relative; width: 30px; height: 30px; border: 1px solid currentColor; transform: rotate(45deg); }
.brand-mark i { position: absolute; display: block; background: currentColor; }
.brand-mark i:first-child { width: 14px; height: 1px; top: 9px; left: 7px; }
.brand-mark i:last-child { width: 1px; height: 14px; top: 7px; left: 14px; background: var(--coral); }
.site-header nav { display: flex; gap: 30px; }
.site-header nav a, .header-cta { font-size: .76rem; font-weight: 600; text-decoration: none; }
.site-header nav a { color: rgba(255,255,255,.7); }
.site-header nav a:hover { color: var(--white); }
.header-cta { justify-self: end; padding-bottom: 5px; border-bottom: 1px solid var(--coral); }
.header-cta span, .button span, .price-card a span { display: inline-block; margin-left: 8px; transition: transform .2s ease; }
.header-cta:hover span, .button:hover span, .price-card a:hover span { transform: translate(3px,-3px); }
.menu-button, .mobile-menu { display: none; }

.hero {
  position: relative;
  min-height: 900px;
  height: 100svh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow: hidden;
  padding: 132px clamp(24px, 7.5vw, 120px) 62px;
  background: var(--ink);
  color: var(--white);
}
.hero-grid {
  position: absolute;
  inset: 0;
  opacity: .15;
  background-image: linear-gradient(rgba(85,201,255,.28) 1px, transparent 1px), linear-gradient(90deg, rgba(85,201,255,.28) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: linear-gradient(to right, #000, transparent 78%);
}
.hero-glow { position: absolute; width: 60vw; aspect-ratio: 1; right: -23vw; top: -26vw; border-radius: 50%; background: radial-gradient(circle, rgba(255,112,77,.25), transparent 65%); }
.eyebrow, .section-label { margin: 0; font-size: .67rem; font-weight: 700; letter-spacing: .17em; line-height: 1.5; text-transform: uppercase; }
.hero .eyebrow { position: relative; margin-bottom: 30px; color: var(--blue); }
.hero h1 {
  position: relative;
  z-index: 2;
  max-width: 1060px;
  margin: 0;
  font-family: var(--display);
  font-size: clamp(3.6rem, 7.3vw, 8rem);
  font-weight: 500;
  letter-spacing: -.065em;
  line-height: .98;
}
.hero h1 span { color: var(--coral); }
.hero-foot { position: relative; z-index: 3; display: flex; align-items: flex-end; justify-content: space-between; gap: 40px; margin-top: clamp(45px, 7vh, 80px); padding-left: 28%; }
.hero-foot p { max-width: 480px; margin: 0; color: #aeb8c7; font-size: clamp(.95rem, 1.2vw, 1.08rem); line-height: 1.7; }
.button { display: inline-flex; align-items: center; justify-content: center; min-height: 58px; padding: 0 25px; border: 0; font-size: .78rem; font-weight: 700; text-decoration: none; cursor: pointer; }
.button-accent { background: var(--coral); color: var(--ink); }
.button-accent:hover { background: var(--blue); }
.button-dark { width: 100%; background: var(--ink); color: var(--white); }
.button-dark:hover { background: var(--coral); color: var(--ink); }
.browser-card {
  position: absolute;
  z-index: 1;
  right: -3vw;
  bottom: 10%;
  width: min(36vw, 530px);
  aspect-ratio: 1.38;
  transform: rotate(-4deg);
  border: 1px solid rgba(255,255,255,.25);
  border-radius: 10px;
  background: rgba(16,29,47,.87);
  box-shadow: 0 36px 100px rgba(0,0,0,.38);
}
.browser-top { height: 42px; display: flex; align-items: center; gap: 7px; padding: 0 14px; border-bottom: 1px solid rgba(255,255,255,.13); }
.browser-top span { width: 7px; height: 7px; border-radius: 50%; background: rgba(255,255,255,.3); }
.browser-top span:first-child { background: var(--coral); }
.browser-top b { margin-left: auto; color: rgba(255,255,255,.38); font-size: .52rem; font-weight: 500; }
.browser-body { height: calc(100% - 42px); display: grid; grid-template-columns: 1.1fr .9fr; padding: 12%; }
.browser-copy small { color: var(--blue); font-size: .48rem; text-transform: uppercase; }
.browser-copy strong { display: block; margin-top: 13%; font-family: var(--display); font-size: clamp(.75rem, 1.5vw, 1.4rem); line-height: 1.2; }
.browser-copy i { display: block; width: 55%; height: 20px; margin-top: 18%; background: var(--coral); }
.browser-shape { display: grid; place-items: center; }
.browser-shape span { width: 80%; aspect-ratio: 1; border: 1px solid var(--blue); border-radius: 50% 50% 12% 50%; box-shadow: inset 0 0 55px rgba(85,201,255,.16); }
.hero-meta { position: absolute; left: clamp(24px, 5vw, 76px); right: clamp(24px, 5vw, 76px); bottom: 27px; display: flex; justify-content: space-between; color: #647184; font-size: .57rem; letter-spacing: .13em; text-transform: uppercase; }

.section-pad { padding: clamp(90px, 11vw, 160px) clamp(24px, 7.5vw, 120px); }
.section-label { color: #6d7480; }
.intro-grid { display: grid; grid-template-columns: 1.45fr .55fr; gap: 9vw; align-items: end; margin-top: 64px; }
.intro h2, .section-heading h2, .process h2, .included h2, .price-intro h2, .faq h2, .contact h2 {
  margin: 0;
  font-family: var(--display);
  font-size: clamp(2.3rem, 4.7vw, 5.2rem);
  font-weight: 500;
  letter-spacing: -.055em;
  line-height: 1.05;
}
.intro-copy p { margin: 0; line-height: 1.75; }
.intro-copy p + p { margin-top: 22px; color: var(--muted); }

.services { padding-top: 30px; }
.section-heading { display: grid; grid-template-columns: .65fr 1.35fr; gap: 8vw; margin-bottom: 75px; }
.service-list { border-top: 1px solid var(--line); }
.service { display: grid; grid-template-columns: .25fr 1.25fr .4fr auto; gap: 35px; align-items: center; min-height: 150px; border-bottom: 1px solid var(--line); transition: padding .25s ease, background .25s ease; }
.service:hover { padding: 0 22px; background: var(--coral); }
.service-number { color: #9299a3; font-size: .7rem; }
.service h3 { margin: 0 0 9px; font-family: var(--display); font-size: clamp(1.2rem, 2vw, 1.8rem); letter-spacing: -.04em; }
.service p { max-width: 570px; margin: 0; color: var(--muted); line-height: 1.6; }
.service:hover p, .service:hover .service-number { color: var(--ink); }
.service strong { font-size: .75rem; }
.service-arrow { font-size: 1.4rem; }

.result { display: grid; grid-template-columns: 1fr 1fr; min-height: 870px; background: var(--ink); color: var(--white); }
.result-visual { position: relative; display: grid; place-items: center; overflow: hidden; background: var(--ink-soft); }
.result-visual::before { content: ""; position: absolute; inset: 0; opacity: .2; background-image: linear-gradient(rgba(85,201,255,.2) 1px, transparent 1px), linear-gradient(90deg, rgba(85,201,255,.2) 1px, transparent 1px); background-size: 56px 56px; }
.orbit { position: absolute; border: 1px solid rgba(85,201,255,.33); border-radius: 50%; }
.orbit-a { width: 60%; aspect-ratio: 1; }
.orbit-b { width: 92%; aspect-ratio: 1; border-color: rgba(255,112,77,.2); }
.result-core { position: relative; z-index: 2; width: 230px; aspect-ratio: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; transform: rotate(-8deg); background: var(--coral); color: var(--ink); border-radius: 54% 46% 48% 52%; }
.result-core span { font-size: .65rem; }
.result-core b { font-family: var(--display); font-size: 3rem; letter-spacing: -.08em; }
.result-core small { font-size: .65rem; }
.result-copy { align-self: center; }
.result-copy .section-label { color: #7c899b; }
.result-copy h2 { margin: 48px 0 55px; font-family: var(--display); font-size: clamp(2.8rem, 5vw, 5.7rem); font-weight: 500; letter-spacing: -.06em; line-height: 1; }
.result-copy h2 em { color: var(--coral); font-style: normal; }
.result-copy ul { margin: 0; padding: 0; list-style: none; border-top: 1px solid rgba(255,255,255,.17); }
.result-copy li { display: grid; grid-template-columns: 42px 1fr; gap: 14px; padding: 20px 0; border-bottom: 1px solid rgba(255,255,255,.17); }
.result-copy li > span { color: var(--blue); font-size: .65rem; }
.result-copy b { font-size: .9rem; }
.result-copy p { margin: 5px 0 0; color: #9ea9b8; font-size: .84rem; line-height: 1.55; }

.process { background: var(--white); }
.process-heading { display: grid; grid-template-columns: 1.55fr .45fr; gap: 9vw; align-items: end; margin: 60px 0 90px; }
.process-heading p { margin: 0; color: var(--muted); line-height: 1.7; }
.steps { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--line); }
.step { min-height: 320px; padding: 26px 28px 30px 0; border-right: 1px solid var(--line); }
.step + .step { padding-left: 28px; }
.step:last-child { border-right: 0; }
.step > span { color: var(--coral); font-size: .68rem; }
.step h3 { margin: 105px 0 22px; font-family: var(--display); font-size: 1.25rem; letter-spacing: -.04em; }
.step p { margin: 0; color: var(--muted); font-size: .88rem; line-height: 1.65; }

.included { display: grid; grid-template-columns: .9fr 1.1fr; gap: 10vw; background: var(--blue); }
.included-title h2 { margin-top: 48px; }
.included-grid { border-top: 1px solid rgba(8,17,31,.28); }
.included-item { padding: 28px 0; border-bottom: 1px solid rgba(8,17,31,.28); }
.included-item span { display: block; margin-bottom: 12px; font-size: .65rem; letter-spacing: .12em; text-transform: uppercase; }
.included-item b { font-family: var(--display); font-size: clamp(1rem, 1.6vw, 1.45rem); letter-spacing: -.035em; }

.prices { display: grid; grid-template-columns: .8fr 1.2fr; gap: 10vw; }
.price-intro > p:last-child { max-width: 500px; margin: 36px 0 0; color: var(--muted); line-height: 1.75; }
.price-intro h2 { margin-top: 50px; }
.price-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; align-items: end; }
.price-card { min-height: 470px; display: flex; flex-direction: column; padding: 34px; border: 1px solid var(--line); background: var(--white); }
.price-card.featured { min-height: 530px; background: var(--ink); color: var(--white); }
.price-card > span { font-size: .68rem; letter-spacing: .13em; text-transform: uppercase; }
.price-card h3 { margin: 65px 0 35px; font-family: var(--display); font-size: clamp(1.8rem, 3vw, 3rem); letter-spacing: -.06em; }
.price-card ul { margin: 0; padding: 0; list-style: none; }
.price-card li { padding: 10px 0; border-top: 1px solid currentColor; font-size: .83rem; opacity: .72; }
.price-card a { width: max-content; margin-top: auto; padding-bottom: 5px; border-bottom: 1px solid var(--coral); font-size: .75rem; font-weight: 700; text-decoration: none; }

.faq { display: grid; grid-template-columns: .75fr 1.25fr; gap: 10vw; background: var(--white); }
.faq h2 { margin-top: 50px; }
.faq-list { border-top: 1px solid var(--line); }
details { border-bottom: 1px solid var(--line); }
summary { display: flex; justify-content: space-between; gap: 25px; padding: 29px 0; font-weight: 700; cursor: pointer; list-style: none; }
summary::-webkit-details-marker { display: none; }
summary span { color: var(--coral); font-size: 1.3rem; transition: transform .2s ease; }
details[open] summary span { transform: rotate(45deg); }
details p { max-width: 680px; margin: -5px 0 30px; color: var(--muted); line-height: 1.7; }

.contact { display: grid; grid-template-columns: .8fr 1.2fr; gap: 11vw; background: var(--coral); }
.contact-copy h2 { margin: 50px 0 35px; }
.contact-copy p:not(.section-label) { max-width: 480px; line-height: 1.7; }
.contact-copy > a { display: inline-block; margin-top: 35px; font-weight: 700; text-decoration-thickness: 1px; text-underline-offset: 7px; }
.contact-form label { display: block; margin-bottom: 28px; }
.contact-form label > span { display: block; margin-bottom: 10px; font-size: .65rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.contact-form input, .contact-form textarea, .contact-form select { width: 100%; padding: 12px 0; border: 0; border-bottom: 1px solid rgba(8,17,31,.55); border-radius: 0; outline: 0; background: transparent; color: var(--ink); }
.contact-form input:focus, .contact-form textarea:focus, .contact-form select:focus { border-bottom-width: 2px; }
.contact-form textarea { resize: vertical; }
.website-field { position: absolute !important; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; }
.contact-form .button:disabled { cursor: wait; opacity: .62; }
.form-note { margin: 15px 0 0; font-size: .68rem; line-height: 1.5; }

.site-footer { display: grid; grid-template-columns: 1fr 1fr auto; align-items: end; gap: 40px; padding: 65px clamp(24px, 7.5vw, 120px) 40px; background: var(--ink); color: var(--white); }
.site-footer p { max-width: 460px; margin: 0; color: #8d98a8; }
.site-footer > span { color: #647184; font-size: .72rem; }

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

@media (max-width: 1050px) {
  .site-header { grid-template-columns: 1fr auto; }
  .site-header nav, .header-cta { display: none; }
  .menu-button { display: grid; gap: 7px; width: 42px; height: 42px; padding: 13px 8px; border: 0; background: transparent; }
  .menu-button span { height: 1px; background: var(--white); transition: transform .2s ease; }
  .menu-button[aria-expanded="true"] span:first-child { transform: translateY(4px) rotate(45deg); }
  .menu-button[aria-expanded="true"] span:last-child { transform: translateY(-4px) rotate(-45deg); }
  .mobile-menu { position: fixed; z-index: -1; inset: 0; display: flex; flex-direction: column; justify-content: center; gap: 25px; padding: 100px 30px 60px; background: var(--ink); }
  .mobile-menu[hidden] { display: none; }
  .mobile-menu a { font-family: var(--display); font-size: clamp(1.5rem, 7vw, 2.6rem); text-decoration: none; }
  .hero { min-height: 820px; }
  .browser-card { opacity: .55; right: -16vw; width: 55vw; }
  .hero h1 { max-width: 900px; }
  .hero-foot { padding-left: 0; }
  .intro-grid, .included, .prices, .faq, .contact { grid-template-columns: 1fr; }
  .intro-grid, .included, .prices, .faq, .contact { gap: 65px; }
  .result { grid-template-columns: 1fr; }
  .result-visual { min-height: 600px; }
  .price-cards { max-width: 800px; }
}

@media (max-width: 720px) {
  .site-header { height: 68px; padding: 0 20px; }
  .brand { font-size: .66rem; }
  .brand-mark { width: 26px; height: 26px; }
  .brand-mark i:first-child { top: 8px; left: 6px; }
  .brand-mark i:last-child { top: 5px; left: 12px; }
  .hero { min-height: 760px; height: auto; justify-content: flex-start; padding: 130px 20px 70px; }
  .hero h1 { font-size: clamp(2.55rem, 12vw, 4rem); line-height: 1.02; }
  .hero-foot { align-items: stretch; flex-direction: column; margin-top: 45px; }
  .hero-foot p { max-width: 100%; }
  .button { width: 100%; }
  .browser-card { position: relative; right: auto; bottom: auto; width: 100%; margin-top: 50px; opacity: .75; transform: rotate(-2deg); }
  .hero-meta { display: none; }
  .section-pad { padding: 85px 20px; }
  .intro-grid, .section-heading, .process-heading { grid-template-columns: 1fr; gap: 40px; }
  .intro h2, .section-heading h2, .process h2, .included h2, .price-intro h2, .faq h2, .contact h2 { font-size: clamp(2rem, 10vw, 3.2rem); }
  .service { grid-template-columns: 34px 1fr auto; gap: 14px; padding: 28px 0; }
  .service:hover { padding: 28px 10px; }
  .service strong { grid-column: 2; }
  .service-arrow { grid-column: 3; grid-row: 1; }
  .result { min-height: 0; }
  .result-visual { min-height: 440px; }
  .result-copy h2 { font-size: clamp(2.5rem, 12vw, 4rem); }
  .steps { grid-template-columns: 1fr 1fr; }
  .step, .step + .step { min-height: 260px; padding: 24px 20px 24px 0; border-bottom: 1px solid var(--line); }
  .step:nth-child(even) { padding-left: 20px; border-right: 0; }
  .step h3 { margin-top: 65px; }
  .price-cards { grid-template-columns: 1fr; }
  .price-card, .price-card.featured { min-height: 450px; }
  .site-footer { grid-template-columns: 1fr; gap: 28px; }
}

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