:root{
  --ink:#0b1226; --muted:#5b6b82; --line:#e7ecf3; --panel:#f6f8fc;
  --brand:#2f6bff; --violet:#7a4ce0; --green:#16a766; --amber:#b7791f; --bad:#c0392b;
  --grad:linear-gradient(135deg,#2f6bff,#7a4ce0);
}
*{box-sizing:border-box}
html,body{overflow-x:hidden;max-width:100%}
body{margin:0;font-family:"Segoe UI",system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:radial-gradient(120% 80% at 100% 0%,#eef3ff 0%,#eef2f8 40%,#e9edf5 100%);
  background-attachment:fixed;line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:var(--brand);text-decoration:none}
.wrap{max-width:880px;margin:0 auto;padding:20px}
.muted{color:var(--muted)} .small{font-size:.85rem} .mt{margin-top:14px}
h1,h2,h3{letter-spacing:-.015em}
code{background:var(--panel);border:1px solid var(--line);border-radius:6px;padding:1px 6px;font-size:.85rem}

.appshell-head{position:sticky;top:0;z-index:30;background:#fff;box-shadow:0 1px 0 var(--line),0 6px 18px rgba(11,18,38,.04);
  display:flex;align-items:center;flex-wrap:wrap;gap:8px 16px;padding:11px 20px}
.appshell-head>.brand{order:1;flex:0 0 auto}
.appshell-head>.appnav{order:2;flex:1 1 auto;min-width:0}
.appshell-head>.topbar-right{order:3;flex:0 0 auto}
@media(max-width:760px){
  /* header keeps just brand + business/sign-out; nav drops to a bottom tab bar */
  .appshell-head>.topbar-right{order:2;margin-left:auto}
  .appshell-head>.appnav{
    position:fixed;left:0;right:0;bottom:0;z-index:60;flex:none;
    display:flex;justify-content:space-around;gap:0;overflow:visible;
    background:#fff;border-top:1px solid var(--line);
    padding:7px 4px calc(7px + env(safe-area-inset-bottom));
    box-shadow:0 -6px 22px rgba(11,18,38,.08);
  }
  .appshell-head>.appnav .navitem{
    flex:1;flex-direction:column;gap:3px;justify-content:center;
    padding:5px 2px;border-radius:12px;font-size:.66rem;font-weight:700;white-space:nowrap}
  .appshell-head>.appnav .navitem .ni-ic{font-size:1.4rem}
  .appshell-head>.appnav .navitem.active{background:transparent;color:var(--brand);box-shadow:none}
  .appshell-head>.appnav .navitem.admin.active{background:transparent;color:var(--ink)}
  /* clear room for the fixed bar */
  body{padding-bottom:calc(68px + env(safe-area-inset-bottom))}
}
.brand{display:flex;align-items:center;gap:9px;font-weight:900;font-size:1.18rem;color:var(--ink)}
.brand .logo{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#2f6bff,#7a4ce0);
  display:flex;align-items:center;justify-content:center;font-size:1.05rem;box-shadow:0 4px 12px rgba(47,107,255,.4)}
.topbar-right{display:flex;align-items:center;gap:14px}
.bizname{display:inline-flex;align-items:center;gap:7px;font-weight:800;color:var(--ink);font-size:.92rem;
  background:var(--panel);border:1px solid var(--line);border-radius:999px;padding:6px 13px;max-width:200px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bizname::before{content:"🏠";font-size:.95rem}
.signout{display:inline-flex;align-items:center;border:1px solid var(--line);background:#fff;border-radius:11px;
  padding:8px 14px;color:var(--ink);font-weight:700;font-size:.88rem;transition:background .15s,border-color .15s,color .15s}
.signout:hover{background:#fdecea;color:var(--bad);border-color:#f3c6c2}
.appnav{display:flex;gap:5px;overflow-x:auto;scrollbar-width:none}
.appnav::-webkit-scrollbar{display:none}
.navitem{display:inline-flex;align-items:center;gap:7px;white-space:nowrap;padding:9px 15px;border-radius:12px;
  color:var(--muted);font-weight:700;font-size:.92rem;transition:background .15s,color .15s,transform .1s}
.navitem .ni-ic{font-size:1.05rem;line-height:1}
.navitem:hover{background:var(--panel);color:var(--ink)}
.navitem.active{background:var(--grad);color:#fff;box-shadow:0 6px 16px rgba(47,107,255,.32)}
.navitem.admin.active{background:#0b1226}
@media(max-width:600px){.bizname{max-width:120px}.brand{font-size:1.05rem}.navitem{padding:8px 12px;font-size:.88rem}}

.card{background:#fff;border:1px solid rgba(11,18,38,.05);border-radius:20px;padding:26px;margin:18px 0;
  box-shadow:0 1px 2px rgba(11,18,38,.03),0 18px 40px rgba(11,18,38,.06)}
.card h2{margin:0 0 .5em;font-size:1.4rem;font-weight:800;display:flex;align-items:center;gap:11px}
.card h2::before{content:"";width:5px;height:1.05em;border-radius:99px;background:var(--grad);flex:0 0 auto}
.card h3{font-size:1.15rem;font-weight:800}
.stat h2::before,.welcome h2::before{display:none}

.row{display:flex;align-items:center} .row.gap{gap:10px;flex-wrap:wrap} .row.between{justify-content:space-between}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--line);background:#fff;border-radius:13px;
  padding:12px 18px;font-weight:800;font-size:.97rem;cursor:pointer;color:var(--ink);
  transition:transform .13s,box-shadow .2s,background .15s}
.btn:hover{transform:translateY(-1px);box-shadow:0 8px 20px rgba(11,18,38,.1)}
.btn.primary{background:var(--grad);color:#fff;border:none;box-shadow:0 10px 24px rgba(47,107,255,.34)}
.btn.primary:hover{box-shadow:0 14px 30px rgba(47,107,255,.45)}
input,select,textarea{font:inherit;padding:13px 15px;border:1.5px solid var(--line);border-radius:13px;background:#fbfcfe;
  min-width:0;color:var(--ink);transition:border-color .15s,box-shadow .15s,background .15s}
input::placeholder,textarea::placeholder{color:#c8cfdb;font-weight:400;opacity:1}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);background:#fff;
  box-shadow:0 0 0 4px rgba(47,107,255,.13)}
label{display:block;margin:14px 0 0;font-weight:700;font-size:.95rem}
label input,label select,label textarea{display:block;width:100%;margin-top:6px;font-weight:500}

/* premium welcome / onboarding */
.welcome{max-width:560px;margin:30px auto;padding:0;overflow:hidden}
.welcome .wtop{background:var(--grad);color:#fff;padding:34px 30px 30px}
.welcome .wtop .wlogo{width:54px;height:54px;border-radius:16px;background:rgba(255,255,255,.18);display:flex;
  align-items:center;justify-content:center;font-size:1.7rem;margin-bottom:14px}
.welcome .wtop h2{color:#fff;font-size:1.7rem;margin:0 0 .2em}
.welcome .wtop p{color:#dbe6ff;margin:0;font-size:1rem}
.welcome .wbody{padding:26px 30px 30px}

.seg{display:flex;gap:6px;background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:5px;margin:14px 0}
.seg a,.seg button{flex:1;text-align:center;padding:10px 8px;border-radius:9px;color:var(--muted);font-weight:700;
  border:none;background:transparent;font:inherit;font-weight:700;cursor:pointer;transition:background .15s,color .15s,box-shadow .2s}
.seg a:hover,.seg button:hover{color:var(--ink)}
.seg a.on,.seg button.on{background:var(--grad);color:#fff;box-shadow:0 6px 16px rgba(47,107,255,.32)}
.auth{max-width:420px;margin:40px auto}

.notice{border-radius:12px;padding:12px 14px;margin:12px 0}
.notice.ok{background:#eafaf1;color:#0b7a44;border:1px solid #bfe9d2}
.notice.warn{background:#fff7e6;color:var(--amber);border:1px solid #f3e0b5}
.notice.bad{background:#fdecea;color:var(--bad);border:1px solid #f5c6c2}

.pill{font-size:.75rem;font-weight:800;border-radius:999px;padding:4px 10px;background:var(--panel);color:var(--muted)}
.pill.ok{background:#eafaf1;color:#0b7a44} .pill.warn{background:#fff7e6;color:var(--amber)}

.cards3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.stat{text-align:left;color:#fff;border:none;position:relative;overflow:hidden;min-height:118px;display:flex;flex-direction:column;justify-content:flex-end}
.stat::after{content:"";position:absolute;top:-30px;right:-30px;width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,.13)}
.stat .big{font-size:2.1rem;font-weight:900;color:#fff;letter-spacing:-.02em;position:relative;z-index:1}
.stat .lbl{color:rgba(255,255,255,.9);font-size:.9rem;font-weight:600;position:relative;z-index:1}
.cards3 .stat:nth-child(1){background:linear-gradient(135deg,#1fb673,#0e8a52);box-shadow:0 12px 28px rgba(16,167,102,.32)}
.cards3 .stat:nth-child(2){background:linear-gradient(135deg,#fb923c,#ea7317);box-shadow:0 12px 28px rgba(234,115,23,.32)}
.cards3 .stat:nth-child(3){background:linear-gradient(135deg,#2f6bff,#7a4ce0);box-shadow:0 12px 28px rgba(47,107,255,.32)}
/* admin stats keep blue/violet variety */
.cards3 .stat:nth-child(1) .big,.cards3 .stat:nth-child(2) .big,.cards3 .stat:nth-child(3) .big{color:#fff}

.ledgergrid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
table{width:100%;border-collapse:collapse} td{padding:8px 4px;border-bottom:1px solid var(--line);font-size:.95rem}
.list{list-style:none;padding:0} .list li{padding:7px 0;border-bottom:1px dashed var(--line)}
.passcard{display:flex;gap:16px;align-items:center;margin-top:14px;flex-wrap:wrap}
#qr img,.qrbig img{display:block}

.reader{max-width:340px;margin:8px 0}
.bizswitch select{font-weight:700}

/* guide */
body.guide{background:#eef2f8}
.ghero{background:linear-gradient(135deg,#2f6bff,#7a4ce0);color:#fff;padding:26px 18px 30px}
.ghero h1{margin:.1em 0}
.pass{text-align:center}
.qrbig{display:flex;justify-content:center;margin:10px 0}
.tokshow{font-size:.8rem}
.infolist{list-style:none;padding:0;margin:0}
.infolist li{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--line)}
.bizrow{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line)}
.bizrow:last-child{border-bottom:none}
.bi{font-size:1.6rem;width:40px;text-align:center}
.bigrow-main{flex:1;min-width:0}.bn{font-weight:700;overflow-wrap:anywhere}
.disc{font-weight:900;color:var(--green);text-align:center}

/* Google button + divider */
.gbtn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;margin-top:6px}
.or{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:.75rem;font-weight:800;
  text-transform:uppercase;letter-spacing:.08em;margin:16px 0}
.or::before,.or::after{content:"";flex:1;height:1px;background:var(--line)}

/* approval toggle switch */
.toggleform{margin:0}
.toggle{width:50px;height:30px;border-radius:999px;background:#d3dae6;border:none;cursor:pointer;position:relative;padding:0}
.toggle span{position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:50%;background:#fff;transition:left .15s ease;box-shadow:0 1px 3px rgba(0,0,0,.25)}
.toggle.on{background:var(--green)} .toggle.on span{left:23px}
textarea{font-family:inherit}

/* wall QR hero (service-first home) */
.wallcard{display:flex;gap:36px;align-items:center;flex-wrap:wrap;justify-content:center;
  background:radial-gradient(130% 130% at 100% 0%,#f3f6ff 0%,#fff 55%)}
.wallcard .wall-left{flex:1 1 340px;min-width:0}
.eyebrow{display:inline-block;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--brand);font-size:.74rem;margin-bottom:8px}
.wallcard h2{margin:0 0 .45em}
.wallcard p{margin:0}
.wall-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.wall-qr{flex:0 0 auto;margin:0 auto;align-self:center;display:flex;flex-direction:column;align-items:center;gap:14px;
  padding:22px;background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:0 12px 30px rgba(11,18,38,.08)}
.wall-qr #wallqr{line-height:0}
.wall-qr #wallqr img,.wall-qr #wallqr canvas{display:block;width:158px;height:158px}
.wall-qr figcaption{color:var(--muted);font-size:.82rem;font-weight:600}
@media(max-width:720px){.wallcard{flex-direction:column;align-items:stretch}
  .wall-actions{justify-content:center}.wall-qr{align-self:center}}

/* de-emphasized money strip */
.minibar{display:flex;align-items:center;justify-content:space-between;gap:16px;
  text-decoration:none;color:var(--ink);padding:20px 24px}
.minibar:hover{transform:translateY(-1px)}
.mini{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;min-width:0}
.mini-n{font-size:1.4rem;font-weight:900;color:var(--green);line-height:1}
.mini-l{color:var(--muted);font-size:.92rem;font-weight:600}
.mini-go{color:var(--brand);font-weight:800;font-size:.95rem;white-space:nowrap}

/* "how you earn" explainer */
.howcard{display:flex;gap:14px;align-items:flex-start;background:linear-gradient(135deg,#eef3ff,#f6f1ff);border:1px solid #e2e9ff}
.howcard .how-ic{font-size:1.5rem;line-height:1.2;flex:0 0 auto}
.howcard b{font-size:1.02rem}
.howcard p{margin:.25em 0 0}

/* settings form — compact two-column on desktop */
/* settings card = same width as every other card */
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:18px 20px;align-items:end;margin-top:10px}
.fgrid label{margin:0}
.fgrid .span2{grid-column:1/3}
.fgrid .sec{margin-top:6px}
.fgrid .sec h3{margin:0 0 .35em}
.fgrid textarea{width:100%;margin-top:12px;font-weight:500}
@media(max-width:560px){.fgrid{grid-template-columns:1fr}.fgrid .span2{grid-column:1}}

/* modal dialog */
dialog.modal{border:none;border-radius:22px;padding:0;max-width:640px;width:94vw;
  box-shadow:0 30px 90px rgba(11,18,38,.32)}
dialog.modal::backdrop{background:rgba(11,18,38,.5);backdrop-filter:blur(3px)}
.modal-body{padding:26px 26px 28px}
.modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.modal-head h3{margin:0;font-size:1.3rem}
.modal-x{background:var(--panel);border:none;border-radius:10px;width:36px;height:36px;font-size:1rem;
  cursor:pointer;color:var(--muted);flex:0 0 auto}
.modal-x:hover{background:#e7ecf3;color:var(--ink)}

/* confirm modal */
.confirm-modal{max-width:420px}
.confirm-modal .modal-body{text-align:center;padding:32px 28px}
.confirm-ic{font-size:2.5rem;margin-bottom:4px}
.confirm-modal h3{margin:.15em 0 .35em;font-size:1.3rem}
.confirm-modal p{margin:0 auto;max-width:30em}
.confirm-actions{display:flex;gap:10px;justify-content:center;margin-top:24px}
.btn.danger{background:#e5484d;color:#fff;border:none;box-shadow:0 8px 20px rgba(229,72,77,.3)}
.btn.danger:hover{background:#d23b40;box-shadow:0 12px 26px rgba(229,72,77,.42)}

/* compact guest cards */
.guestcard{padding:18px 20px;margin:12px 0}
.guestcard h3{font-size:1.12rem}
.gactions{margin-top:12px;align-items:center}
.btn.sm{padding:8px 13px;font-size:.86rem;border-radius:11px}
.bklist{margin-top:10px;border-top:1px solid var(--line)}
.bk{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--line);font-size:.92rem}
.bk:last-child{border-bottom:none}
.bk b{color:var(--green)}

/* elegant per-guest note */
.notewrap{margin-top:11px}
.gnote{display:flex;gap:9px;align-items:flex-start;background:#fff8e6;border:1px solid #f4e6bb;border-radius:12px;
  padding:10px 13px;font-size:.92rem;color:#6b5618;cursor:pointer;line-height:1.45}
.gnote:hover{background:#fef3d7}
.gnote-ic{flex:0 0 auto}
.addnote{background:none;border:1px dashed #d4dbe6;border-radius:11px;padding:7px 13px;color:var(--muted);
  font-weight:600;font-size:.85rem;cursor:pointer}
.addnote:hover{background:var(--panel);color:var(--ink);border-color:var(--brand)}
.noteform textarea{width:100%;font-weight:500;resize:vertical}

/* click-to-edit guest name */
.gname{cursor:pointer;display:inline-flex;align-items:center;gap:9px;margin:.1em 0}
.gname .pencil{font-size:.72em;color:var(--brand);opacity:.85;transition:transform .12s}
.gname:hover .pencil{transform:scale(1.12)}
.renameform{display:flex;gap:8px;align-items:center;margin:.15em 0}
.renameform input{max-width:280px;font-weight:700}

/* empty state */
.empty{text-align:center;padding:40px 28px}
.empty .empty-ic{font-size:2.8rem}
.empty h3{margin:.4em 0 .2em}
.empty p{max-width:34em;margin:0 auto 18px}

/* per-row remove */
.iconbtn{background:none;border:none;cursor:pointer;font-size:1.05rem;padding:8px;border-radius:10px;line-height:1}
.iconbtn:hover{background:var(--panel)}
.toggleform{margin:0}

/* add-a-business form */
.addgrid{display:grid;grid-template-columns:1fr 1fr;gap:14px 18px;align-items:end;margin-top:16px}
.addgrid label{margin:0}
.addgrid .f-addr{grid-column:1/3}
.addgrid .f-disc,.addgrid .f-comm{grid-column:auto}
.addgrid .f-btn{grid-column:1/3;justify-self:start}
@media(max-width:620px){.addgrid{grid-template-columns:1fr 1fr}.addgrid .f-name,.addgrid .f-addr,.addgrid .f-btn{grid-column:1/3}}
.taglet{display:inline-block;font-size:.66rem;font-weight:800;letter-spacing:.03em;text-transform:uppercase;
  color:var(--amber);background:#fff7e6;border:1px solid #f3e0b5;border-radius:6px;padding:1px 6px;vertical-align:middle}

/* category tabs */
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.tab{border:1px solid var(--line);background:#fff;border-radius:999px;padding:7px 14px;font-weight:700;cursor:pointer;color:var(--muted);font-size:.9rem}
.tab.on{background:var(--brand);color:#fff;border-color:var(--brand)}

/* earnings */
.hero-earn{background:linear-gradient(135deg,#2f6bff,#7a4ce0);color:#fff}
.hero-earn .muted{color:#dbe6ff}
.bignum{font-size:2.6rem;font-weight:900;letter-spacing:-.02em;margin:2px 0}
.barrow{margin:12px 0}.barrow-top{display:flex;justify-content:space-between;margin-bottom:5px}
.bar{height:9px;background:var(--panel);border-radius:999px;overflow:hidden}
.bar span{display:block;height:100%;background:var(--brand);border-radius:999px}

/* add-to-wallet */
.wallet-btns{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:10px}
.wbtn{display:inline-flex;align-items:center;gap:8px;background:#000;color:#fff;border-radius:11px;padding:10px 16px;font-weight:700;font-size:.9rem}

@media(max-width:620px){.cards3,.ledgergrid{grid-template-columns:1fr}.topbar nav{gap:10px;font-size:.9rem;flex-wrap:wrap}}
