:root{
  --forest:#0E3B2E; --pine:#0A2C22; --emerald:#18936A; --emerald-deep:#0F7A56;
  --emerald-soft:#E3F1E9; --emerald-mist:#F0F7F2;
  --canvas:#FFFFFF; --wash:#F4F8F5; --surface:#FFFFFF; --surface-2:#F1F6F2;
  --gold:#E0A92E; --gold-soft:#F7ECCF;
  --ink:#14241D; --muted:#5B6B62; --faint:#93A89C;
  --line:#E4ECE7; --line-soft:#EFF4F0;
  --danger:#C2453B; --danger-soft:#FBEAE8;
  --shadow-sm:0 1px 2px rgba(14,59,46,.05), 0 2px 8px rgba(14,59,46,.05);
  --shadow-md:0 4px 14px rgba(14,59,46,.08), 0 12px 34px rgba(14,59,46,.07);
  --shadow-lg:0 10px 30px rgba(15,122,86,.16), 0 30px 60px rgba(14,59,46,.12);
  --r-sm:12px; --r-md:18px; --r-lg:26px;
  --ease:cubic-bezier(.22,1,.36,1); --spring:cubic-bezier(.34,1.56,.64,1);
  --frame:430px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{
  font-family:"Plus Jakarta Sans",system-ui,sans-serif;
  background:radial-gradient(1100px 560px at 82% -10%, #ECF6F0 0%, transparent 55%),
             radial-gradient(900px 500px at -10% 110%, #EAF4EE 0%, transparent 50%), var(--wash);
  color:var(--ink);min-height:100vh;min-height:100dvh;display:flex;justify-content:center;align-items:stretch;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea,select{font-family:inherit}
h1,h2,h3,h4{font-family:"Bricolage Grotesque",serif;font-weight:700;margin:0;letter-spacing:-.02em;line-height:1.06}
a{color:var(--emerald-deep)}

#app{width:100%;max-width:var(--frame);background:var(--canvas);position:relative;overflow:hidden;display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;min-height:100svh}
@media(min-width:540px){
  body{padding:26px 16px;align-items:center}
  #app{min-height:auto;height:calc(100dvh - 52px);max-height:920px;border-radius:42px;
    box-shadow:0 40px 90px rgba(14,59,46,.20),0 8px 24px rgba(14,59,46,.12);border:1px solid rgba(255,255,255,.6)}
}
.screen{flex:1;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;position:relative}
.screen::-webkit-scrollbar{width:0}

.pad{padding:20px 20px 28px}
.muted{color:var(--muted)} .faint{color:var(--faint)}
.row{display:flex;align-items:center;gap:10px}
.between{display:flex;align-items:center;justify-content:space-between;gap:10px}
.grow{flex:1;min-width:0}
.eyebrow{font-size:11.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--emerald)}
.center{text-align:center}
.hidden{display:none!important}
.fade-in{animation:fadeIn .5s var(--ease) both}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.spin{width:22px;height:22px;border-radius:50%;border:2.5px solid var(--emerald-soft);border-top-color:var(--emerald);animation:sp .7s linear infinite;display:inline-block}
@keyframes sp{to{transform:rotate(360deg)}}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;border-radius:999px;padding:14px 20px;font-size:15px;transition:transform .18s var(--spring),box-shadow .2s,background .2s,opacity .2s;line-height:1}
.btn:active{transform:scale(.96)}
.btn-primary{background:linear-gradient(180deg,var(--emerald),var(--emerald-deep));color:#fff;box-shadow:var(--shadow-lg)}
.btn-primary:disabled{background:var(--line);color:var(--faint);box-shadow:none;cursor:not-allowed;transform:none}
.btn-forest{background:var(--forest);color:#fff;box-shadow:var(--shadow-md)}
.btn-ghost{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.btn-soft{background:var(--emerald-soft);color:var(--emerald-deep)}
.btn-block{width:100%}
.btn-lg{padding:17px 24px;font-size:16.5px}
.icon-btn{width:42px;height:42px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--surface);box-shadow:var(--shadow-sm);border:1px solid var(--line);flex:none;transition:transform .15s}
.icon-btn:active{transform:scale(.92)}

.field{margin-bottom:14px}
.label{display:block;font-size:13px;font-weight:700;margin-bottom:7px;color:var(--ink)}
.label .hint{font-weight:500;color:var(--faint)}
.input,.textarea,.select{width:100%;background:var(--surface);border:1.5px solid var(--line);border-radius:var(--r-sm);padding:13px 14px;font-size:15px;color:var(--ink);transition:border .15s,box-shadow .15s;outline:none}
.textarea{resize:vertical;min-height:88px;line-height:1.5}
.input:focus,.textarea:focus,.select:focus{border-color:var(--emerald);box-shadow:0 0 0 4px var(--emerald-soft)}
.input::placeholder,.textarea::placeholder{color:var(--faint)}
.err{background:var(--danger-soft);color:var(--danger);border-radius:12px;padding:11px 14px;font-size:13px;font-weight:600;margin-bottom:12px}

.brand{display:flex;align-items:center;gap:10px}
.brand-mark{width:34px;height:34px;border-radius:11px;background:linear-gradient(140deg,var(--emerald),var(--forest));display:flex;align-items:center;justify-content:center;box-shadow:0 6px 16px rgba(15,122,86,.32)}
.brand-mark svg{width:19px;height:19px}
.brand-name{font-family:"Bricolage Grotesque";font-weight:800;font-size:18px;letter-spacing:-.02em}
.brand-name b{color:var(--emerald-deep)}

/* ---------- auth ---------- */
.auth{flex:1;display:flex;flex-direction:column;justify-content:center;padding:34px 26px;position:relative;overflow:hidden}
.auth .blob{position:absolute;border-radius:50%;filter:blur(50px);opacity:.55;z-index:0}
.auth .blob.b1{width:260px;height:260px;background:var(--emerald-soft);top:-60px;right:-70px}
.auth .blob.b2{width:200px;height:200px;background:var(--gold-soft);bottom:-40px;left:-50px}
.auth>*{position:relative;z-index:1}
.auth-logo{width:60px;height:60px;border-radius:18px;background:linear-gradient(140deg,var(--emerald),var(--forest));display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);margin-bottom:20px}
.auth-logo svg{width:32px;height:32px}
.auth h1{font-size:30px}
.auth .sub{color:var(--muted);margin:10px 0 26px;font-size:15px;line-height:1.5}
.auth .toggle-link{margin-top:18px;text-align:center;font-size:13.5px;color:var(--muted)}
.auth .toggle-link button{color:var(--emerald-deep);font-weight:700}
.ok-note{background:var(--emerald-soft);color:var(--forest);border-radius:12px;padding:12px 14px;font-size:13px;font-weight:600;margin-bottom:12px}

/* ---------- dashboard ---------- */
.topbar{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.85);backdrop-filter:blur(14px);padding:16px 20px 12px;border-bottom:1px solid var(--line-soft)}
.stat-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin-top:14px}
.stat{background:var(--surface);border-radius:var(--r-md);padding:13px;box-shadow:var(--shadow-sm);border:1px solid var(--line-soft)}
.stat .n{font-family:"Bricolage Grotesque";font-weight:800;font-size:23px;line-height:1;letter-spacing:-.03em;color:var(--forest)}
.stat .l{font-size:10.5px;color:var(--muted);margin-top:5px;font-weight:600}
.stat.accent .n{color:var(--emerald-deep)} .stat.gold .n{color:var(--gold)}

