:root {
  --bg: #050713;
  --panel: #0b1022cc;
  --line: #ffffff1a;
  --text: #f7f1ff;
  --muted: #b9aecb;
  --purple: #8c5cff;
  --violet: #c083ff;
  --blue: #6ba4ff;
  --pink: #ff82d1;
  --green: #68e5b2
}

* {
  box-sizing: border-box
}

html {
  scroll-behavior: smooth
}

body {
  margin: 0;
  background: radial-gradient(circle at top right, #32105f 0, #090b1b 38%, #050713 100%);
  color: var(--text);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Arial, sans-serif
}

a {
  color: inherit;
  text-decoration: none
}

.nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 7vw;

  background: rgba(5,8,18,.95)
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);

  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 10px 35px rgba(0, 0, 0, 0.18);
}

.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 800;
  letter-spacing: .06em
}

.spark {
  width: 24px;
  height: 24px;
  background: radial-gradient(circle, #fff 0 8%, transparent 9%), conic-gradient(from 45deg, transparent 0 12%, #fff 13% 16%, transparent 17% 37%, #b98cff 38% 42%, transparent 43% 62%, #fff 63% 66%, transparent 67% 87%, #b98cff 88% 91%, transparent 92%);
  filter: drop-shadow(0 0 14px #a16cff)
}

.navlinks {
  display: flex;
  gap: 34px;
  font-size: 13px;
  letter-spacing: .08em
}

.navlinks a {
  opacity: .78
}

.navlinks a:hover,
.navlinks .active {
  opacity: 1;
  color: #d9c5ff
}

.hero {
  min-height: 100vh;
  display: grid;
  place-items: center;
  position: relative;
  overflow: hidden;
  background: linear-gradient(180deg, #05071344 0, #050713 100%)
}

.aurora {
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 50% 58%, #ff82d155 0, #8c5cff33 18%, transparent 43%), radial-gradient(ellipse at 70% 30%, #7b46ff77 0, transparent 42%), linear-gradient(160deg, transparent 0 20%, #802cff44 38%, #ff8ee533 50%, transparent 68%), linear-gradient(20deg, #070717 0, #161033 44%, #050713 100%);
  filter: saturate(130%)
}

.aurora:after {
  content: "";
  position: absolute;
  left: -10%;
  right: -10%;
  bottom: -4%;
  height: 34%;
  background: linear-gradient(180deg, transparent, #01030a 70%), radial-gradient(ellipse at 50% 100%, #263561 0, #050713 58%);
  clip-path: polygon(0 58%, 12% 46%, 28% 60%, 41% 39%, 54% 61%, 70% 42%, 82% 57%, 100% 43%, 100% 100%, 0 100%)
}

.stars {
  position: absolute;
  inset: 0;
  background-image: radial-gradient(#fff8 1px, transparent 1px);
  background-size: 80px 80px;
  opacity: .18
}

.heroText {
  position: relative;
  text-align: center;
  padding: 0 20px
}

.hero h1 {
  font-size: clamp(70px, 12vw, 180px);
  line-height: .9;
  margin: 0;
  font-weight: 900;
  letter-spacing: -.08em;
  background: linear-gradient(90deg, #fff, #d5b7ff, #8d65ff, #fff);
  -webkit-background-clip: text;
  color: transparent;
  text-shadow: 0 0 40px #985dff66
}

.hero .plus {
  font-size: .45em;
  margin: 0 .1em;
  text-shadow: 0 0 28px #fff;
  color: #fff
}

.hero p {
  margin: 32px auto 0;
  max-width: 780px;
  letter-spacing: .35em;
  text-transform: uppercase;
  color: #f2e8ff;
  font-size: 15px
}

.scroll {
  position: absolute;
  bottom: 34px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 11px;
  letter-spacing: .15em;
  color: #d7c8ef;
  text-align: center
}

.mouse {
  display: block;
  margin: 0 auto 10px;
  width: 20px;
  height: 34px;
  border: 1px solid #ffffffaa;
  border-radius: 20px
}

.section {
  padding: 110px 7vw;
  border-top: 1px solid var(--line)
}

.eyebrow {
  text-transform: uppercase;
  color: var(--violet);
  font-size: 12px;
  letter-spacing: .25em;
  font-weight: 800
}

.section h2 {
  font-size: clamp(34px, 4vw, 56px);
  margin: 12px 0 18px
}

.two {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 70px;
  align-items: center
}

.copy {
  color: var(--muted);
  font-size: 18px;
  line-height: 1.75
}

.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 22px;
  border-radius: 10px;
  background: linear-gradient(135deg, #675dff, #8d43e9);
  border: 1px solid #ffffff26;
  font-weight: 800;
  box-shadow: 0 14px 40px #6e4cff33
}

.btn.secondary {
  background: #ffffff08
}

.aboutArt {
  min-height: 320px;
  border: 1px solid #ffffff22;
  border-radius: 18px;
  background: linear-gradient(120deg, #090b1e88, #000a), url('unfortunately-screenshot.png') center/cover;
  box-shadow: 0 30px 90px #0008;
  position: relative;
  overflow: hidden
}

.aboutArt:after {
  content: 'CREATE\A INSPIRE\A IMPACT';
  white-space: pre;
  position: absolute;
  right: 34px;
  top: 34px;
  font-size: 34px;
  line-height: 1.45;
  color: #ffd98a;
  text-shadow: 0 0 20px #ffcf7588
}

.values {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
  margin-top: 54px
}

.value {
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: #ffffff07
}

.icon {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: #7d4dff22;
  color: #d9c2ff;
  font-size: 22px;
  margin-bottom: 14px
}

.projectGrid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 34px;
  margin-top: 38px
}

.card {
  background: linear-gradient(180deg, #11182ddd, #080b18dd);
  border: 1px solid #ffffff18;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 24px 70px #0005
}

.thumb {
  height: 280px;
  background: #111;
  overflow: hidden
}

.thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block
}

.thumb.china {
  background: linear-gradient(135deg, #1a1027, #48214e 45%, #0a1026), radial-gradient(circle at 30% 20%, #ffcb6b 0 8%, transparent 18%);
  position: relative
}

.thumb.china:before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent 0 12%, #ffac3a22 12% 14%, transparent 15% 28%, #f56b7f22 29% 32%, transparent 33%), linear-gradient(0deg, #000 0, #0000 50%)
}

.thumb.china:after {
  content: 'Read the Room';
  position: absolute;
  bottom: 28px;
  left: 28px;
  font-size: 34px;
  font-weight: 900;
  color: #ffe2b0;
  text-shadow: 0 0 20px #ff7c66
}

.cardBody {
  padding: 28px
}

.card h3 {
  font-size: 31px;
  margin: 0 0 6px
}

.sub {
  color: #c999ff;
  font-weight: 700;
  margin-bottom: 20px
}

.card p {
  color: var(--muted);
  line-height: 1.7
}

.actions {
  display: flex;
  gap: 14px;
  margin-top: 24px;
  flex-wrap: wrap
}

.mini {
  padding: 12px 18px;
  border-radius: 10px;
  border: 1px solid #ffffff24;
  background: #ffffff08
}

.footer {
  padding: 40px 7vw;
  border-top: 1px solid var(--line);
  display: flex;
  justify-content: space-between;
  gap: 20px;
  color: #b9aecb
}

.page {
  padding-top: 120px;
  min-height: 100vh
}

.projectDetail {
  display: grid;
  gap: 42px
}

.detailCard {
  display: grid;
  grid-template-columns: .95fr 1fr;
  gap: 36px;
  padding: 28px;
  border: 1px solid #ffffff18;
  background: #ffffff08;
  border-radius: 24px
}

.feature {
  display: flex;
  gap: 16px;
  margin: 20px 0;
  color: var(--muted)
}

.demoPanel {
  max-width: 900px;
  margin: 0 auto;
  text-align: center;
  padding: 70px;
  border: 1px solid #ffffff18;
  border-radius: 24px;
  background: linear-gradient(135deg, #ffffff0b, #6d4aff18)
}

@media(max-width:800px) {
  .nav {
    position: sticky;
    padding: 18px 5vw
  }

  .navlinks {
    gap: 14px;
    font-size: 11px
  }

  .two,
  .projectGrid,
  .detailCard {
    grid-template-columns: 1fr
  }

  .values {
    grid-template-columns: 1fr 1fr
  }

  .hero p {
    letter-spacing: .18em
  }

  .section {
    padding: 80px 5vw
  }

  .footer {
    display: block
  }

  .thumb {
    height: 220px
  }
}

/* v4 project polish */
.centerTitle {
  text-align: center;
  max-width: 820px;
  margin: 0 auto 52px
}

.centerTitle h2 {
  margin-bottom: 10px
}

.projectsPage {
  background: radial-gradient(circle at 18% 8%, #6b34ff22, transparent 28%), radial-gradient(circle at 88% 28%, #b35cff1c, transparent 30%)
}

.polished {
  max-width: 1180px;
  margin: 0 auto
}

.featureProject {
  grid-template-columns: 1.7fr .75fr;
  align-items: center;
  padding: 12px;
  border-radius: 24px;
  background: linear-gradient(135deg, #10172bdd, #070a17ee);
  box-shadow: 0 28px 100px #0008, inset 0 0 0 1px #ffffff08
}

.featureProject .coverFrame {
  height: 100%;
  min-height: 430px;
  border-radius: 18px;
  overflow: hidden;
  background: #090b18
}

.featureProject .coverFrame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block
}

.featureProject .projectText {
  padding: 24px 30px
}

.featureProject h3 {
  font-size: clamp(36px, 4vw, 54px);
  line-height: 1.05;
  margin: 0 0 10px
}

.smallCopy {
  font-size: 17px
}

.stackedActions {
  flex-direction: column;
  align-items: stretch;
  max-width: 260px
}

.stackedActions .btn,
.stackedActions .mini {
  justify-content: center;
  text-align: center
}

.wideCta {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 24px;
  padding: 30px 36px;
  border: 1px solid #ffffff18;
  border-radius: 22px;
  background: linear-gradient(135deg, #6d4aff24, #ffffff08);
  box-shadow: 0 20px 80px #0005
}

.wideCta h3 {
  margin: 0 0 6px;
  font-size: 26px
}

.wideCta p {
  margin: 0;
  color: var(--muted)
}

.ctaSpark {
  width: 70px;
  height: 70px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: #8c5cff18
}

.bigSpark {
  width: 38px;
  height: 38px
}

@media(max-width:900px) {
  .featureProject {
    grid-template-columns: 1fr
  }

  .featureProject .coverFrame {
    min-height: 260px
  }

  .featureProject .projectText {
    padding: 22px
  }

  .wideCta {
    grid-template-columns: 1fr;
    text-align: center
  }

  .wideCta .btn {
    justify-content: center
  }

  .ctaSpark {
    margin: 0 auto
  }

  .stackedActions {
    max-width: none
  }
}

/* v5 alignment + remove demo page from navigation */
.featureProject {
  grid-template-columns: minmax(0, 1.45fr) minmax(280px, .55fr);
  align-items: stretch;
}

.featureProject .coverFrame {
  width: 100%;
  aspect-ratio: 16 / 9;
  min-height: 0;
  height: auto;
  align-self: center;
}

.featureProject .coverFrame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.featureProject .projectText {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

@media(max-width:900px) {
  .featureProject {
    grid-template-columns: 1fr;
  }

  .featureProject .coverFrame {
    aspect-ratio: 16/9;
  }
}


/* final project layout fix */
.projectsPage {
  overflow-x: hidden;
}

.polished {
  max-width: 1220px;
  width: 100%;
}

.featureProject {
  width: 100%;
  overflow: hidden;
  grid-template-columns: minmax(0, 1.55fr) minmax(300px, .62fr);
  gap: 0;
  padding: 10px;
  align-items: center;
}

.featureProject .coverFrame {
  width: 100%;
  max-width: 100%;
  aspect-ratio: 16/9;
  border-radius: 18px;
  overflow: hidden;
  align-self: center;
}

.featureProject .coverFrame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
}

.featureProject:first-child .coverFrame img {
  object-position: center center;
}

.featureProject .projectText {
  min-width: 0;
  padding: 34px 34px 34px 38px;
}

.featureProject h3 {
  font-size: clamp(28px, 3vw, 42px);
}

@media(max-width:900px) {
  .featureProject {
    grid-template-columns: 1fr;
    gap: 0;
    padding: 10px;
  }

  .featureProject .projectText {
    padding: 24px 16px 18px;
  }
}

/* final card equalization */
.projectDetail .detailCard {
  box-sizing: border-box;
}

.projectDetail .detailCard+.detailCard {
  margin-top: 0;
}

.featureProject .coverFrame {
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .09);
}

@media(min-width:901px) {
  .featureProject {
    min-height: 360px;
  }

  .featureProject .coverFrame {
    max-height: 460px;
  }
}

/* LUMORA LABS v2.0 About page update */
.aboutArt {
  background: linear-gradient(120deg, #090b1e88, #0009), url('about-aurora.png') center/cover;
}

.aboutArt:after {
  content: '';
  display: none;
}

.aboutPage {
  min-height: 100vh;
  background: radial-gradient(circle at 80% 10%, #2b8bff1c, transparent 30%), radial-gradient(circle at 30% 10%, #8c5cff21, transparent 30%), #050713;
}

.aboutHeroImage {
  min-height: 72vh;
  position: relative;
  display: flex;
  align-items: center;
  padding: 140px 7vw 80px;
  overflow: hidden;
  background: linear-gradient(90deg, #050713 0%, #050713d8 29%, #05071355 58%, #050713 100%), url('about-aurora.png') right center/cover no-repeat;
  border-bottom: 1px solid var(--line);
}

.aboutHeroImage:before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(#fff7 1px, transparent 1px);
  background-size: 88px 88px;
  opacity: .12;
}

.aboutHeroImage:after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 38%;
  background: linear-gradient(180deg, transparent, #050713 82%);
}

.aboutHeroText {
  position: relative;
  z-index: 1;
  max-width: 650px;
}

.aboutHeroText h1 {
  font-size: clamp(54px, 7vw, 104px);
  line-height: .93;
  margin: 16px 0 26px;
  letter-spacing: -.06em;
  background: linear-gradient(90deg, #fff, #e2d2ff, #9d75ff);
  -webkit-background-clip: text;
  color: transparent;
}

.aboutHeroText p {
  font-size: clamp(18px, 2vw, 25px);
  line-height: 1.6;
  color: #ded4ee;
  max-width: 620px;
}

.valuesSection {
  padding-top: 80px;
}

.valuesIntro {
  max-width: 780px;
  margin-bottom: 34px;
}

.valuesIntro h2 {
  font-size: clamp(34px, 4vw, 58px);
  max-width: 780px;
}

.refinedValues .value {
  min-height: 210px;
  text-align: left;
  background: linear-gradient(180deg, #ffffff0a, #ffffff04);
}

.refinedValues .value b {
  font-size: 18px;
}

.refinedValues .value p {
  color: var(--muted);
  line-height: 1.65;
}

@media(max-width:800px) {
  .aboutHeroImage {
    min-height: 72vh;
    padding: 110px 5vw 70px;
    background-position: center;
  }

  .aboutHeroImage {
    background-image: linear-gradient(90deg, #050713 0%, #050713d8 55%, #05071366 100%), url('about-aurora.png');
  }
}


/* v2.1: navigation logo */


.logo-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 260px;
}

.site-logo {
  height: 58px;
  width: auto;
  display: block;
 filter:
        drop-shadow(0 0 8px rgba(120,220,255,.7))
        drop-shadow(0 0 18px rgba(80,180,255,.5))
        drop-shadow(0 0 28px rgba(80,180,255,.3));
}
.logo-container{
    position:relative;
}
.logo-container::before{
    content:"";
    position:absolute;

    width:90px;
    height:90px;

    background:rgba(65,180,255,.15);

    filter:blur(30px);

    border-radius:50%;

    left:-15px;
    top:-10px;

    z-index:-1;
}
.brand-name {
  font-weight: 700;
  letter-spacing: .08em;
  font-size: 18px;
  color:  #ffffff;
  white-space: nowrap;
  text-shadow: 0 0 18px rgba(111, 164, 255, .18);
}

@media(max-width:800px) {
  .logo-brand {
    min-width: auto;
    gap: 8px
  }

  .site-logo {
    height: 36px
  }

  .brand-name {
    font-size: 13px;
    letter-spacing: .05em
  }
}
