:root{
  --bg:#f5fbf7;
  --bg-soft:#edf7f1;
  --panel:#ffffff;
  --panel-soft:#f3f8f4;
  --line:rgba(16,39,34,.10);
  --text:#12241e;
  --muted:#5f736b;
  --brand:#9ce737;
  --brand-2:#62d7a9;
  --accent:#5f8f1a;
  --shadow:0 24px 70px rgba(18,36,30,.08);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Verdana,system-ui,sans-serif;
  background:
    radial-gradient(circle at top left, rgba(98,215,169,.18), transparent 24rem),
    radial-gradient(circle at 85% 15%, rgba(156,231,55,.18), transparent 20rem),
    linear-gradient(180deg, #f8fcf9 0%, #eef7f1 100%);
  color:var(--text);
}
a{color:inherit;text-decoration:none}
button,input{font:inherit}
img{max-width:100%;display:block}

.site-header{
  position:sticky;
  top:0;
  z-index:20;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:16px 24px;
  backdrop-filter:blur(18px);
  background:rgba(255,255,255,.86);
  border-bottom:1px solid var(--line);
}
.site-logo{
  display:inline-flex;
  align-items:center;
  gap:12px;
  font-weight:700;
  letter-spacing:.02em;
}
.site-logo-mark{
  width:14px;
  height:14px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  box-shadow:0 0 24px rgba(156,231,55,.8);
}
.site-nav,.site-header-actions,.site-language-switch,.hero-actions,.cta-actions,.footer-links,.auth-session-actions{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}
.site-nav a,.site-language-switch a,.ghost-button,.secondary-button,.primary-button,.auth-provider{
  transition:transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease;
}
.site-nav a{
  font-size:14px;
  color:var(--muted);
}
.site-nav a:hover{color:var(--text)}
.site-language-switch{
  padding:4px;
  border:1px solid var(--line);
  border-radius:999px;
  background:#fff;
}
.site-language-switch a{
  padding:8px 12px;
  border-radius:999px;
  color:var(--muted);
  font-size:13px;
  font-weight:700;
}
.site-language-switch a.is-active{
  color:#0a1613;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
}
.ghost-button,.secondary-button,.primary-button,.auth-provider{
  border:1px solid var(--line);
  border-radius:999px;
  padding:12px 18px;
  background:#fff;
  color:var(--text);
  cursor:pointer;
}
.comparison-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
}
.comparison-card strong{
  display:block;
  margin-bottom:10px;
  font-size:18px;
  color:var(--text);
}
.primary-button{
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  color:#08110f;
  border:none;
  font-weight:700;
  box-shadow:0 18px 40px rgba(98,215,169,.20);
}
.secondary-button{
  background:rgba(255,255,255,.06);
}
.ghost-button:hover,.secondary-button:hover,.primary-button:hover,.auth-provider:hover,.site-language-switch a:hover{
  transform:translateY(-1px);
}
.full{width:100%;justify-content:center}

main{
  width:min(1240px,calc(100% - 40px));
  margin:0 auto;
}
.hero{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:32px;
  align-items:center;
  padding:64px 0 28px;
}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:var(--accent);
  font-size:13px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.12em;
}
.eyebrow::before{
  content:"";
  width:38px;
  height:1px;
  background:linear-gradient(90deg,var(--brand),transparent);
}
.hero h1,.section-heading h2,.cta-section h2{
  margin:16px 0;
  line-height:1.02;
  letter-spacing:-.04em;
  color:#10261f;
}
.hero h1{font-size:clamp(44px,6vw,76px)}
.hero-lead,.section-heading p,.feature-card p,.comparison-card p,.workflow p,.audience-grid p,.faq-list p,.cta-section p,.site-footer p,.auth-intro{
  color:var(--muted);
  line-height:1.65;
}
.hero-points{
  margin:22px 0 0;
  padding:0;
  list-style:none;
  display:grid;
  gap:10px;
}
.hero-points li::before{
  content:"";
  display:inline-block;
  width:10px;
  height:10px;
  border-radius:50%;
  margin-right:10px;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
}