.section-head{display:flex;align-items:flex-end;justify-content:space-between;margin:22px 0 12px}
.section-head h3{font-size:19px}
.biz-card{display:flex;align-items:center;gap:13px;padding:14px;border-radius:var(--r-md);background:var(--surface);box-shadow:var(--shadow-sm);border:1px solid var(--line-soft);margin-bottom:11px;transition:transform .16s var(--ease);width:100%;text-align:left}
.biz-card:active{transform:scale(.985)}
.biz-logo{width:48px;height:48px;border-radius:14px;flex:none;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:800;color:#fff;font-family:"Bricolage Grotesque";object-fit:cover;overflow:hidden}
.biz-logo img{width:100%;height:100%;object-fit:cover}
.biz-meta{flex:1;min-width:0}
.biz-name{font-weight:700;font-size:15.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.biz-sub{font-size:12.5px;color:var(--muted);margin-top:2px;display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.pill{font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:999px;background:var(--surface-2);color:var(--muted)}
.pill.live{background:var(--emerald-soft);color:var(--emerald-deep)}
.chev{color:var(--faint);flex:none}
.empty{text-align:center;padding:46px 20px;color:var(--muted)}
.empty .emoji{font-size:46px}
.empty h3{margin:14px 0 6px;color:var(--ink)}
.fab{position:absolute;right:18px;bottom:22px;z-index:30}

/* ---------- editor ---------- */
.tabs{display:flex;gap:6px;background:var(--surface-2);padding:5px;border-radius:14px;margin:4px 0 18px}
.tab{flex:1;padding:10px 6px;border-radius:10px;font-size:12.5px;font-weight:700;color:var(--muted);transition:.18s}
.tab.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}
.logo-input-row{display:flex;gap:10px;align-items:center}
.logo-preview{width:52px;height:52px;border-radius:14px;flex:none;display:flex;align-items:center;justify-content:center;font-size:26px;color:#fff;font-family:"Bricolage Grotesque";font-weight:800;background:linear-gradient(140deg,var(--emerald),var(--forest));overflow:hidden}
.logo-preview img{width:100%;height:100%;object-fit:cover}
.var-item{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:10px 12px;margin-bottom:9px}
.var-item.dim{opacity:.5}
.var-item .vname{flex:1;font-weight:600;font-size:14px;border:none;background:transparent;outline:none;min-width:0}
.reorder{display:flex;flex-direction:column;gap:1px;flex:none}
.rmove{width:24px;height:17px;border-radius:6px;background:var(--surface-2);color:var(--muted);font-size:9px;display:flex;align-items:center;justify-content:center;transition:.12s}
.rmove:active{transform:scale(.85)} .rmove:disabled{opacity:.3}
.toggle{width:42px;height:25px;border-radius:999px;background:var(--line);position:relative;transition:background .2s;flex:none}
.toggle.on{background:var(--emerald)}
.toggle::after{content:"";position:absolute;top:3px;left:3px;width:19px;height:19px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.2);transition:transform .2s var(--spring)}
.toggle.on::after{transform:translateX(17px)}
.del-x{color:var(--faint);padding:4px;font-size:18px;line-height:1}
.add-inline{display:flex;gap:8px;margin-top:4px}
.add-inline .input{flex:1}
.kw-tag{display:inline-flex;align-items:center;gap:7px;padding:8px 12px;border-radius:999px;background:var(--surface-2);font-size:13px;font-weight:600;margin:0 7px 7px 0}
.kw-tag .ke{border:none;background:transparent;font-weight:600;font-size:13px;outline:none;width:auto;min-width:40px;max-width:160px}
.kw-tag button.kx{color:var(--faint);font-size:15px;line-height:1}
.tmpl-note{font-size:11.5px;color:var(--faint);margin:-4px 0 10px}

.sticky-foot{position:sticky;bottom:0;background:linear-gradient(to top,var(--canvas) 62%,transparent);padding:14px 20px calc(16px + env(safe-area-inset-bottom));margin-top:auto}

/* ---------- QR sheet ---------- */
.sheet-overlay{position:absolute;inset:0;z-index:60;background:rgba(14,59,46,.42);backdrop-filter:blur(3px);display:flex;align-items:flex-end;animation:ovIn .25s ease both}
@keyframes ovIn{from{opacity:0}to{opacity:1}}
.sheet{width:100%;background:var(--canvas);border-radius:28px 28px 0 0;padding:10px 20px 26px;animation:sheetUp .38s var(--spring) both;max-height:92%;overflow-y:auto}
@keyframes sheetUp{from{transform:translateY(100%)}to{transform:none}}
.sheet-grab{width:42px;height:5px;border-radius:999px;background:var(--line);margin:8px auto 16px}
.qr-box{background:#fff;border-radius:var(--r-lg);padding:22px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);margin:6px auto 18px;width:fit-content;border:1px solid var(--line-soft)}
.qr-box svg{width:208px;height:208px;display:block}
.link-row{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:11px 14px;margin-bottom:10px}
.link-row .lnk-input{flex:1;min-width:0;border:none;background:transparent;outline:none;font-size:12.5px;color:var(--ink)}

.aspect-bar{margin-bottom:10px}
.aspect-bar .between{margin-bottom:5px}
.aspect-bar .tname{font-size:13px;font-weight:600}
.aspect-bar .tval{font-size:12px;font-weight:700;color:var(--emerald-deep)}
.track{height:8px;border-radius:999px;background:var(--surface-2);overflow:hidden}
.track i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--gold),var(--emerald));transition:width .8s var(--ease)}

