:root{
  --paper:#f4efe6;
  --paper-2:#efe8db;
  --ink:#211d18;
  --muted:#6f675c;
  --forest:#234b3f;
  --forest-deep:#1c3d33;
  --coral:#ff6a4d;
  --coral-deep:#ec4f31;
  --coral-ink:#b53419;
  --peach:#fbe4d4;
  --sand:#e7ddcd;
  --card:#fbf8f2;
  --display:'Unbounded', system-ui, sans-serif;
  --body:'Onest', system-ui, -apple-system, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
h1,h2,h3{font-family:var(--display);line-height:1.04;letter-spacing:-0.02em;font-weight:700}
a{color:inherit;text-decoration:none}
img,svg{display:block}

/* buttons */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--body);font-weight:600;font-size:1.02rem;
  border-radius:999px;padding:15px 26px;border:1.6px solid transparent;
  cursor:pointer;transition:transform .18s ease, background .2s ease, box-shadow .2s ease;
  white-space:nowrap;
}
.btn-primary{background:var(--coral);color:var(--ink);font-weight:700;box-shadow:0 10px 26px -10px rgba(255,106,77,.7)}
.btn-primary:hover{background:var(--coral-deep);transform:translateY(-2px);box-shadow:0 16px 30px -10px rgba(255,106,77,.75)}
.btn-ghost{background:transparent;border-color:rgba(33,29,24,.22);color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn-light{background:#fff;color:var(--ink)}
.btn-light:hover{transform:translateY(-2px);box-shadow:0 16px 30px -12px rgba(0,0,0,.35)}
.btn:focus-visible{outline:3px solid var(--forest);outline-offset:3px}
.btn-lg{padding:18px 34px;font-size:1.1rem}

/* header */
header{
  position:sticky;top:0;z-index:50;
  transition:transform .3s ease, padding .3s ease;
  padding:18px 0;
}
header.scrolled{transform:translateY(-100%)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:20px}
.logo{display:inline-flex;align-items:baseline;gap:2px;font-family:var(--display);font-weight:700;font-size:1.32rem;letter-spacing:-0.03em}
.logo .dot{color:var(--coral)}
.nav-links{display:flex;gap:30px;font-weight:500;font-size:.98rem;color:var(--muted)}
.nav-links a{transition:color .18s}
.nav-links a:hover{color:var(--ink)}
@media(max-width:860px){.nav-links{display:none}}

/* hero */
.hero{padding:46px 0 70px;position:relative}
.hero-grid{display:flex;flex-direction:column;align-items:center;gap:44px}
.hero-copy{text-align:center;max-width:720px}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--peach);color:var(--coral-ink);
  font-weight:600;font-size:.86rem;letter-spacing:.01em;
  padding:8px 15px;border-radius:999px;margin-bottom:24px;
}
.hero h1{font-size:clamp(2.6rem,6vw,4.3rem);font-weight:800}
.hero h1 .accent{color:var(--coral-ink)}
.hero .sub{font-size:1.22rem;color:var(--muted);margin:24px 0 32px;max-width:none;line-height:1.5}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.trust{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:26px;font-size:.95rem;color:var(--muted)}
.hero-demo{width:100%}
.hero-demo .ba{aspect-ratio:16/7;border-radius:20px;margin-left:auto;margin-right:auto}
.avatars{display:flex}
.avatars span{
  width:34px;height:34px;border-radius:50%;border:2.5px solid var(--paper);
  margin-left:-10px;display:grid;place-items:center;color:#fff;font-weight:700;font-size:.8rem;
}
.avatars span:first-child{margin-left:0}
.stars{color:var(--coral-deep)}