.hero-visual{
  min-height:520px;
  position:relative;
}
.light-stage{
  position:relative;
  min-height:520px;
  border:1px solid var(--line);
  border-radius:34px;
  overflow:hidden;
  background:
    linear-gradient(180deg, rgba(255,255,255,.95), rgba(240,248,243,.96)),
    radial-gradient(circle at 50% 0%, rgba(214,255,114,.18), transparent 38%);
  box-shadow:var(--shadow);
}
.grid-floor{
  position:absolute;
  inset:auto 0 0 0;
  height:58%;
  background:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size:54px 54px;
  mask-image:linear-gradient(180deg, transparent 0%, rgba(0,0,0,.85) 26%);
  transform:perspective(800px) rotateX(66deg) translateY(120px);
  transform-origin:center top;
}
.beam{
  position:absolute;
  top:-10%;
  width:42%;
  height:88%;
  filter:blur(10px);
  opacity:.42;
  animation:floatBeam 6s ease-in-out infinite;
}
.beam-a{
  left:10%;
  background:linear-gradient(180deg, rgba(214,255,114,.35), transparent 70%);
  clip-path:polygon(40% 0%, 60% 0%, 100% 100%, 0% 100%);
}
.beam-b{
  left:34%;
  animation-delay:-1.8s;
  background:linear-gradient(180deg, rgba(45,230,174,.3), transparent 70%);
  clip-path:polygon(45% 0%, 55% 0%, 92% 100%, 8% 100%);
}
.beam-c{
  left:58%;
  animation-delay:-3.3s;
  background:linear-gradient(180deg, rgba(156,231,55,.28), transparent 72%);
  clip-path:polygon(44% 0%, 56% 0%, 90% 100%, 10% 100%);
}
@keyframes floatBeam{
  0%,100%{transform:translateY(0) scaleX(1)}
  50%{transform:translateY(12px) scaleX(1.06)}
}
.floating-card{
  position:absolute;
  display:grid;
  gap:4px;
  min-width:180px;
  padding:18px 18px 16px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(6,17,15,.7);
  backdrop-filter:blur(12px);
  box-shadow:0 18px 36px rgba(0,0,0,.25);
}
.floating-card strong{font-size:18px}
.floating-card span{font-size:13px;color:var(--muted)}
.card-plan{top:18%;left:7%}
.card-heatmap{top:9%;right:8%}
.card-export{bottom:12%;left:31%}