/* ========== CUSTOMER FLOW ========== */
.cust-top{padding:16px 20px 8px;display:flex;align-items:center;gap:12px}
.progress{flex:1;height:7px;border-radius:999px;background:var(--surface-2);overflow:hidden}
.progress i{display:block;height:100%;background:linear-gradient(90deg,var(--emerald),var(--emerald-deep));border-radius:999px;transition:width .5s var(--ease)}
.step-no{font-size:12px;font-weight:700;color:var(--faint)}

.welcome{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:18px 26px 22px;position:relative;overflow:hidden}
.blob{position:absolute;border-radius:50%;filter:blur(46px);opacity:.5;z-index:0;animation:float 9s ease-in-out infinite}
.blob.b1{width:240px;height:240px;background:var(--emerald-soft);top:-40px;left:-50px}
.blob.b2{width:200px;height:200px;background:var(--gold-soft);bottom:10px;right:-60px;animation-delay:-3s}
.blob.b3{width:150px;height:150px;background:var(--emerald-mist);top:40%;right:-30px;animation-delay:-5s}
@keyframes float{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(12px,-18px) scale(1.08)}}
.welcome>*{position:relative;z-index:1}
.w-logo{width:84px;height:84px;border-radius:26px;display:flex;align-items:center;justify-content:center;font-size:42px;font-weight:800;color:#fff;font-family:"Bricolage Grotesque";box-shadow:var(--shadow-lg);background:linear-gradient(140deg,var(--emerald),var(--forest));animation:pop .6s var(--spring) both;overflow:hidden}
.w-logo img{width:100%;height:100%;object-fit:cover}
@keyframes pop{from{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}
.w-name{font-size:29px;margin-top:18px;animation:fadeIn .6s .1s var(--ease) both}
.w-greet{font-size:15.5px;color:var(--muted);margin-top:10px;line-height:1.5;max-width:300px;animation:fadeIn .6s .2s var(--ease) both}
.w-time{display:inline-flex;align-items:center;gap:7px;margin-top:14px;font-size:12.5px;font-weight:700;color:var(--emerald-deep);background:var(--emerald-soft);padding:7px 14px;border-radius:999px;animation:fadeIn .6s .3s var(--ease) both}
.w-cta{margin-top:26px;animation:fadeIn .6s .4s var(--ease) both}
.powered{font-size:11px;color:var(--faint);padding:14px;text-align:center}
.powered b{color:var(--muted)}

.flow-pad{padding:8px 20px 24px;flex:1;display:flex;flex-direction:column}
.flow-h{font-size:25px;margin:14px 0 4px}
.flow-sub{font-size:14.5px;color:var(--muted);margin-bottom:20px;line-height:1.45}
.rate-card{background:var(--surface);border-radius:var(--r-lg);padding:17px 18px;box-shadow:var(--shadow-sm);border:1px solid var(--line-soft);margin-bottom:13px;animation:slideUp .5s var(--ease) both}
@keyframes slideUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.rate-card .rc-top{display:flex;align-items:center;gap:11px;margin-bottom:13px}
.rc-emoji{width:40px;height:40px;border-radius:13px;background:var(--emerald-soft);display:flex;align-items:center;justify-content:center;font-size:20px;flex:none}
.rc-name{font-weight:700;font-size:15.5px}
.rc-tip{font-size:11.5px;color:var(--faint);margin-top:1px;height:14px;transition:color .2s}
.stars{display:flex;gap:6px}
.star{flex:1;aspect-ratio:1;max-width:46px;border-radius:13px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;transition:transform .2s var(--spring),background .2s}
.star svg{width:24px;height:24px;transition:transform .25s var(--spring)}
.star .s-path{fill:#CDD8D0;transition:fill .15s}
.star.lit{background:var(--gold-soft)}
.star.lit .s-path{fill:var(--gold)}
.star:active{transform:scale(.88)}
.star.bounce svg{animation:starPop .42s var(--spring)}
@keyframes starPop{0%{transform:scale(1)}40%{transform:scale(1.45) rotate(-8deg)}100%{transform:scale(1)}}

.chips{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:8px}
.chip{padding:11px 16px;border-radius:999px;background:var(--surface);border:1.5px solid var(--line);font-size:14px;font-weight:600;color:var(--ink);transition:transform .18s var(--spring),background .18s,border-color .18s,color .18s;display:inline-flex;align-items:center;gap:7px}
.chip:active{transform:scale(.93)}
.chip.on{background:var(--emerald);border-color:var(--emerald);color:#fff;box-shadow:0 6px 16px rgba(15,122,86,.26)}
.chip.on .ck{animation:pop .35s var(--spring)}
.chip.pop{animation:chipPop .4s var(--spring)}
@keyframes chipPop{0%{transform:scale(1)}45%{transform:scale(1.12)}100%{transform:scale(1)}}

.gen-cards{display:flex;flex-direction:column;gap:13px}
.gen-card{background:var(--surface);border-radius:var(--r-lg);padding:18px;box-shadow:var(--shadow-sm);border:2px solid var(--line-soft);transition:border-color .2s,transform .16s var(--ease),box-shadow .2s;text-align:left;width:100%;animation:slideUp .5s var(--ease) both}
.gen-card:active{transform:scale(.99)}
.gen-card.sel{border-color:var(--emerald);box-shadow:var(--shadow-lg)}
.gen-card .gc-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.gc-tag{font-size:10.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--emerald-deep)}
.gc-radio{width:24px;height:24px;border-radius:50%;border:2px solid var(--line);flex:none;display:flex;align-items:center;justify-content:center;transition:.2s}
.gen-card.sel .gc-radio{border-color:var(--emerald);background:var(--emerald)}
.gc-radio svg{width:13px;height:13px;opacity:0;transition:opacity .2s}
.gen-card.sel .gc-radio svg{opacity:1}
.gc-text{font-size:14.5px;line-height:1.55;color:var(--ink)}
.gc-foot{font-size:11px;color:var(--faint);margin-top:10px}
.skel{background:var(--surface);border-radius:var(--r-lg);padding:18px;box-shadow:var(--shadow-sm);margin-bottom:13px}
.skel .ln{height:13px;border-radius:999px;background:linear-gradient(90deg,var(--surface-2) 25%,#E6EFE9 50%,var(--surface-2) 75%);background-size:200% 100%;animation:shimmer 1.3s infinite;margin-bottom:9px}
@keyframes shimmer{from{background-position:200% 0}to{background-position:-200% 0}}
.gen-status{text-align:center;padding:8px 0 18px;color:var(--muted);font-size:14px;font-weight:600}
.gen-status .dots span{animation:blink 1.4s infinite both}
.gen-status .dots span:nth-child(2){animation-delay:.2s}
.gen-status .dots span:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,80%,100%{opacity:.2}40%{opacity:1}}

.done{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:30px 28px;position:relative;overflow:hidden}
.check-ring{width:96px;height:96px;border-radius:50%;background:var(--emerald-soft);display:flex;align-items:center;justify-content:center;animation:pop .5s var(--spring) both}
.check-ring svg{width:46px;height:46px}
.check-ring .cp{stroke:var(--emerald-deep);stroke-width:3.5;fill:none;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:40;stroke-dashoffset:40;animation:draw .5s .25s var(--ease) forwards}
@keyframes draw{to{stroke-dashoffset:0}}
.done h2{font-size:27px;margin:22px 0 10px;animation:fadeIn .5s .2s both}
.done p{color:var(--muted);line-height:1.5;max-width:300px;animation:fadeIn .5s .3s both}
.copied-pill{margin:20px 0 6px;display:inline-flex;gap:8px;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:12px 16px;font-size:13px;box-shadow:var(--shadow-sm);animation:fadeIn .5s .35s both;max-width:100%}
.copied-pill .ct{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--muted);font-style:italic}
.confetti{position:absolute;top:0;width:9px;height:14px;border-radius:2px;opacity:0;animation:confFall 2.2s ease-in forwards}
@keyframes confFall{0%{opacity:1;transform:translateY(-20px) rotate(0)}100%{opacity:0;transform:translateY(680px) rotate(540deg)}}

.toast{position:fixed;left:50%;bottom:30px;transform:translate(-50%,20px);background:var(--forest);color:#fff;padding:12px 18px;border-radius:14px;font-size:13.5px;font-weight:600;z-index:200;opacity:0;transition:.3s var(--spring);box-shadow:var(--shadow-md);display:flex;gap:8px;align-items:center;max-width:90vw}
.toast.show{opacity:1;transform:translate(-50%,0)}

.loading-full{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:var(--muted);font-size:14px}

@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.05ms!important}}