:root {
  --cream: #fff9ed;
  --cream-2: #fff2dd;
  --paper: #fffdf8;
  --ink: #171513;
  --muted: #70685f;
  --soft: rgba(23,21,19,.10);
  --yellow: #ffdd32;
  --orange: #ea8f5d;
  --orange-2: #f7b34d;
  --sage: #d7e6ca;
  --blue: #dcebf0;
  --shadow: 0 24px 70px rgba(87, 60, 27, .11);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-height: 100vh;
  color: var(--ink);
  font-family: ui-rounded, "SF Pro Rounded", Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
  background:
    radial-gradient(circle at 7% 8%, rgba(255, 222, 50, .22), transparent 28%),
    radial-gradient(circle at 90% 0%, rgba(234, 143, 93, .18), transparent 30%),
    linear-gradient(180deg, #fffdf8 0%, #fff8ec 44%, #f8ead7 100%);
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
.nav {
  position: sticky;
  top: 32px;
  z-index: 20;
  width: min(1320px, calc(100% - 112px));
  height: 74px;
  margin: 32px auto -106px;
  padding: 0 20px 0 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  border: 1px solid rgba(40, 31, 20, .09);
  border-radius: 24px;
  background: rgba(255, 253, 248, .82);
  box-shadow: 0 18px 54px rgba(68, 45, 20, .11);
  backdrop-filter: blur(18px);
}
.logo {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 24px;
  font-weight: 950;
  letter-spacing: -0.055em;
  color: var(--ink);
  white-space: nowrap;
}
.logo span { color: var(--orange); margin-left: -0.12em; }
.logo::before {
  content: "";
  width: 26px;
  height: 26px;
  flex: 0 0 26px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 22% 22%, var(--ink) 0 22%, transparent 23%),
    radial-gradient(circle at 78% 22%, var(--ink) 0 22%, transparent 23%),
    radial-gradient(circle at 22% 78%, var(--ink) 0 22%, transparent 23%),
    radial-gradient(circle at 78% 78%, var(--yellow) 0 22%, transparent 23%);
}
.nav-links { display: flex; align-items: center; gap: 26px; color: #60594f; font-size: 15px; }
.nav-links a { opacity: .94; transition: .2s ease; }
.nav-links a:hover { color: var(--ink); opacity: 1; transform: translateY(-1px); }
.github-btn {
  padding: 14px 20px;
  border-radius: 999px;
  background: var(--ink);
  color: white;
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .08em;
  box-shadow: 0 14px 28px rgba(24, 20, 14, .16);
  white-space: nowrap;
}
main { max-width: 100%; margin: 0 auto; }
.hero {
  position: relative;
  min-height: 560px;
  padding: 156px 70px 72px;
  display: flex;
  align-items: center;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(255, 250, 237, .88), rgba(255, 244, 226, .70)),
    linear-gradient(180deg, #fff2de 0%, #f5d8b8 100%);
  border-bottom: 1px solid rgba(59, 42, 22, .08);
}
.home-scene { position: absolute; inset: 0; opacity: .9; pointer-events: none; }
.home-scene::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 48% 47%, rgba(255,255,255,.72), transparent 34%),
    linear-gradient(90deg, rgba(255,253,248,.25), rgba(255,248,236,.35));
}
.window {
  position: absolute;
  left: 8.4%;
  top: 13%;
  width: 260px;
  height: 300px;
  padding: 18px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  border-radius: 0 0 28px 28px;
  border: 12px solid rgba(255,255,255,.42);
  background: rgba(255,255,255,.26);
}
.window span { border-radius: 0 0 26px 26px; background: linear-gradient(180deg, #d7edf6 0%, #fff7dd 100%); }
.sun { position: absolute; left: 3.8%; top: 33%; width: 82px; height: 82px; border-radius: 50%; background: var(--yellow); box-shadow: 0 0 64px rgba(255, 222, 50, .46); }
.left-plant { position: absolute; left: 1.7%; bottom: 86px; width: 160px; height: 210px; }
.left-plant::after { content:""; position:absolute; left:48px; bottom:0; width:70px; height:54px; border-radius:0 0 16px 16px; background:#d7ad79; }
.left-plant i, .right-plant i { position:absolute; width:70px; height:34px; border-radius:70px 70px 0 70px; background:#a9ba82; opacity:.65; }
.left-plant i:nth-child(1){ left:22px; top:10px; transform:rotate(-30deg); }
.left-plant i:nth-child(2){ left:82px; top:48px; transform:scaleX(-1) rotate(-26deg); }
.left-plant i:nth-child(3){ left:10px; top:78px; transform:rotate(-18deg); }
.left-plant i:nth-child(4){ left:82px; top:118px; transform:scaleX(-1) rotate(-20deg); }
.left-plant i:nth-child(5){ left:34px; top:142px; transform:rotate(-35deg); }
.lamp { position:absolute; left:2%; bottom:95px; width:120px; height:190px; opacity:.62; }
.lamp b { position:absolute; left:0; top:0; width:120px; height:72px; border-radius:80px 80px 8px 8px; background:#e7b58c; }
.lamp i { position:absolute; left:54px; top:70px; width:12px; height:115px; background:#b89973; border-radius:999px; }
.sofa { position:absolute; right:16%; bottom:0; width:420px; height:150px; border-radius:80px 80px 0 0; background:rgba(245, 220, 188, .78); }
.sofa b, .sofa i { position:absolute; bottom:52px; width:110px; height:86px; border-radius:12px 28px 12px 28px; transform:rotate(-8deg); }
.sofa b { left:78px; background:#f4bd54; }
.sofa i { right:72px; background:#e99d80; transform:rotate(11deg); }
.sofa em { position:absolute; left:35px; right:35px; bottom:0; height:56px; border-radius:30px 30px 0 0; background:rgba(255,253,248,.5); }
.wall-art { position:absolute; right:31.8%; top:24%; width:150px; height:120px; border-radius:8px; border:8px solid rgba(232, 196, 155, .42); background:rgba(255,250,236,.55); }
.wall-art b { position:absolute; left:54px; top:30px; width:50px; height:50px; border-radius:50%; background:#f0c973; }
.wall-art i { position:absolute; left:22px; bottom:18px; width:72px; height:42px; border-radius:50px 50px 0 0; background:#b6c58e; }
.wall-art em { position:absolute; right:20px; bottom:18px; width:46px; height:46px; border-radius:50%; background:#dfe5c3; }
.shelf { position:absolute; right:18%; top:26%; width:310px; height:14px; border-radius:999px; background:rgba(158, 108, 60, .20); }
.book { position:absolute; bottom:14px; display:block; width:32px; border-radius:8px 8px 2px 2px; }
.book.a { left:32px; height:80px; background:#e59a78; }
.book.b { left:76px; height:112px; background:#f1c86d; }
.book.c { left:120px; height:68px; background:#94aec9; }
.small-plant { position:absolute; right:28px; bottom:14px; width:45px; height:36px; border-radius:0 0 14px 14px; background:#e0aa6d; }
.small-plant::before, .small-plant::after { content:""; position:absolute; bottom:28px; width:42px; height:24px; border-radius:50px 50px 0 50px; background:#9cb77f; }
.small-plant::before { left:-24px; transform:rotate(-28deg); }
.small-plant::after { right:-24px; transform:scaleX(-1) rotate(-28deg); }
.right-plant { position:absolute; right:2.2%; bottom:52px; width:220px; height:290px; opacity:.8; }
.right-plant::after { content:""; position:absolute; right:46px; bottom:0; width:86px; height:70px; border-radius:30px 30px 24px 24px; background:#e0b06f; }
.right-plant i:nth-child(1){ right:88px; top:0; transform:rotate(-18deg); }
.right-plant i:nth-child(2){ right:24px; top:42px; transform:scaleX(-1) rotate(-18deg); }
.right-plant i:nth-child(3){ right:104px; top:82px; transform:rotate(-10deg); }
.right-plant i:nth-child(4){ right:12px; top:122px; transform:scaleX(-1) rotate(-14deg); }
.right-plant i:nth-child(5){ right:96px; top:160px; transform:rotate(-20deg); }
.right-plant i:nth-child(6){ right:30px; top:198px; transform:scaleX(-1) rotate(-24deg); }
.hero-copy {
  position: relative;
  z-index: 2;
  width: min(980px, 100%);
  margin-left: 11.5%;
  margin-top: 42px;
}
.hero h1 { margin: 0; }
.wordmark-main {
  position: relative;
  display: inline-block;
  color: #11100f;
  font-size: clamp(96px, 13.4vw, 190px);
  line-height: .82;
  font-weight: 950;
  letter-spacing: -0.085em;
  text-shadow: 0 8px 18px rgba(20,16,12,.08);
}
.wordmark-main em {
  position: relative;
  font-style: normal;
  color: var(--orange);
  letter-spacing: -0.09em;
  text-shadow: 0 9px 22px rgba(234,143,93,.18);
}
.wordmark-main em::before {
  content: "";
  position: absolute;
  right: -44px;
  top: -2px;
  width: 13px;
  height: 38px;
  border-radius: 999px;
  background: linear-gradient(180deg, #ffdf38, #ffc63f);
  transform: rotate(16deg);
  box-shadow: 24px 20px 0 -3px #ffcf3f;
  filter: drop-shadow(0 4px 7px rgba(247,179,77,.18));
}
.wordmark-main em::after {
  content: "";
  position: absolute;
  right: -8px;
  bottom: -26px;
  width: 132px;
  height: 62px;
  border-bottom: 3px solid rgba(247,179,77,.72);
  border-right: 3px solid rgba(247,179,77,.58);
  border-radius: 50%;
  transform: rotate(-20deg);
  filter: blur(.1px);
}
.hero-copy p {
  max-width: 600px;
  margin: 34px 0 0 8px;
  color: #686058;
  font-size: clamp(21px, 2vw, 29px);
  line-height: 1.34;
  letter-spacing: -0.02em;
}
.family, .lower, .footer { width: min(1320px, calc(100% - 112px)); margin-left: auto; margin-right: auto; }
.family { margin-top: 18px; }
.eyebrow { margin: 0 0 18px; color: rgba(23,21,19,.40); font-size: 13px; letter-spacing: .38em; }
.card-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.product-card {
  position: relative;
  min-height: 230px;
  overflow: hidden;
  padding: 30px 24px;
  border: 1px solid var(--soft);
  border-radius: 22px;
  box-shadow: 0 18px 42px rgba(78,55,26,.06);
  transition: .25s ease;
  cursor: pointer;
}
.product-card:hover { transform: translateY(-3px); box-shadow: 0 24px 58px rgba(78,55,26,.10); }
.product-card.lite { background: linear-gradient(135deg, rgba(255,250,218,.98), rgba(244,226,182,.80)); }
.product-card.classic { background: linear-gradient(135deg, rgba(255,253,248,.98), rgba(229,216,195,.78)); }
.product-card.spatial { background: linear-gradient(135deg, rgba(255,240,222,.98), rgba(240,192,146,.80)); }
.product-card.evo { background: linear-gradient(135deg, rgba(240,248,232,.98), rgba(209,228,195,.80)); }
.product-card h2 { margin: 0; font-size: 27px; line-height: 1; letter-spacing: -0.04em; }
.product-card p { max-width: 260px; margin: 22px 0 0; color: var(--muted); font-size: 17px; line-height: 1.45; }
.product-card .card-link { position: absolute; left: 24px; bottom: 28px; display: inline-flex; gap: 9px; align-items: center; font-weight: 900; }
.product-card .card-link span { transition: .2s ease; }
.product-card:hover .card-link span { transform: translateX(4px); }
.product-card img { position: absolute; right: 20px; bottom: 18px; width: 138px; max-height: 150px; object-fit: contain; filter: drop-shadow(0 16px 18px rgba(48,36,18,.13)); }
.product-card.spatial img { width: 150px; right: 16px; bottom: 16px; }
.product-card.evo img { width: 132px; opacity: .68; }
.lower { display: grid; grid-template-columns: .85fr 1.35fr; gap: 72px; margin-top: 44px; }
.vision h2 { margin: 0; font-size: 26px; letter-spacing: -0.03em; }
.vision p { color: var(--muted); line-height: 1.7; max-width: 520px; }
.outline-btn { display: inline-flex; gap: 14px; align-items: center; margin-top: 6px; border: 1px solid var(--soft); border-radius: 999px; padding: 13px 22px; font-size: 12px; font-weight: 900; letter-spacing: .08em; background: rgba(255,255,255,.56); transition: .25s ease; text-transform: uppercase; }
.outline-btn:hover { background: var(--yellow); transform: translateY(-1px); }
.resource-row { display: grid; grid-template-columns: 32px 1fr auto 18px; align-items: center; gap: 18px; min-height: 60px; margin-bottom: 10px; padding: 0 22px; border: 1px solid rgba(23,21,19,.10); border-radius: 16px; background: rgba(255,255,255,.62); box-shadow: 0 12px 34px rgba(61,42,17,.05); transition: .2s ease; }
.resource-row:hover { border-color: rgba(23,21,19,.18); background: rgba(255,255,255,.88); transform: translateY(-1px); }
.icon { color: var(--ink); font-size: 22px; opacity: .82; }
.resource-row strong { color: var(--muted); font-weight: 600; }
.resource-row em { color: var(--muted); font-style: normal; }
.footer { margin-top: 36px; padding: 20px 0 28px; border-top: 1px solid rgba(23,21,19,.10); display: flex; gap: 40px; color: rgba(23,21,19,.48); font-size: 14px; }
.foot-logo { color: rgba(23,21,19,.82); font-weight: 900; }
.social { margin-left: auto; }

/* Final hero: a single high-quality integrated illustration background. */
.hero {
  min-height: 520px;
  padding: 118px 70px 38px;
  align-items: center;
  background-image:
    linear-gradient(90deg, rgba(255, 250, 238, .58) 0%, rgba(255, 250, 238, .30) 38%, rgba(255, 250, 238, .02) 72%),
    url("assets/hero-bg.jpg");
  background-size: 112% auto;
  background-position: center 46%;
  background-repeat: no-repeat;
}
.home-scene { display: none; }
.hero-copy {
  width: min(660px, 46vw);
  margin-left: 10.5%;
  margin-top: 30px;
}
.wordmark-main {
  font-size: clamp(90px, 11vw, 176px);
}
.hero-copy p {
  max-width: 620px;
  margin-top: 32px;
}

@media (max-width: 1180px) {
  .nav-links { display: none; }
  .card-grid { grid-template-columns: repeat(2, 1fr); }
  .lower { grid-template-columns: 1fr; gap: 38px; }
  .hero-copy { margin-left: 4%; }
}
@media (max-width: 760px) {
  .nav { width: calc(100% - 32px); top: 16px; margin-top: 16px; height: 64px; padding: 0 16px; }
  .github-btn { display: none; }
  .hero { min-height: 560px; padding: 120px 24px 50px; align-items: center; text-align: center; background-position: 58% center; }
  .hero-copy { width: min(560px, 100%); margin: 34px auto 0; }
  .wordmark-main { font-size: clamp(70px, 20vw, 108px); }
  .wordmark-main em::before, .wordmark-main em::after { display: none; }
  .hero-copy p { margin: 24px auto 0; font-size: 18px; }
  .window { left: 5%; width: 230px; opacity:.55; }
  .shelf, .wall-art, .sofa { opacity:.55; }
  .right-plant { right:-70px; opacity:.45; }
  .family, .lower, .footer { width: calc(100% - 40px); }
  .card-grid { grid-template-columns: 1fr; }
  .product-card { min-height: 220px; }
  .resource-row { grid-template-columns: 28px 1fr; padding: 16px; }
  .resource-row strong, .resource-row em { display: none; }
  .footer { flex-direction: column; gap: 12px; }
  .social { margin-left: 0; }
}

/* Mobile-first refinement: keep the illustrated hero on desktop, but remove it on phones. */
@media (max-width: 760px) {
  body {
    background:
      radial-gradient(circle at 10% 0%, rgba(255, 222, 50, .16), transparent 30%),
      linear-gradient(180deg, #fffdf8 0%, #fff7ea 48%, #f8ead7 100%);
  }

  .nav {
    position: sticky;
    top: 14px;
    width: calc(100% - 32px);
    height: 64px;
    margin: 16px auto 0;
    border-radius: 22px;
  }

  .hero {
    min-height: auto;
    padding: 92px 24px 44px;
    align-items: flex-start;
    text-align: center;
    background-image: none !important;
    background:
      linear-gradient(180deg, rgba(255, 253, 248, .96) 0%, rgba(255, 246, 231, .92) 100%) !important;
  }

  .hero::before,
  .hero::after,
  .home-scene {
    display: none !important;
  }

  .hero-copy {
    width: min(560px, 100%);
    margin: 0 auto;
  }

  .wordmark-main {
    font-size: clamp(72px, 22vw, 116px);
    line-height: .88;
  }

  .hero-copy p {
    max-width: 92%;
    margin: 24px auto 0;
    font-size: clamp(18px, 5vw, 22px);
    line-height: 1.45;
  }

  .family {
    margin-top: 28px;
  }
}