.proof-strip,.comparison-grid,.feature-grid,.workflow,.audience-grid{
  display:grid;
  gap:18px;
}
.app-demo-section,
.video-section{
  padding-top:30px;
}
.app-demo-browser{
  border:1px solid var(--line);
  border-radius:28px;
  overflow:hidden;
  background:rgba(255,255,255,.03);
  box-shadow:var(--shadow);
}
.demo-gallery{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:18px;
}
.demo-card{
  padding:18px;
  border:1px solid var(--line);
  border-radius:24px;
  background:rgba(255,255,255,.92);
  box-shadow:var(--shadow);
}
.demo-card h3{
  margin:0 0 8px;
  font-size:20px;
  letter-spacing:-.03em;
}
.demo-card p{
  margin:0 0 14px;
  color:var(--muted);
  font-size:15px;
  line-height:1.6;
}
.mini-app{
  position:relative;
  aspect-ratio:16 / 10;
  overflow:hidden;
  border-radius:20px;
  border:1px solid rgba(16,38,31,.08);
  background:linear-gradient(180deg,#fcfffd 0%, #eef5f0 100%);
}
.mini-app::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(rgba(122,146,134,.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(122,146,134,.08) 1px, transparent 1px);
  background-size:16% 18%;
}
.mini-toolbar{
  position:absolute;
  left:10px;
  right:10px;
  top:10px;
  height:18px;
  border-radius:999px;
  background:rgba(18,36,30,.08);
}
.mini-panel{
  position:absolute;
  inset:auto 12px 12px 12px;
  height:38px;
  border-radius:16px;
  background:rgba(255,255,255,.9);
  border:1px solid rgba(16,38,31,.08);
}
.demo-cursor{
  position:absolute;
  width:18px;
  height:18px;
  border-radius:50%;
  background:#111;
  box-shadow:0 0 0 4px rgba(98,215,169,.22);
  z-index:4;
}
.demo-cursor::after{
  content:"";
  position:absolute;
  inset:5px;
  border-radius:50%;
  background:#fff;
  opacity:.4;
}
.demo-floorplan-sheet{
  position:absolute;
  inset:26% 16% 20% 16%;
  border-radius:18px;
  border:1px dashed rgba(16,38,31,.22);
  background:rgba(255,255,255,.82);
}
.demo-upload-badge{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  padding:8px 14px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  color:#0b1712;
  font-size:13px;
  font-weight:700;
}
.demo-progress{
  position:absolute;
  left:18%;
  right:18%;
  bottom:18%;
  height:8px;
  border-radius:999px;
  background:rgba(18,36,30,.08);
  overflow:hidden;
}
.demo-progress::after{
  content:"";
  position:absolute;
  inset:0 auto 0 0;
  width:32%;
  border-radius:999px;
  background:linear-gradient(90deg,var(--brand),var(--brand-2));
}
.demo-room-outline{
  position:absolute;
  left:17%;
  top:23%;
  width:52%;
  height:42%;
  border:3px solid #182c24;
  border-radius:14px;
  opacity:0;
  transform:scale(.92);
}
.demo-room-fill{
  position:absolute;
  left:17%;
  top:23%;
  width:52%;
  height:42%;
  border-radius:14px;
  background:rgba(98,215,169,.18);
  opacity:0;
}
.demo-furniture-block{
  position:absolute;
  width:32%;
  height:14%;
  left:30%;
  top:44%;
  border-radius:18px;
  background:linear-gradient(180deg,#8f9cad,#7b8798);
  box-shadow:0 12px 20px rgba(15,23,42,.14);
  opacity:0;
}
.demo-light-dot{
  position:absolute;
  width:16px;
  height:16px;
  border-radius:50%;
  background:#23362d;
  top:30%;
  left:48%;
  opacity:0;
}
.demo-light-glow{
  position:absolute;
  width:42%;
  height:28%;
  left:30%;
  top:34%;
  border-radius:50%;
  background:radial-gradient(circle, rgba(255,214,120,.58) 0%, rgba(245,242,170,.24) 48%, rgba(245,242,170,0) 78%);
  opacity:0;
}
.demo-filter-chip{
  position:absolute;
  top:28%;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(16,38,31,.12);
  background:#fff;
  font-size:12px;
  font-weight:700;
  color:#485d54;
}
.demo-filter-chip.chip-a{ left:10%; }
.demo-filter-chip.chip-b{ left:38%; }
.demo-filter-chip.chip-c{ left:64%; }
.demo-product-card{
  position:absolute;
  width:26%;
  height:28%;
  top:46%;
  border-radius:18px;
  background:#fff;
  border:1px solid rgba(16,38,31,.08);
  box-shadow:0 12px 18px rgba(15,23,42,.08);
  opacity:0;
}
.demo-product-card::before{
  content:"";
  position:absolute;
  left:14%;
  right:14%;
  top:16%;
  height:40%;
  border-radius:14px;
  background:linear-gradient(180deg,#f8fafb,#e7edf0);
}
.demo-product-card::after{
  content:"";
  position:absolute;
  left:16%;
  right:16%;
  bottom:18%;
  height:10%;
  border-radius:999px;
  background:rgba(16,38,31,.12);
}
.demo-product-card.card-a{ left:10%; }
.demo-product-card.card-b{ left:37%; }
.demo-product-card.card-c{ left:64%; }
.demo-upload .demo-floorplan-sheet{ animation:sheetFloat 4.2s ease-in-out infinite; }
.demo-upload .demo-progress::after{ animation:progressFill 4.2s ease-in-out infinite; }
.demo-upload .demo-cursor{ animation:cursorUpload 4.2s ease-in-out infinite; }
.demo-draw .demo-room-outline{ animation:roomOutline 4.4s ease-in-out infinite; }
.demo-draw .demo-room-fill{ animation:roomFill 4.4s ease-in-out infinite; }
.demo-draw .demo-cursor{ animation:cursorDraw 4.4s ease-in-out infinite; }
.demo-light .demo-light-dot{ animation:lightDot 4s ease-in-out infinite; }
.demo-light .demo-light-glow{ animation:lightGlow 4s ease-in-out infinite; }
.demo-light .demo-cursor{ animation:cursorLight 4s ease-in-out infinite; }
.demo-furniture .demo-furniture-block{ animation:furnitureSnap 4.3s ease-in-out infinite; }
.demo-furniture .demo-cursor{ animation:cursorFurniture 4.3s ease-in-out infinite; }
.demo-filter .chip-a,
.demo-filter .chip-b,
.demo-filter .chip-c{ animation:chipSelect 4.8s ease-in-out infinite; }
.demo-filter .chip-b{ animation-delay:.18s; }
.demo-filter .chip-c{ animation-delay:.36s; }
.demo-filter .card-a{ animation:productReveal 4.8s ease-in-out infinite; }
.demo-filter .card-b{ animation:productReveal 4.8s ease-in-out infinite .15s; }
.demo-filter .card-c{ animation:productReveal 4.8s ease-in-out infinite .3s; }
.demo-filter .demo-cursor{ animation:cursorFilter 4.8s ease-in-out infinite; }
.app-demo-chrome{
  display:flex;
  align-items:center;
  gap:8px;
  padding:14px 18px;
  border-bottom:1px solid var(--line);
  background:rgba(255,255,255,.03);
}
.app-demo-chrome span{
  width:10px;
  height:10px;
  border-radius:50%;
  background:rgba(255,255,255,.18);
}
.app-demo-canvas{
  position:relative;
  min-height:420px;
  background:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px),
    radial-gradient(circle at 80% 20%, rgba(45,230,174,.14), transparent 18rem),
    linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01));
  background-size:44px 44px,44px 44px,auto,auto;
}
.app-demo-room,
.app-demo-strip,
.app-demo-spot,
.app-demo-heat,
.app-demo-cursor{
  position:absolute;
}
.app-demo-room{
  border:2px solid rgba(255,255,255,.85);
  background:rgba(156,231,55,.08);
}
.room-a{left:10%;top:18%;width:34%;height:38%}
.room-b{left:40%;top:28%;width:40%;height:34%}
.app-demo-strip{
  height:7px;
  border-radius:999px;
  background:linear-gradient(90deg,#d6ff72,#2de6ae);
  box-shadow:0 0 20px rgba(214,255,114,.38);
}
.strip-a{left:17%;top:28%;width:18%}
.strip-b{left:52%;top:39%;width:22%}
.app-demo-spot{
  width:16px;
  height:16px;
  border-radius:50%;
  background:#fff;
  box-shadow:0 0 0 7px rgba(255,255,255,.12),0 0 26px rgba(214,255,114,.24);
}
.spot-a{left:22%;top:48%}
.spot-b{left:29%;top:48%}
.spot-c{left:62%;top:53%}
.app-demo-heat{
  border-radius:50%;
  background:radial-gradient(circle, rgba(255,176,32,.4), rgba(255,176,32,0));
  filter:blur(10px);
}
.heat-a{left:14%;top:42%;width:120px;height:120px}
.heat-b{left:54%;top:47%;width:130px;height:130px}
.app-demo-cursor{
  width:26px;
  height:34px;
  background:linear-gradient(180deg,#eff8f3,#d6ff72);
  clip-path:polygon(0 0, 0 100%, 28% 76%, 52% 100%, 66% 92%, 42% 68%, 76% 68%);
  filter:drop-shadow(0 12px 18px rgba(0,0,0,.35));
  animation:demoCursor 5.6s ease-in-out infinite;
}
@keyframes demoCursor{
  0%{left:20%;top:24%}
  28%{left:30%;top:36%}
  54%{left:61%;top:42%}
  78%{left:66%;top:54%}
  100%{left:20%;top:24%}
}
.video-frame{
  overflow:hidden;
  border-radius:28px;
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  background:#050908;
}
.video-frame iframe{
  display:block;
  width:100%;
  aspect-ratio:16/9;
  border:0;
}
.proof-strip{
  grid-template-columns:repeat(3,1fr);
  margin:6px 0 28px;
}
.proof-strip > div,.comparison-card,.feature-card,.workflow article,.audience-grid article,.cta-section,.site-footer,.auth-dialog-card{
  border:1px solid var(--line);
  border-radius:24px;
  background:rgba(255,255,255,.92);
  box-shadow:var(--shadow);
}
.proof-strip > div{
  padding:18px 20px;
  color:var(--muted);
}
.content-section{
  padding:42px 0;
}
.content-section.alt{
  position:relative;
}
.content-section.alt::before{
  content:"";
  position:absolute;
  inset:12px -40px;
  border-radius:34px;
  background:linear-gradient(180deg, rgba(255,255,255,.85), rgba(255,255,255,.55));
  z-index:-1;
}
.section-heading{
  max-width:880px;
  margin-bottom:24px;
}
.section-heading h2{font-size:clamp(34px,4vw,54px)}
.comparison-grid{
  grid-template-columns:repeat(3,1fr);
}
.comparison-table-wrap{
  overflow:auto;
  border:1px solid var(--line);
  border-radius:24px;
  background:rgba(255,255,255,.03);
  box-shadow:var(--shadow);
}
.comparison-table{
  width:100%;
  min-width:860px;
  border-collapse:collapse;
}
.comparison-table th,
.comparison-table td{
  padding:16px 18px;
  border-bottom:1px solid var(--line);
  vertical-align:top;
  text-align:left;
}
.comparison-table thead th{
  background:rgba(98,215,169,.08);
  font-size:14px;
}
.comparison-table tbody th{
  width:22%;
  color:var(--text);
}
.comparison-table td{
  color:var(--muted);
}
.comparison-table tbody td:last-child{
  color:var(--text);
  background:rgba(156,231,55,.10);
}
.comparison-card,.feature-card,.workflow article,.audience-grid article{
  padding:24px;
}
.comparison-card.highlight{
  border-color:rgba(156,231,55,.35);
  background:linear-gradient(180deg, rgba(156,231,55,.08), rgba(45,230,174,.08));
}
.feature-grid{
  grid-template-columns:repeat(3,1fr);
}
.feature-card.media{
  grid-column:span 1;
  display:grid;
  gap:18px;
}
.feature-card.media img{
  width:100%;
  aspect-ratio:1.2;
  object-fit:cover;
  border-radius:18px;
  background:#fff;
}
.workflow{
  grid-template-columns:repeat(4,1fr);
}
.workflow article span{
  display:inline-grid;
  place-items:center;
  width:48px;
  height:48px;
  border-radius:14px;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  color:#08110f;
  font-weight:700;
}
.audience-grid{
  grid-template-columns:repeat(3,1fr);
}

.faq-list{
  display:grid;
  gap:12px;
}
.faq-list details{
  border:1px solid var(--line);
  border-radius:20px;
  background:rgba(255,255,255,.03);
  padding:18px 20px;
}
.faq-list summary{
  cursor:pointer;
  font-weight:700;
}
.faq-list p{margin:12px 0 0}

.cta-section,.site-footer{
  display:flex;
  justify-content:space-between;
  gap:24px;
  padding:28px;
  margin:22px 0 36px;
}
.site-footer{
  width:min(1240px,calc(100% - 40px));
  margin:0 auto 32px;
  align-items:flex-start;
  border-top:1px solid rgba(16,38,31,.08);
}
.site-footer-nav{
  display:grid;
  gap:10px;
}
.site-footer-nav strong{
  font-size:14px;
}
.footer-links{
  justify-content:flex-end;
}
.footer-links a{color:var(--muted)}
.prose-page{
  padding:56px 0 40px;
}
.prose-grid{
  display:grid;
  grid-template-columns:280px minmax(0,1fr);
  gap:28px;
  align-items:start;
}
.toc-card,
.prose-card{
  border:1px solid var(--line);
  border-radius:24px;
  background:rgba(255,255,255,.92);
  box-shadow:var(--shadow);
}
.toc-card{
  position:sticky;
  top:102px;
  padding:22px;
}
.toc-card nav{
  display:grid;
  gap:10px;
}
.toc-card a{
  color:var(--muted);
}
.toc-card a:hover{
  color:var(--text);
}
.prose-card{
  padding:28px;
}
.prose-card h2,
.prose-card h3{
  margin-top:0;
}
.prose-card section + section{
  margin-top:28px;
  padding-top:28px;
  border-top:1px solid var(--line);
}
.prose-card ul{
  margin:14px 0 0;
  padding-left:18px;
  color:var(--muted);
  line-height:1.75;
}
.page-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:20px;
}

.auth-dialog{
  border:none;
  background:transparent;
  padding:0;
}
.auth-dialog::backdrop{
  background:rgba(18,36,30,.22);
  backdrop-filter:blur(6px);
}
.auth-dialog-card{
  width:min(520px,calc(100vw - 24px));
  margin:auto;
  padding:28px;
  position:relative;
  background:#ffffff;
  color:var(--text);
  box-shadow:0 28px 70px rgba(16,38,31,.18);
}
.auth-dialog-card h2,
.auth-dialog-card label,
.auth-dialog-card strong{
  color:var(--text);
}
.auth-dialog-card .eyebrow{
  color:#56745f;
}
.auth-intro{
  color:#445a50;
}
.auth-close{
  position:absolute;
  top:16px;
  right:16px;
  width:42px;
  height:42px;
  border-radius:999px;
}
.auth-dialog-card label{
  display:grid;
  gap:8px;
  margin-top:18px;
  font-size:14px;
}
.auth-dialog-card input{
  width:100%;
  border:1px solid var(--line);
  border-radius:16px;
  padding:14px 16px;
  background:var(--panel-soft);
  color:var(--text);
}
.auth-divider{
  display:flex;
  align-items:center;
  gap:12px;
  margin:18px 0;
  color:var(--muted);
}
.auth-divider::before,.auth-divider::after{
  content:"";
  flex:1;
  height:1px;
  background:var(--line);
}
.auth-provider{
  width:100%;
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-top:10px;
}
.auth-provider span:first-of-type{
  display:inline-flex;
  align-items:center;
  gap:12px;
}
.auth-provider-icon{
  width:22px;
  height:22px;
  display:inline-grid;
  place-items:center;
  color:#111;
}
.auth-provider-icon svg{
  width:100%;
  height:100%;
}
.auth-provider small{color:var(--muted)}
.auth-session{
  margin-top:18px;
  padding:18px;
  border-radius:18px;
  background:rgba(156,231,55,.1);
  border:1px solid rgba(156,231,55,.22);
}
@keyframes sheetFloat{
  0%,100%{ transform:translateY(14px) scale(.96); opacity:.82; }
  18%,72%{ transform:translateY(0) scale(1); opacity:1; }
}
@keyframes progressFill{
  0%{ width:0; }
  20%{ width:8%; }
  58%{ width:86%; }
  100%{ width:86%; }
}
@keyframes cursorUpload{
  0%,100%{ transform:translate(24px,18px); }
  28%{ transform:translate(120px,72px); }
  55%{ transform:translate(150px,74px); }
  80%{ transform:translate(188px,128px); }
}
@keyframes roomOutline{
  0%,18%{ opacity:0; transform:scale(.92); }
  30%,100%{ opacity:1; transform:scale(1); }
}
@keyframes roomFill{
  0%,34%{ opacity:0; }
  48%,100%{ opacity:1; }
}
@keyframes cursorDraw{
  0%,8%{ transform:translate(34px,52px); }
  24%{ transform:translate(160px,52px); }
  42%{ transform:translate(160px,130px); }
  60%{ transform:translate(34px,130px); }
  76%,100%{ transform:translate(34px,52px); }
}
@keyframes lightDot{
  0%,18%{ opacity:0; transform:scale(.6); }
  32%,100%{ opacity:1; transform:scale(1); }
}
@keyframes lightGlow{
  0%,26%{ opacity:0; transform:scale(.7); }
  40%,100%{ opacity:1; transform:scale(1); }
}
@keyframes cursorLight{
  0%,14%{ transform:translate(34px,48px); }
  30%,100%{ transform:translate(140px,76px); }
}
@keyframes furnitureSnap{
  0%,18%{ opacity:0; transform:translate(40px,18px) scale(.92); }
  36%,100%{ opacity:1; transform:translate(0,0) scale(1); }
}
@keyframes cursorFurniture{
  0%,18%{ transform:translate(148px,44px); }
  40%{ transform:translate(116px,98px); }
  72%,100%{ transform:translate(116px,98px); }
}
@keyframes chipSelect{
  0%,100%{
    background:#fff;
    color:#485d54;
    border-color:rgba(16,38,31,.12);
  }
  25%,72%{
    background:rgba(156,231,55,.22);
    color:#183026;
    border-color:rgba(98,215,169,.42);
  }
}
@keyframes productReveal{
  0%,18%{ opacity:0; transform:translateY(18px) scale(.96); }
  34%,100%{ opacity:1; transform:translateY(0) scale(1); }
}
@keyframes cursorFilter{
  0%,12%{ transform:translate(28px,24px); }
  28%{ transform:translate(92px,54px); }
  46%{ transform:translate(164px,54px); }
  64%{ transform:translate(228px,54px); }
  82%,100%{ transform:translate(228px,54px); }
}

@media (max-width: 1100px){
  .hero,.comparison-grid,.workflow,.audience-grid,.feature-grid,.proof-strip{
    grid-template-columns:1fr;
  }
  .site-header{
    flex-wrap:wrap;
  }
  .site-nav{
    order:3;
    width:100%;
    justify-content:flex-start;
  }
}
@media (max-width: 720px){
  main,.site-footer{width:min(100% - 24px, 1240px)}
  .site-header{padding:14px 12px}
  .hero{padding-top:38px}
  .hero-visual,.light-stage{min-height:420px}
  .cta-section,.site-footer{flex-direction:column}
  .prose-grid{grid-template-columns:1fr}
  .toc-card{position:static}
}