/* before-after slider */
.ba{
  position:relative;width:100%;aspect-ratio:600/450;
  border-radius:24px;overflow:hidden;background:var(--sand);
  box-shadow:0 30px 60px -28px rgba(33,29,24,.45);
  touch-action:none;user-select:none;cursor:ew-resize;
  --pos:50%;
}
.ba .layer{position:absolute;inset:0}
.ba .scene{width:100%;height:100%;object-fit:cover}
.ba .layer-before{clip-path:inset(0 calc(100% - var(--pos)) 0 0)}
.ba-divider{position:absolute;top:0;bottom:0;left:var(--pos);width:3px;background:#fff;transform:translateX(-1.5px);box-shadow:0 0 0 1px rgba(0,0,0,.06)}
.ba-handle{
  position:absolute;top:50%;left:50%;translate:-50% -50%;
  width:48px;height:48px;border-radius:50%;background:#fff;border:none;
  box-shadow:0 6px 16px rgba(0,0,0,.28);display:grid;place-items:center;
  cursor:ew-resize;color:var(--ink);
}
.ba-handle svg{width:22px;height:22px}
.ba-handle:focus-visible{outline:3px solid var(--coral);outline-offset:3px}
.ba-tag{
  position:absolute;top:14px;font-size:.78rem;font-weight:700;letter-spacing:.04em;
  text-transform:uppercase;padding:6px 12px;border-radius:999px;backdrop-filter:blur(4px);
}
.ba-tag.before{left:14px;background:rgba(28,25,21,.66);color:#fff}
.ba-tag.after{right:14px;background:#fff;color:var(--coral-ink)}
.ba-frame{position:relative}
.ba-cap{margin-top:12px;font-size:.9rem;line-height:1.55;color:var(--muted)}
.ba-room{display:inline;font-weight:700;text-transform:uppercase;font-size:.75rem;letter-spacing:.07em;color:var(--coral-ink)}
.ba-room::after{content:' · ';color:var(--sand);font-weight:400;letter-spacing:0}
.ba-prompt{display:inline;font-size:.9rem;color:var(--muted)}
.reactions .gal-grid{margin-top:48px;padding:0 24px}

/* sections */
section{position:relative}
.sec-head{text-align:center;max-width:680px;margin:0 auto 50px}
.sec-head .kicker{color:var(--coral-ink);font-weight:600;letter-spacing:.05em;text-transform:uppercase;font-size:.82rem}
.sec-head h2{font-size:clamp(2rem,4.4vw,3rem);margin-top:14px}
.sec-head p{color:var(--muted);font-size:1.12rem;margin-top:16px}

/* reactions */
.reactions{padding:30px 0 90px}
.react-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}
.react{
  background:var(--card);border:1px solid var(--sand);border-radius:20px;padding:24px;
  box-shadow:0 14px 30px -22px rgba(33,29,24,.4);transition:transform .25s ease;
  display:flex;flex-direction:column;
}
.react .who{margin-top:auto;padding-top:18px}
.react:nth-child(odd){transform:rotate(-1.1deg)}
.react:nth-child(even){transform:rotate(1deg)}
.react:hover{transform:rotate(0) translateY(-4px)}
.react .quote{font-family:var(--display);font-weight:600;font-size:1.18rem;line-height:1.25;letter-spacing:-0.01em}
.react .quote.big{color:var(--coral-ink)}
.react .who{display:flex;align-items:center;gap:11px}
.react .who .av{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:.85rem}
.react .who .meta{font-size:.86rem;line-height:1.25}
.react .who .meta b{display:block;font-weight:600}
.react .who .meta span{color:var(--muted)}

/* steps */
.steps-sec{background:var(--paper-2);padding:90px 0;border-top:1px solid var(--sand);border-bottom:1px solid var(--sand)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:auto auto auto;gap:24px;margin-top:8px}
.step{background:var(--card);border-radius:22px;padding:32px;border:1px solid var(--sand);display:grid;grid-template-columns:auto 1fr;grid-template-rows:subgrid;grid-row:span 3;gap:0 14px;align-items:center}
.step .num{font-family:var(--display);font-weight:800;font-size:1rem;color:var(--coral);letter-spacing:.04em;align-self:center}
.step .ico{width:54px;height:54px;border-radius:16px;background:var(--peach);display:grid;place-items:center;margin:0;justify-self:end}
.step .ico svg{width:28px;height:28px;color:var(--coral-deep)}
.step h3{grid-column:1/-1;font-size:1.34rem;font-weight:700;margin-top:18px;margin-bottom:0;align-self:start}
.step p{grid-column:1/-1;color:var(--muted);margin-top:10px;margin-bottom:0;align-self:start}
@media(max-width:760px){.steps{grid-template-columns:1fr}}

/* gallery */
.gallery{padding:90px 0}
.gal-grid{display:grid;grid-template-columns:1fr;gap:40px}
.gal-grid .ba{aspect-ratio:16/9;border-radius:20px}

/* ideas / suggestions */
.ideas-sec{background:var(--paper-2);padding:90px 0;border-top:1px solid var(--sand);border-bottom:1px solid var(--sand)}
.ideas-card{display:grid;grid-template-columns:.85fr 1.15fr;gap:8px;background:var(--card);border:1px solid var(--sand);border-radius:26px;padding:8px;box-shadow:0 24px 50px -32px rgba(33,29,24,.5);max-width:980px;margin:0 auto}
.ideas-photo{position:relative;border-radius:20px;overflow:hidden;min-height:280px;background:var(--sand)}
.ideas-scene{position:absolute;inset:0}
.ideas-scene svg{width:100%;height:100%}
.ideas-detected{position:absolute;left:14px;bottom:14px;background:rgba(33,29,24,.74);color:#fff;font-size:.82rem;font-weight:600;padding:7px 13px;border-radius:999px;backdrop-filter:blur(4px)}
.ideas-detected::before{content:"";display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--coral);margin-right:7px;vertical-align:middle}
.ideas-panel{padding:28px 26px;display:flex;flex-direction:column}
.ideas-lead{font-family:var(--display);font-weight:600;font-size:1.24rem;letter-spacing:-0.01em;margin-bottom:18px}
.ideas-chips{display:flex;flex-wrap:wrap;gap:10px}
.idea{
  font-family:var(--body);font-weight:600;font-size:.96rem;color:var(--forest);
  background:var(--paper);border:1.4px solid var(--sand);border-radius:999px;
  padding:10px 17px;cursor:pointer;transition:all .18s ease;
}
.idea:hover{border-color:var(--coral);background:#fff;color:var(--coral-ink);transform:translateY(-2px)}
.idea:focus-visible{outline:3px solid var(--coral);outline-offset:2px}
.ideas-input{display:flex;gap:8px;margin-top:22px}
.ideas-input input{
  flex:1;font-family:var(--body);font-size:1rem;color:var(--ink);
  background:var(--paper);border:1.4px solid var(--sand);border-radius:14px;padding:13px 16px;
}
.ideas-input input:focus{outline:none;border-color:var(--forest)}
.idea-send{
  width:50px;flex:0 0 50px;border:none;border-radius:14px;background:var(--coral);color:#fff;
  cursor:pointer;display:grid;place-items:center;transition:background .2s ease, transform .18s ease;
}
.idea-send svg{width:22px;height:22px}
.idea-send:hover{background:var(--coral-deep);transform:translateY(-2px)}
.idea-send:focus-visible{outline:3px solid var(--forest);outline-offset:2px}
.ideas-foot{margin-top:auto;padding-top:20px;color:var(--muted);font-size:.92rem}
@media(max-width:760px){.ideas-card{grid-template-columns:1fr}.ideas-photo{min-height:220px}}

/* pricing */
.pricing-sec{padding:90px 0;background:var(--paper-2);border-top:1px solid var(--sand);border-bottom:1px solid var(--sand)}
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,360px));gap:20px;justify-content:center}
.price-card{background:var(--card);border:1px solid var(--sand);border-radius:24px;padding:32px;display:flex;flex-direction:column;gap:14px}
.price-card--featured{background:var(--forest);border-color:var(--forest);color:#fff}
.price-label{font-family:var(--display);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.price-card--featured .price-label{color:rgba(255,255,255,.6)}
.price-badge{display:inline-block;background:var(--coral);color:#fff;font-size:.78rem;font-weight:700;padding:4px 12px;border-radius:20px;align-self:flex-start}
.price-amount{display:flex;align-items:baseline;gap:8px}
.price-num{font-family:var(--display);font-size:2.4rem;font-weight:800;line-height:1;color:var(--ink)}
.price-card--featured .price-num{color:#fff}
.price-per{font-size:.9rem;color:var(--muted)}
.price-card--featured .price-per{color:rgba(255,255,255,.6)}
.price-desc{color:var(--muted);font-size:.97rem;margin:0;flex:1}
.price-card--featured .price-desc{color:rgba(255,255,255,.8)}
.price-features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;font-size:.95rem}
.price-features li{display:flex;align-items:center;gap:8px;color:var(--muted)}
.price-card--featured .price-features li{color:rgba(255,255,255,.85)}
.price-features .bi{color:var(--coral);font-size:1rem;flex-shrink:0}
.price-cta{width:100%;justify-content:center;margin-top:8px}
@media(max-width:760px){.pricing-grid{grid-template-columns:1fr}}

/* final cta */
.cta-sec{padding:30px 0 100px}
.cta-panel{
  background:var(--forest);color:#fff;border-radius:34px;
  padding:70px 48px;text-align:center;position:relative;overflow:hidden;
}
.cta-panel::before{content:"";position:absolute;top:-80px;right:-60px;width:280px;height:280px;border-radius:50%;background:rgba(255,106,77,.22)}
.cta-panel::after{content:"";position:absolute;bottom:-100px;left:-40px;width:240px;height:240px;border-radius:50%;background:rgba(255,255,255,.06)}
.cta-panel > *{position:relative;z-index:1}
.cta-panel h2{font-size:clamp(2.1rem,4.6vw,3.2rem);font-weight:800}
.cta-panel h2 em{font-style:normal;color:var(--coral)}
.cta-panel p{color:rgba(255,255,255,.82);font-size:1.18rem;margin:18px auto 0;max-width:46ch}
.dropzone{
  margin:36px auto 22px;max-width:480px;background:rgba(255,255,255,.07);
  border:2px dashed rgba(255,255,255,.35);border-radius:20px;padding:34px 20px;
  cursor:pointer;transition:all .2s ease;
}
.dropzone:hover{background:rgba(255,255,255,.12);border-color:#fff}
.dropzone .dz-ico{width:46px;height:46px;margin:0 auto 12px;color:#fff;opacity:.9}
.dropzone .dz-ico svg{width:46px;height:46px}
.dropzone b{display:block;font-size:1.08rem}
.dropzone span{color:rgba(255,255,255,.6);font-size:.92rem}
.cta-note{color:rgba(255,255,255,.72);font-size:.95rem;margin-top:6px}

/* footer */
footer{padding:54px 0;border-top:1px solid var(--sand)}
.foot{display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between;align-items:center}
.foot-links{display:flex;gap:26px;flex-wrap:wrap;color:var(--muted);font-size:.96rem}
.foot-links a:hover{color:var(--ink)}
.foot .tag{color:var(--muted);font-size:.9rem;width:100%;border-top:1px solid var(--sand);padding-top:20px;margin-top:10px}

/* toast */
.toast{
  position:fixed;left:50%;bottom:26px;translate:-50% 80px;opacity:0;
  background:var(--ink);color:#fff;padding:14px 22px;border-radius:14px;
  font-weight:500;z-index:90;transition:all .35s ease;box-shadow:0 16px 40px -14px rgba(0,0,0,.5);
  max-width:90vw;text-align:center;
}
.toast.show{translate:-50% 0;opacity:1}

/* reveal */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1;transform:none}

@media (prefers-reduced-motion: reduce){
  *{scroll-behavior:auto}
  .reveal{transition:none;opacity:1;transform:none}
  .btn,.react,.chip,.case,.sugg{transition:none}
  .dot-live::after{animation:none}
}

/* tablet */
@media(max-width:860px){
  .hero{padding:36px 0 56px}
  .hero-grid{gap:32px}
  .steps-sec{padding:70px 0}
  .gallery{padding:70px 0}
  .ideas-sec{padding:70px 0}
  .cta-panel{padding:56px 36px}

  /* images: scale proportionally — aspect-ratio set by JS, height free to follow */
  .ba{width:80%!important;height:auto!important;margin-left:auto!important;margin-right:auto!important}
  .hero-demo .ba{width:100%!important}
}

/* mobile */
@media(max-width:640px){
  .wrap{padding:0 16px}

  /* header */
  header{padding:14px 0}
  header .btn{font-size:.82rem;padding:10px 16px}

  /* hero */
  .hero{padding:24px 0 40px}
  .hero-grid{gap:24px}
  .eyebrow{font-size:.78rem;white-space:normal;text-align:center}
  .hero .sub{font-size:1.05rem}
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn{width:100%;justify-content:center}
  .trust{flex-wrap:wrap;justify-content:center;text-align:center}

  .reactions .gal-grid{padding:0 16px;margin-top:32px}
  .ba{width:100%!important;height:auto!important;margin-left:auto!important;margin-right:auto!important}
  .ba-tag{font-size:.65rem;padding:4px 8px;top:10px}
  .ba-tag.before{left:10px}
  .ba-tag.after{right:10px}
  .ba-handle svg{width:16px;height:16px}

  /* reactions */
  .reactions{padding:24px 0 56px}
  .react:nth-child(odd),.react:nth-child(even){transform:none}

  /* steps */
  .steps-sec{padding:56px 0}
  .steps{grid-template-columns:1fr;grid-template-rows:none}
  .step{grid-row:auto;grid-template-rows:auto;padding:24px}

  /* section heads */
  .sec-head{margin-bottom:32px}
  .sec-head h2{font-size:1.7rem}
  .sec-head p{font-size:1rem}

  /* gallery */
  .gallery{padding:56px 0}

  /* ideas */
  .ideas-sec{padding:56px 0}
  .ideas-panel{padding:20px 16px}
  .ideas-lead{font-size:1.05rem}

  /* cta */
  .cta-sec{padding:16px 0 56px}
  .cta-panel{padding:40px 20px;border-radius:24px}
  .cta-panel h2{font-size:1.8rem}
  .cta-panel p{font-size:1rem}
  .dropzone{padding:24px 16px}
  .cta-btn{width:100%;justify-content:center}

  /* footer */
  .foot{flex-direction:column;align-items:flex-start;gap:16px}
  .foot-links{gap:14px;font-size:.9rem}

}

@media(max-width:360px){
  header .btn{display:none}
}

/* auth modal — landing style */
#modal-auth .auth-modal{
  background:var(--card);
  border-radius:26px;
  border:1px solid var(--sand);
}
#modal-auth .modal-body{
  padding:44px 36px 36px;
  font-family:var(--body);
}
#modal-auth .auth-icon{
  background:var(--peach);
  color:var(--coral);
  border-radius:18px;
}
#modal-auth .auth-title{
  font-family:var(--display);
  font-size:1.7rem;
  font-weight:700;
  letter-spacing:-0.02em;
  color:var(--ink);
}
#modal-auth .auth-subtitle{
  color:var(--muted);
  font-family:var(--body);
}
#modal-auth .auth-input,
#modal-auth .auth-code{
  background:var(--paper);
  border-color:var(--sand);
  font-family:var(--body);
  color:var(--ink);
  border-radius:14px;
}
#modal-auth .auth-input:focus,
#modal-auth .auth-code:focus{
  border-color:var(--forest);
  box-shadow:0 0 0 4px rgba(35,75,63,.1);
}
#modal-auth .auth-btn{
  background:var(--coral);
  color:var(--ink);
  font-family:var(--body);
  font-weight:700;
  border-radius:999px;
  border:none;
  justify-content: center;
}
#modal-auth .auth-btn:hover{
  background:var(--coral-deep);
  color:var(--ink);
}
#modal-auth .auth-btn:disabled{
  opacity:.6;
}
#modal-auth .auth-link{
  color:var(--muted);
  font-family:var(--body);
}
#modal-auth .auth-link:hover{
  color:var(--ink);
  background:transparent;
}
#modal-auth .alert{
  border-radius:12px;
  font-family:var(--body);
  font-size:.9rem;
  border:none;
  background:var(--peach);
  color:var(--coral-ink);
}
