:root {
  --blue: #126df2;
  --blue-2: #56c9ff;
  --deep: #18356e;
  --pink: #ff5c9c;
  --orange: #ff8b35;
  --gold: #ffd76f;
  --cream: #fff8ec;
  --paper: rgba(255, 252, 244, .84);
  --glass: rgba(255, 255, 255, .68);
  --ink: #1e315a;
  --muted: rgba(30, 49, 90, .66);
  --line: rgba(255, 255, 255, .72);
  --shadow: 0 24px 60px rgba(55, 95, 160, .18), inset 0 1px 0 rgba(255,255,255,.66);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; min-width: 320px; font-family: "PingFang SC", "Microsoft YaHei", Arial, sans-serif; color: var(--ink); background: radial-gradient(circle at 18% 8%, rgba(255,255,255,.95), transparent 24%), radial-gradient(circle at 82% 16%, rgba(255,216,235,.72), transparent 20%), linear-gradient(180deg, #dff5ff 0%, #f8fbff 34%, #fff6e8 100%); overflow-x: hidden; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button, input { font: inherit; }
h1, h2, h3, p { margin-top: 0; }
h1 { font-size: clamp(38px, 4.8vw, 78px); line-height: 1.05; color: #1068df; margin-bottom: 14px; letter-spacing: -.045em; }
h2 { font-size: clamp(26px, 3vw, 46px); line-height: 1.15; letter-spacing: -.03em; margin-bottom: 12px; }
h3 { margin-bottom: 8px; }
.site-shell { width: min(1480px, calc(100% - 28px)); margin: 14px auto 28px; }
.topbar { position: sticky; top: 12px; z-index: 20; display: grid; grid-template-columns: 220px 1fr auto; align-items: center; gap: 18px; min-height: 72px; padding: 10px 18px; background: rgba(255,255,255,.82); border: 1px solid var(--line); border-radius: 18px; box-shadow: var(--shadow); backdrop-filter: blur(22px) saturate(1.08); }
.brand img { width: 176px; filter: drop-shadow(0 8px 12px rgba(58, 112, 195, .14)); }
.nav { display: flex; justify-content: center; gap: clamp(14px, 2vw, 36px); }
.nav a { position: relative; display: grid; gap: 2px; text-align: center; font-weight: 900; font-size: 14px; color: var(--ink); }
.nav a em { font-style: normal; font-size: 11px; color: var(--muted); font-weight: 800; }
.nav a::after { content: ""; position: absolute; left: 20%; right: 20%; bottom: -18px; height: 3px; border-radius: 99px; background: linear-gradient(90deg, var(--blue), var(--pink)); opacity: 0; transform: scaleX(.2); transition: .2s; }
.nav a:hover::after, .nav a.is-active::after { opacity: 1; transform: scaleX(1); }
.nav a.is-active { color: var(--blue); }
.top-actions { display: flex; gap: 10px; align-items: center; }
.lang-toggle, .menu-toggle { border: 1px solid rgba(255, 117, 157, .32); background: rgba(255,255,255,.72); border-radius: 999px; min-height: 42px; padding: 0 18px; color: var(--pink); font-weight: 950; cursor: pointer; }
.lang-toggle span { color: #e79aa9; margin: 0 5px; }
.menu-toggle { display: none; width: 48px; padding: 0; border-radius: 14px; }
.menu-toggle i { display: block; width: 22px; height: 2px; margin: 5px auto; background: var(--blue); border-radius: 9px; }
.section { position: relative; }
.section-card { margin-top: 22px; padding: clamp(22px, 3vw, 42px); background: var(--paper); border: 1px solid var(--line); border-radius: 30px; box-shadow: var(--shadow); backdrop-filter: blur(18px); }
.soft-card { background: rgba(255,255,255,.62); }
.eyebrow { margin: 0 0 8px; color: var(--blue); font-weight: 950; letter-spacing: .03em; }
.lead, .section-card p, .detail-card p, .phase-card p, details p { color: var(--muted); line-height: 1.75; }
.lead { font-size: 18px; max-width: 760px; }
.section-title { text-align: center; margin-bottom: 26px; }
.section-title p { margin: 0 0 6px; color: var(--blue); font-weight: 950; }
.compact { margin-bottom: 18px; }
.hero { min-height: 650px; display: grid; grid-template-columns: .95fr 1.05fr; align-items: center; gap: 20px; padding: 42px 38px 34px; overflow: hidden; border-radius: 0 0 38px 38px; background: linear-gradient(180deg, rgba(136,220,255,.66), rgba(255,255,255,.38)); }
.hero-bg { position: absolute; inset: 0; overflow: hidden; pointer-events: none; }
.cloud { position: absolute; border-radius: 999px; background: rgba(255,255,255,.72); filter: blur(1px); }
.cloud::before, .cloud::after { content: ""; position: absolute; border-radius: inherit; background: inherit; }
.cloud-a { width: 220px; height: 56px; left: 8%; top: 20%; }
.cloud-a::before { width: 95px; height: 95px; left: 24px; top: -48px; }
.cloud-a::after { width: 120px; height: 120px; right: 22px; top: -70px; }
.cloud-b { width: 270px; height: 68px; right: 6%; top: 10%; opacity: .82; }
.cloud-b::before { width: 120px; height: 120px; left: 36px; top: -62px; }
.cloud-b::after { width: 150px; height: 150px; right: 18px; top: -82px; }
.planet { position: absolute; border-radius: 50%; background: radial-gradient(circle at 34% 28%, #fff, #9de5ff 20%, #ff9eca 64%, #8f77ff); box-shadow: 0 12px 30px rgba(80,95,200,.2); }
.planet::after { content: ""; position: absolute; inset: 44% -32% auto; height: 16%; border: 7px solid rgba(255,205,95,.86); border-radius: 50%; transform: rotate(-18deg); }
.planet-a { width: 126px; height: 126px; left: 49%; top: 42px; }
.planet-b { width: 74px; height: 74px; right: 14%; top: 172px; }
.spark { position: absolute; color: #fff; text-shadow: 0 0 16px #ff9cc8; font-size: 38px; }
.spark-a { left: 39%; top: 86px; } .spark-b { right: 28%; top: 86px; }
.hero-copy, .hero-art { position: relative; z-index: 1; }
.hero-logo { width: min(560px, 92%); margin-bottom: 18px; filter: drop-shadow(0 16px 0 rgba(255,255,255,.86)) drop-shadow(0 24px 34px rgba(55,112,195,.18)); }
.cta-row { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 28px; }
.btn { display: inline-flex; align-items: center; gap: 12px; min-height: 58px; padding: 0 28px; border-radius: 999px; font-weight: 950; box-shadow: var(--shadow); }
.btn.primary { color: white; background: linear-gradient(180deg, #ff8cbc, #ff3f8b); }
.btn.secondary { color: var(--blue); background: rgba(255,255,255,.76); border: 1px solid rgba(51,154,255,.25); }
.pet-stage { position: relative; min-height: 520px; }
.pet { position: absolute; width: 220px; height: 250px; border-radius: 48% 48% 44% 44%; box-shadow: 0 24px 42px rgba(75,80,140,.18); }
.pet::before, .pet::after { content: ""; position: absolute; top: -46px; width: 74px; height: 86px; border-radius: 20px 48px 20px 48px; background: inherit; }
.pet::before { left: 26px; transform: rotate(-24deg); } .pet::after { right: 26px; transform: rotate(24deg) scaleX(-1); }
.pet span { position: absolute; inset: 58px 34px auto; height: 82px; background: radial-gradient(circle at 28% 42%, #111 0 10%, #fff 11% 15%, transparent 16%), radial-gradient(circle at 72% 42%, #111 0 10%, #fff 11% 15%, transparent 16%); }
.pet span::after { content: "♡"; position: absolute; left: 50%; top: 52px; transform: translateX(-50%); color: #ff6f9d; font-size: 38px; }
.pet-purple { left: 210px; top: 56px; background: linear-gradient(160deg, #c79aff, #8f62ff); }
.pet-pink { left: 40px; top: 196px; background: linear-gradient(160deg, #ffc0d5, #ff8eaf); transform: scale(.86); }
.pet-gold { right: 42px; top: 210px; background: linear-gradient(160deg, #ffd46d, #ffb15c); transform: scale(.88); }
.bot { position: absolute; right: 58px; top: 28px; width: 118px; height: 118px; border-radius: 50%; display: grid; place-items: center; font-weight: 950; color: #1675dd; background: linear-gradient(180deg, #fff, #d8f7ff); box-shadow: var(--shadow); }
.crystal { position: absolute; bottom: 80px; width: 56px; height: 86px; clip-path: polygon(50% 0,100% 34%,76% 100%,24% 100%,0 34%); background: linear-gradient(140deg,#8ae7ff,#7f73ff,#ff83c0); opacity: .9; }
.crystal-a { left: 380px; } .crystal-b { right: 320px; bottom: 38px; transform: scale(.7); }
.overview-grid, .detail-grid, .business-grid, .capability-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.overview-grid article, .business-grid article, .capability-grid article { padding: 22px; border-radius: 24px; background: linear-gradient(180deg, rgba(255,255,255,.8), rgba(255,244,229,.72)); border: 1px solid rgba(255,255,255,.85); box-shadow: 0 14px 34px rgba(80,100,160,.08); }
.overview-grid strong, .business-grid strong, .phase-card span { color: var(--pink); font-size: 28px; font-weight: 950; }
.showcase-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 22px; }
.poster-card { min-height: 360px; padding: 28px; border-radius: 34px; display: flex; flex-direction: column; justify-content: flex-end; overflow: hidden; position: relative; color: var(--deep); background: radial-gradient(circle at 76% 18%, rgba(255,255,255,.92), transparent 18%), radial-gradient(circle at 30% 38%, rgba(255,115,170,.42), transparent 22%), linear-gradient(145deg, #bdeeff, #fff5fa 62%, #fff1d8); box-shadow: var(--shadow); border: 1px solid var(--line); }
.poster-card::before { content: ""; position: absolute; width: 210px; height: 210px; right: -36px; top: 48px; border-radius: 48% 48% 44% 44%; background: linear-gradient(160deg, #c79aff, #8f62ff); opacity: .9; box-shadow: 0 20px 40px rgba(80,80,160,.16); }
.poster-card::after { content: "✦"; position: absolute; top: 28px; left: 28px; font-size: 46px; color: white; text-shadow: 0 0 18px #ff72a8; }
.poster-card.warm { background: radial-gradient(circle at 72% 22%, rgba(255,255,255,.92), transparent 18%), linear-gradient(145deg, #fff0b9, #ffe7f0 56%, #dff5ff); }
.poster-card.mint { background: radial-gradient(circle at 72% 22%, rgba(255,255,255,.92), transparent 18%), linear-gradient(145deg, #dff9db, #e8f2ff 56%, #fff1d8); }
.poster-card span, .poster-card h2, .poster-card p { position: relative; z-index: 1; }
.poster-card span { color: var(--blue); font-weight: 950; }
.page-hero { min-height: 390px; display: flex; flex-direction: column; justify-content: center; overflow: hidden; position: relative; background: radial-gradient(circle at 82% 22%, rgba(255,255,255,.9), transparent 18%), radial-gradient(circle at 72% 54%, rgba(255,97,158,.18), transparent 24%), linear-gradient(135deg, rgba(181,236,255,.9), rgba(255,246,231,.82)); }
.page-hero::after { content: ""; position: absolute; right: clamp(20px, 8vw, 120px); bottom: -36px; width: 240px; height: 240px; border-radius: 50%; background: radial-gradient(circle at 35% 25%, white, #91e7ff 26%, #8b72ff 72%); box-shadow: var(--shadow); opacity: .72; }
.detail-grid { grid-template-columns: repeat(2, 1fr); margin-top: 22px; }
.detail-card { padding: 28px; border-radius: 30px; border: 1px solid rgba(255,255,255,.85); box-shadow: var(--shadow); background: rgba(255,255,255,.72); }
.detail-card.lilac { background: linear-gradient(180deg,#f0e4ff,#fff8fb); } .detail-card.green { background: linear-gradient(180deg,#e7f9da,#fffaf2); } .detail-card.pink { background: linear-gradient(180deg,#ffe1eb,#fff8f4); } .detail-card.blue { background: linear-gradient(180deg,#dff3ff,#fffaf0); }
.icon { width: 96px; height: 96px; display: grid; place-items: center; font-size: 48px; color: #ff5b9a; background: rgba(255,255,255,.58); border-radius: 24px; margin-bottom: 16px; }
ul { padding-left: 18px; color: var(--deep); font-weight: 800; line-height: 1.9; }
.deep-section, .split, .team-proof { display: grid; grid-template-columns: .92fr 1.08fr; gap: 28px; align-items: center; }
.process-grid, .asset-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.process-grid span, .asset-grid div { min-height: 82px; display: grid; place-items: center; text-align: center; padding: 16px; border-radius: 20px; background: rgba(255,255,255,.72); border: 1px solid rgba(255,255,255,.88); color: var(--blue); font-weight: 950; box-shadow: 0 14px 30px rgba(60,100,180,.08); }
.loop-diagram { position: relative; min-height: 390px; display: grid; place-items: center; }
.loop-core { width: 150px; height: 150px; border-radius: 50%; display: grid; place-items: center; text-align: center; color: white; font-weight: 950; background: radial-gradient(circle at 40% 32%, #fff, #8ce8ff 26%, #8a72ff 70%); box-shadow: 0 18px 46px rgba(88,107,230,.24); }
.loop-diagram span { position: absolute; left: 50%; top: 50%; width: 148px; min-height: 70px; margin: -35px 0 0 -74px; transform: rotate(calc(var(--i) * 72deg)) translateY(-150px) rotate(calc(var(--i) * -72deg)); padding: 10px; border-radius: 18px; text-align: center; background: rgba(255,255,255,.72); box-shadow: var(--shadow); }
.loop-diagram b { display: block; color: var(--blue); } .loop-diagram em { font-size: 12px; color: var(--muted); font-style: normal; }
.business-grid { grid-template-columns: repeat(4, 1fr); margin-top: 22px; }
.asset-grid { grid-template-columns: repeat(3, 1fr); }
.phase-list { display: grid; gap: 18px; margin-top: 22px; }
.phase-card { display: grid; grid-template-columns: 90px 110px 1fr; gap: 18px; align-items: start; padding: 26px; border-radius: 30px; background: var(--paper); border: 1px solid var(--line); box-shadow: var(--shadow); backdrop-filter: blur(18px); }
.phase-card b { color: var(--orange); font-size: 22px; }
.phase-card ul { grid-column: 3; display: flex; flex-wrap: wrap; gap: 10px; padding: 0; margin: 6px 0 0; list-style: none; }
.phase-card li { padding: 8px 12px; border-radius: 999px; background: rgba(255,255,255,.68); color: var(--blue); font-size: 13px; }
.proof-number { min-height: 210px; border-radius: 28px; display: grid; place-items: center; text-align: center; background: linear-gradient(145deg, #126df2, #73d7ff); color: white; box-shadow: var(--shadow); }
.proof-number strong { display: block; font-size: clamp(42px, 5vw, 78px); }
.proof-number span { font-weight: 950; }
.capability-grid { grid-template-columns: repeat(4, 1fr); margin-top: 22px; }
.faq-list details { padding: 20px 0; border-bottom: 1px solid rgba(38,97,180,.12); }
.faq-list details:last-child { border-bottom: 0; }
summary { cursor: pointer; font-weight: 950; color: var(--blue); font-size: 20px; }
.waitlist { display: grid; grid-template-columns: 1fr auto; gap: 22px; align-items: center; background: linear-gradient(135deg, rgba(170,228,255,.86), rgba(255,236,246,.86)); }
.waitlist-form { display: flex; gap: 12px; }
.waitlist input { width: min(320px, 48vw); min-height: 56px; border: 1px solid rgba(35,130,240,.18); border-radius: 999px; padding: 0 20px; outline: 0; background: rgba(255,255,255,.86); }
.waitlist button { min-height: 56px; border: 0; border-radius: 999px; padding: 0 26px; background: linear-gradient(180deg,#ff8cbc,#ff3f8b); color: white; font-weight: 950; cursor: pointer; }
.footer { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 18px; align-items: center; }
.footer img { width: 160px; } .footer p { margin: 8px 0 0; } .footer-links { display: flex; gap: 16px; font-weight: 900; color: var(--blue); }
.reveal { opacity: 0; transform: translateY(24px); transition: .7s ease; transition-delay: var(--delay, 0s); }
.reveal.is-visible { opacity: 1; transform: translateY(0); }
@media (max-width: 1080px) {
  .topbar { grid-template-columns: 180px 1fr auto; }
  .nav { position: fixed; left: 20px; right: 20px; top: 94px; display: none; grid-template-columns: repeat(2,1fr); padding: 18px; border-radius: 22px; background: rgba(255,255,255,.96); box-shadow: var(--shadow); }
  .nav.is-open { display: grid; }
  .menu-toggle { display: block; }
  .hero, .split, .deep-section, .team-proof, .waitlist { grid-template-columns: 1fr; }
  .hero { padding: 32px 18px; }
  .hero-art { order: -1; }
  .pet-stage { min-height: 420px; transform: scale(.9); transform-origin: center; }
  .overview-grid, .showcase-grid, .business-grid, .capability-grid, .asset-grid { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 720px) {
  .site-shell { width: 100%; margin: 0; }
  .topbar { top: 0; border-radius: 0 0 20px 20px; grid-template-columns: 150px 1fr auto; }
  .brand img { width: 138px; }
  .lang-toggle { padding: 0 12px; min-height: 38px; }
  .hero { min-height: auto; border-radius: 0 0 28px 28px; }
  .hero-logo { width: 92%; }
  h1 { font-size: 34px; }
  .lead { font-size: 15px; }
  .btn, .waitlist button { width: 100%; justify-content: center; }
  .cta-row, .waitlist-form { flex-direction: column; }
  .waitlist input { width: 100%; }
  .pet-stage { min-height: 300px; transform: scale(.66); margin: -60px 0; }
  .overview-grid, .showcase-grid, .detail-grid, .business-grid, .capability-grid, .asset-grid, .process-grid { grid-template-columns: 1fr; }
  .loop-diagram { transform: scale(.78); margin: -34px 0; }
  .section-card, .detail-card, .phase-card { border-radius: 24px; margin: 16px 10px 0; }
  .phase-card { grid-template-columns: 1fr; }
  .phase-card ul { grid-column: 1; }
  .footer { margin: 16px 10px 0; }
  .footer-links { flex-wrap: wrap; }
}

/* Feature dropdown and poster-like detail pages */
.nav-item { position: relative; display: grid; place-items: center; }
.nav-item > a { position: relative; display: grid; gap: 2px; text-align: center; font-weight: 900; font-size: 14px; color: var(--ink); }
.nav-item > a em { font-style: normal; font-size: 11px; color: var(--muted); font-weight: 800; }
.nav-item > a::after { content: ""; position: absolute; left: 20%; right: 20%; bottom: -18px; height: 3px; border-radius: 99px; background: linear-gradient(90deg, var(--blue), var(--pink)); opacity: 0; transform: scaleX(.2); transition: .2s; }
.nav-item:hover > a::after, .nav-item.is-active > a::after { opacity: 1; transform: scaleX(1); }
.nav-item.is-active > a { color: var(--blue); }
.submenu { position: absolute; top: calc(100% + 22px); left: 50%; width: 270px; padding: 12px; border-radius: 22px; background: rgba(255,255,255,.9); border: 1px solid rgba(255,255,255,.82); box-shadow: var(--shadow); backdrop-filter: blur(18px) saturate(1.08); transform: translate(-50%, 8px); opacity: 0; pointer-events: none; transition: .22s ease; }
.submenu::before { content: ""; position: absolute; left: 0; right: 0; top: -24px; height: 24px; }
.has-menu:hover .submenu, .has-menu.is-open .submenu { opacity: 1; transform: translate(-50%, 0); pointer-events: auto; }
.submenu a { display: grid; gap: 2px; padding: 12px 14px; border-radius: 16px; text-align: left; font-weight: 950; color: var(--deep); }
.submenu a:hover, .submenu a.is-active { background: linear-gradient(90deg, rgba(255,139,53,.16), rgba(86,201,255,.18)); color: var(--blue); }
.submenu a::after { display: none; }
.feature-hero { position: relative; min-height: 620px; display: grid; grid-template-columns: 1fr .72fr; align-items: center; gap: 26px; margin-top: 22px; padding: clamp(28px, 5vw, 70px); overflow: hidden; border-radius: 38px; border: 1px solid var(--line); box-shadow: var(--shadow); background: linear-gradient(180deg, #27b9ff 0%, #dff8ff 45%, #fff6e5 100%); }
.feature-hero::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 20% 16%, rgba(255,255,255,.82), transparent 18%), radial-gradient(circle at 80% 18%, rgba(255,255,255,.78), transparent 16%), radial-gradient(circle at 50% 86%, rgba(255,210,107,.46), transparent 26%); pointer-events: none; }
.feature-hero-copy { position: relative; z-index: 1; }
.feature-hero h1 { font-size: clamp(42px, 5.8vw, 88px); color: #fff; text-shadow: 0 5px 0 rgba(30,91,180,.24), 0 14px 30px rgba(30,91,180,.22); -webkit-text-stroke: 1px rgba(16,104,223,.18); }
.feature-hero .lead { color: rgba(20,49,92,.78); max-width: 720px; font-weight: 800; }
.memory-hero { background: linear-gradient(180deg, #18aef8 0%, #bfefff 42%, #fff1df 100%); }
.breeding-hero { background: linear-gradient(180deg, #10a9ff 0%, #d7f6ff 42%, #fff2d3 100%); }
.social-hero { background: linear-gradient(180deg, #18b8ff 0%, #dff6ff 44%, #ffe9ef 100%); }
.ar-hero { background: linear-gradient(180deg, #169bff 0%, #cbf4ff 42%, #fff5dc 100%); }
.hero-badges { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 26px; }
.hero-badges span { padding: 12px 18px; border-radius: 999px; color: var(--blue); background: rgba(255,255,255,.82); border: 1px solid rgba(255,255,255,.9); box-shadow: 0 12px 28px rgba(50,95,160,.12); font-weight: 950; }
.poster-pet { position: relative; z-index: 1; width: min(360px, 72vw); height: 400px; margin-inline: auto; border-radius: 48% 48% 44% 44%; background: linear-gradient(160deg, #ffd46d, #ff9a77); box-shadow: 0 28px 56px rgba(40,82,160,.22); }
.poster-pet::before, .poster-pet::after { content: ""; position: absolute; top: -62px; width: 112px; height: 132px; border-radius: 26px 70px 26px 70px; background: inherit; }
.poster-pet::before { left: 40px; transform: rotate(-24deg); }
.poster-pet::after { right: 40px; transform: rotate(24deg) scaleX(-1); }
.poster-pet span { position: absolute; inset: 100px 54px auto; height: 110px; background: radial-gradient(circle at 28% 42%, #111 0 11%, #fff 12% 16%, transparent 17%), radial-gradient(circle at 72% 42%, #111 0 11%, #fff 12% 16%, transparent 17%); }
.poster-pet span::after { content: "♡"; position: absolute; left: 50%; top: 68px; transform: translateX(-50%); color: #ff5c9c; font-size: 54px; }
.poster-cat { background: linear-gradient(160deg, #f2f2f2, #a9c5e8); }
.orange-pet { background: linear-gradient(160deg, #ffd46d, #ff9b62); }
.gray-pet { background: linear-gradient(160deg, #f4f4f4, #98aecf); }
.pink-pet { background: linear-gradient(160deg, #ffc0d5, #ff8eaf); }
.split-pet { background: linear-gradient(90deg, #ffd46d 0 50%, #b8c4d9 50% 100%); }
.poster-pet.small { width: 170px; height: 190px; transform: scale(.82); }
.poster-pet.small::before, .poster-pet.small::after { top: -34px; width: 58px; height: 70px; }
.poster-pet.small::before { left: 22px; }
.poster-pet.small::after { right: 22px; }
.poster-pet.small span { inset: 50px 28px auto; height: 62px; }
.poster-pet.small span::after { top: 38px; font-size: 30px; }
.poster-layout { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 22px; }
.poster-panel { min-height: 280px; padding: 24px; border-radius: 30px; border: 1px solid rgba(255,255,255,.86); box-shadow: var(--shadow); background: rgba(255,255,255,.76); position: relative; overflow: hidden; }
.poster-panel::after { content: ""; position: absolute; width: 140px; height: 140px; right: -36px; bottom: -36px; border-radius: 50%; background: rgba(255,255,255,.46); }
.poster-panel b { display: inline-grid; place-items: center; width: 48px; height: 48px; margin-bottom: 14px; border-radius: 50%; background: white; color: var(--blue); font-size: 24px; box-shadow: 0 10px 22px rgba(50,90,150,.12); }
.poster-panel h2 { color: var(--deep); }
.blue-panel { background: linear-gradient(180deg, #dff4ff, #fffaf0); }
.green-panel { background: linear-gradient(180deg, #e8facf, #fffaf0); }
.pink-panel { background: linear-gradient(180deg, #ffe1eb, #fff8f4); }
.orange-panel { background: linear-gradient(180deg, #ffe0b2, #fff8ee); }
.mini-timeline { display: grid; grid-template-columns: repeat(4,1fr); gap: 8px; margin-top: 20px; }
.mini-timeline span { padding: 10px 6px; border-radius: 14px; background: rgba(255,255,255,.74); color: var(--blue); font-weight: 950; text-align: center; }
.avatar-row { display: flex; gap: 10px; margin-top: 20px; }
.avatar-row i { width: 54px; height: 54px; border-radius: 50%; background: linear-gradient(160deg, #ffd46d, #ff8eaf); box-shadow: inset 0 0 0 5px rgba(255,255,255,.7); }
.speech-bubble { display: inline-block; margin-top: 18px; padding: 16px 18px; border-radius: 20px 20px 20px 6px; background: white; color: #8c5b35; font-weight: 950; box-shadow: 0 12px 24px rgba(70,100,160,.1); }
.dna-stage { position: relative; z-index: 1; display: grid; place-items: center; min-height: 420px; }
.dna-stage i { width: 128px; height: 320px; border-radius: 999px; background: repeating-linear-gradient(180deg, transparent 0 24px, rgba(255,255,255,.8) 24px 32px), linear-gradient(90deg, #35d6ff, #b875ff, #ff93cc); filter: drop-shadow(0 18px 30px rgba(70,90,190,.25)); transform: rotate(18deg); }
.dna-stage strong { position: absolute; padding: 14px 24px; border-radius: 999px; background: rgba(255,255,255,.84); color: var(--blue); font-size: 28px; box-shadow: var(--shadow); }
.breeding-flow { display: grid; grid-template-columns: 1fr 80px 1fr 1.1fr; gap: 18px; align-items: center; margin-top: 22px; }
.parent-card, .offspring-card { min-height: 330px; display: grid; place-items: center; text-align: center; padding: 24px; border-radius: 30px; background: var(--paper); border: 1px solid var(--line); box-shadow: var(--shadow); }
.dna-link { display: grid; place-items: center; width: 80px; height: 80px; border-radius: 50%; color: white; background: linear-gradient(180deg, #56c9ff, #8f72ff); font-size: 42px; font-weight: 950; box-shadow: var(--shadow); }
.friend-stage { position: relative; min-height: 420px; display: flex; align-items: center; justify-content: center; gap: 0; }
.friend-stage .poster-pet { margin: 0 -22px; }
.heart-float { position: absolute; top: 72px; right: 22%; width: 86px; height: 86px; display: grid; place-items: center; border-radius: 50%; color: #ff5c9c; background: rgba(255,255,255,.82); font-size: 42px; box-shadow: var(--shadow); }
.social-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; margin-top: 22px; }
.social-grid article { padding: 24px; border-radius: 28px; background: var(--paper); border: 1px solid var(--line); box-shadow: var(--shadow); }
.social-grid span { font-size: 44px; }
.ar-phone { position: relative; z-index: 1; width: min(320px, 72vw); min-height: 470px; margin-inline: auto; border-radius: 44px; padding: 28px; background: rgba(255,255,255,.75); border: 10px solid rgba(24,53,110,.8); box-shadow: var(--shadow); display: grid; place-items: center; }
.ar-phone b { position: absolute; left: 24px; top: 20px; padding: 8px 14px; border-radius: 999px; color: white; background: linear-gradient(180deg, #ff8cbc, #ff3f8b); }
.page-cta { display: flex; justify-content: space-between; align-items: center; gap: 18px; background: linear-gradient(135deg, rgba(255,221,126,.9), rgba(255,236,246,.86)); }
.page-cta h2 { margin-bottom: 0; }
@media (max-width: 1080px) {
  .nav { align-items: start; }
  .nav-item { place-items: stretch; }
  .submenu { position: static; width: auto; transform: none; opacity: 1; pointer-events: auto; margin-top: 8px; box-shadow: none; background: rgba(255,255,255,.64); }
  .has-menu:hover .submenu, .has-menu.is-open .submenu { transform: none; }
  .nav-item > a::after { display: none; }
  .feature-hero, .breeding-flow, .page-cta { grid-template-columns: 1fr; }
  .poster-layout, .social-grid { grid-template-columns: repeat(2,1fr); }
  .dna-link { margin: auto; }
}
@media (max-width: 720px) {
  .feature-hero { min-height: auto; margin: 16px 10px 0; border-radius: 28px; }
  .feature-hero h1 { font-size: 38px; }
  .poster-layout, .social-grid, .breeding-flow { grid-template-columns: 1fr; margin: 16px 10px 0; }
  .poster-pet { width: 230px; height: 260px; }
  .poster-pet::before, .poster-pet::after { top: -42px; width: 76px; height: 90px; }
  .poster-pet span { inset: 70px 38px auto; height: 78px; }
  .poster-pet span::after { top: 48px; font-size: 38px; }
  .page-cta { flex-direction: column; align-items: stretch; }
}

.home-loop-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.home-loop-row a { min-height: 150px; display: grid; place-items: center; text-align: center; gap: 6px; padding: 18px; border-radius: 24px; background: linear-gradient(180deg, rgba(255,255,255,.86), rgba(255,246,226,.74)); border: 1px solid rgba(255,255,255,.9); box-shadow: 0 14px 34px rgba(80,100,160,.08); }
.home-loop-row span { font-size: 42px; }
.home-loop-row b { color: var(--blue); font-size: 20px; font-weight: 950; }
.home-loop-row small { color: var(--muted); font-weight: 800; line-height: 1.5; }
@media (max-width: 1080px) { .home-loop-row { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 720px) { .home-loop-row { grid-template-columns: 1fr; } }

/* Tokenomics marketplace poster section */
.token-hero { background: radial-gradient(circle at 20% 16%, rgba(255,255,255,.9), transparent 16%), radial-gradient(circle at 86% 22%, rgba(255,182,211,.42), transparent 22%), linear-gradient(180deg, #26b9ff 0%, #dff7ff 48%, #fff2dd 100%); }
.token-hero h1 { color: #fff; text-shadow: 0 5px 0 rgba(30,91,180,.18), 0 14px 30px rgba(30,91,180,.2); -webkit-text-stroke: 1px rgba(16,104,223,.16); }
.token-hero-tags { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 22px; }
.token-hero-tags span { padding: 12px 18px; border-radius: 999px; background: rgba(255,255,255,.82); color: var(--blue); font-weight: 950; border: 1px solid rgba(255,255,255,.9); box-shadow: 0 12px 28px rgba(50,95,160,.12); }
.market-scene { display: grid; grid-template-columns: 1fr 330px; gap: 22px; background: linear-gradient(180deg, rgba(255,238,204,.86), rgba(255,248,236,.88)); }
.market-main { position: relative; padding: 24px; border-radius: 30px; background: linear-gradient(180deg, #ffd18d 0 0, #fff7e9 0); border: 1px solid rgba(255,255,255,.9); box-shadow: inset 0 0 0 8px rgba(255,182,94,.18); }
.market-main::before { content: ""; display: block; height: 72px; margin: -24px -24px 16px; border-radius: 30px 30px 18px 18px; background: repeating-linear-gradient(90deg, #ff8f68 0 54px, #fff3dc 54px 108px); box-shadow: inset 0 -8px 0 rgba(189,101,52,.12); }
.market-sign, .brand-sign { display: inline-flex; align-items: center; gap: 10px; min-height: 54px; padding: 0 24px; margin-top: -70px; position: relative; z-index: 1; border-radius: 18px; color: white; font-size: 22px; font-weight: 950; background: linear-gradient(180deg, #ffad5f, #ff6f3f); box-shadow: 0 12px 22px rgba(165,83,35,.18), inset 0 2px 0 rgba(255,255,255,.55); border: 2px solid rgba(255,255,255,.72); }
.market-tabs { display: flex; flex-wrap: wrap; gap: 10px; margin: 14px 0 18px; }
.market-tabs span { padding: 8px 18px; border-radius: 999px; background: rgba(255,255,255,.78); color: #9b612b; font-weight: 950; box-shadow: inset 0 -2px 0 rgba(182,108,49,.12); }
.goods-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.goods-card { position: relative; min-height: 275px; display: grid; align-content: start; gap: 8px; padding: 14px; border-radius: 22px; background: linear-gradient(180deg, #ffe2f1, #fff6df); border: 2px solid rgba(255,255,255,.78); box-shadow: 0 16px 32px rgba(110,80,140,.12); overflow: hidden; }
.goods-card.green { background: linear-gradient(180deg, #e8ffd4, #fff6df); }
.goods-card.orange { background: linear-gradient(180deg, #ffe1b9, #fff6df); }
.goods-card.blue { background: linear-gradient(180deg, #dff1ff, #fff6df); }
.goods-card em { position: absolute; left: 12px; top: 12px; padding: 4px 9px; border-radius: 999px; background: linear-gradient(180deg, #ff7fc4, #b56dff); color: white; font-size: 12px; font-style: normal; font-weight: 950; }
.goods-card h3 { margin: 6px 0 0; color: #7d4c2b; font-size: 17px; }
.goods-card p { margin: 0; color: rgba(80,65,75,.62); font-weight: 800; }
.goods-card strong { color: #ff5f2e; font-size: 20px; }
.ico { position: relative; display: inline-grid; place-items: center; width: 86px; height: 86px; margin: 26px auto 4px; border-radius: 24px; background: radial-gradient(circle at 32% 24%, #fff 0 12%, rgba(255,255,255,.2) 13%), linear-gradient(160deg, #8ee9ff, #7b79ff 52%, #ff8fc7); box-shadow: 0 12px 24px rgba(76,101,185,.2), inset 0 3px 0 rgba(255,255,255,.68), inset 0 -5px 0 rgba(47,57,130,.12); }
.ico::before { font-size: 42px; filter: drop-shadow(0 3px 0 rgba(0,0,0,.08)); }
.pet-ico::before { content: "🐱"; }
.puppy-ico::before { content: "🐶"; }
.dna-ico::before { content: "🧬"; }
.ball-ico::before { content: "🪐"; }
.gift-ico::before { content: "🎁"; }
.shop-ico::before { content: "🏪"; }
.coin-ico::before { content: "💰"; }
.percent-ico::before { content: "%"; font-weight: 950; color: #fff; font-size: 46px; }
.collar-ico::before { content: "🏅"; }
.house-ico::before { content: "🏠"; }
.food-ico::before { content: "🥫"; }
.badge-ico::before { content: "🏆"; }
.brand-zone { padding: 24px; border-radius: 30px; background: linear-gradient(180deg, #fff1c9, #fff9ed); border: 2px solid rgba(255,196,118,.6); box-shadow: var(--shadow); }
.brand-sign { margin: 0 0 18px; font-size: 20px; }
.food-bag { position: relative; min-height: 230px; padding: 28px 18px; display: grid; align-content: center; gap: 12px; text-align: center; border-radius: 20px 20px 16px 16px; background: linear-gradient(165deg, #f6c181, #d18b4d); color: #78401f; box-shadow: inset 0 8px 0 rgba(255,255,255,.25), 0 18px 30px rgba(132,78,36,.16); }
.food-bag::before { content: "🐾"; font-size: 44px; }
.food-bag b { font-size: 28px; line-height: 1.2; }
.food-bag span { font-weight: 950; color: rgba(90,48,25,.72); }
.brand-items { display: flex; justify-content: center; gap: 12px; margin: 18px 0; }
.brand-items .ico { width: 72px; height: 72px; margin: 0; border-radius: 22px; }
.brand-zone p { margin-bottom: 0; font-weight: 800; }
.token-flow-strip { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; align-items: stretch; }
.token-flow-strip div { position: relative; min-height: 170px; display: grid; place-items: center; text-align: center; gap: 6px; padding: 16px; border-radius: 24px; background: linear-gradient(180deg, rgba(255,255,255,.88), rgba(255,246,226,.78)); border: 1px solid rgba(255,255,255,.9); box-shadow: 0 14px 30px rgba(80,100,160,.08); }
.token-flow-strip div:not(:last-child)::after { content: "→"; position: absolute; right: -18px; top: 50%; transform: translateY(-50%); color: #ff9a3d; font-size: 30px; font-weight: 950; z-index: 2; }
.token-flow-strip .ico { width: 76px; height: 76px; margin: 0; border-radius: 50%; }
.token-flow-strip b { color: var(--blue); font-size: 18px; }
.token-flow-strip span { color: var(--muted); font-weight: 800; font-size: 13px; line-height: 1.45; }
.fee-card { background: linear-gradient(180deg, #fff2cc, #fff8eb) !important; border-color: rgba(255,183,62,.56) !important; }
.token-assets div { gap: 10px; min-height: 120px; }
.token-assets .ico { width: 62px; height: 62px; margin: 0; border-radius: 18px; }
.token-assets .ico::before { font-size: 30px; }
.token-dock { display: grid; grid-template-columns: repeat(4, minmax(120px, 1fr)) minmax(220px, 1.2fr); gap: 16px; margin-top: 22px; align-items: stretch; }
.dock-card { min-height: 132px; display: grid; place-items: center; text-align: center; padding: 16px; border-radius: 28px; color: white; border: 3px solid rgba(255,255,255,.7); box-shadow: var(--shadow), inset 0 4px 0 rgba(255,255,255,.38); }
.dock-card span { font-size: 42px; }
.dock-card b { font-size: 24px; text-shadow: 0 3px 0 rgba(0,0,0,.12); }
.dock-card.green { background: linear-gradient(180deg, #a7e95f, #61bf42); }
.dock-card.pink { background: linear-gradient(180deg, #ff9eb8, #ff6a86); }
.dock-card.blue { background: linear-gradient(180deg, #74d9ff, #3298ee); }
.dock-card.purple { background: linear-gradient(180deg, #c99aff, #8a70ee); }
.market-cta { min-height: 132px; display: grid; place-items: center; padding: 16px 28px; border-radius: 999px; color: white; background: linear-gradient(180deg, #ffd35e, #ff8a22); border: 3px solid rgba(255,255,255,.72); font-size: 30px; font-weight: 950; box-shadow: var(--shadow), inset 0 5px 0 rgba(255,255,255,.35); text-shadow: 0 3px 0 rgba(160,78,18,.18); }
@media (max-width: 1180px) {
  .market-scene { grid-template-columns: 1fr; }
  .goods-grid { grid-template-columns: repeat(2, 1fr); }
  .token-flow-strip { grid-template-columns: repeat(2, 1fr); }
  .token-flow-strip div:not(:last-child)::after { display: none; }
  .token-dock { grid-template-columns: repeat(2, 1fr); }
  .market-cta { grid-column: 1 / -1; }
}
@media (max-width: 720px) {
  .market-scene { margin: 16px 10px 0; }
  .goods-grid, .token-flow-strip, .token-dock { grid-template-columns: 1fr; }
  .market-main { padding: 18px; }
  .market-main::before { margin: -18px -18px 16px; }
  .market-sign { font-size: 18px; padding: 0 16px; }
}
