/* Quando — app styles (warm & human, mobile-first PWA) */
:root{
  --ink:#2A201B;--ink-soft:#5C4F47;--coral:#FF6E4F;--coral-deep:#EF512E;--amber:#FFB44D;
  --green:#19BE84;--green-deep:#0E9A6A;--red:#E2553C;--cream:#FFF6EE;--sand:#F6EADF;
  --card:#FFFFFF;--mut:#8C7B70;--line:#EFDDCD;--line-2:#E4CDB9;
  --shadow:0 18px 40px -22px rgba(42,32,27,.35);
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{background:var(--cream);color:var(--ink);font-family:'Inter',system-ui,-apple-system,sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased;overscroll-behavior-y:contain}
h1,h2,h3,h4,.pop{font-family:'Poppins','Inter',sans-serif;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
img,svg{display:block;max-width:100%}
.hidden{display:none!important}

/* layout shell */
.app{max-width:560px;margin:0 auto;min-height:100%;display:flex;flex-direction:column;background:var(--cream);position:relative}
.topbar{position:sticky;top:0;z-index:30;background:rgba(255,246,238,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);padding:max(10px,env(safe-area-inset-top)) 16px 10px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.topbar .brand{display:flex;align-items:center;gap:9px}
.topbar .brand img{height:26px}
.topbar .biz{font-family:'Poppins';font-weight:600;font-size:15px;line-height:1.1}
.topbar .biz small{display:block;font-family:'Inter';font-weight:400;font-size:11px;color:var(--mut)}
.netdot{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:var(--green-deep);background:rgba(25,190,132,.12);padding:5px 10px;border-radius:99px}
.netdot.off{color:#B5701A;background:rgba(255,180,77,.2)}
.netdot .d{width:7px;height:7px;border-radius:50%;background:currentColor}

main{flex:1;padding:16px 16px 96px}
.view{display:none}
.view.active{display:block;animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* bottom nav */
.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:40;background:rgba(255,255,255,.96);backdrop-filter:blur(12px);border-top:1px solid var(--line);display:flex;padding:6px 4px max(6px,env(safe-area-inset-bottom));max-width:560px;margin:0 auto}
.tabbar button{flex:1;background:none;border:none;color:var(--mut);font-size:10.5px;font-weight:600;display:flex;flex-direction:column;align-items:center;gap:3px;padding:7px 2px;border-radius:12px;position:relative}
.tabbar button .ic{font-size:20px;line-height:1}
.tabbar button.active{color:var(--coral-deep)}
.tabbar button .badge{position:absolute;top:2px;right:50%;transform:translateX(16px);background:var(--coral-deep);color:#fff;font-size:10px;min-width:16px;height:16px;border-radius:99px;display:grid;place-items:center;padding:0 4px}

/* headings */
.vhead{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:14px;gap:10px}
.vhead h2{font-size:22px;font-weight:700}
.vhead .sub{color:var(--mut);font-size:13px}
.kicker{font-family:'Poppins';font-weight:700;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--coral-deep)}

/* buttons */
.btn{font-family:'Poppins';font-weight:600;font-size:14.5px;padding:12px 18px;border-radius:12px;border:1px solid transparent;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:.18s}
.btn:active{transform:scale(.98)}
.btn-coral{background:linear-gradient(180deg,#FF8459,var(--coral-deep));color:#fff;box-shadow:0 12px 24px -14px rgba(239,81,46,.8)}
.btn-ghost{background:#fff;border-color:var(--line-2);color:var(--ink)}
.btn-green{background:var(--green);color:#fff}
.btn-soft{background:var(--sand);color:var(--ink)}
.btn-danger{background:#fff;border-color:#f0c4ba;color:var(--red)}
.btn-block{width:100%}
.btn.sm{padding:8px 12px;font-size:13px;border-radius:10px}
.fab{position:fixed;right:calc(50% - 280px + 16px);bottom:84px;z-index:45;width:58px;height:58px;border-radius:50%;background:linear-gradient(180deg,#FF8459,var(--coral-deep));color:#fff;border:none;font-size:30px;display:grid;place-items:center;box-shadow:0 16px 30px -10px rgba(239,81,46,.7)}
@media(max-width:592px){.fab{right:16px}}

/* cards */
.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:16px;box-shadow:var(--shadow)}
.card+.card{margin-top:12px}
.row{display:flex;align-items:center;gap:12px}
.muted{color:var(--mut)}
.pill{font-family:'Poppins';font-size:10.5px;font-weight:700;padding:4px 9px;border-radius:99px;white-space:nowrap}
.pill.ok{color:var(--green-deep);background:rgba(25,190,132,.14)}
.pill.pend{color:#B5701A;background:rgba(255,180,77,.22)}
.pill.cancel{color:var(--red);background:rgba(226,85,60,.12)}
.pill.done{color:var(--mut);background:var(--sand)}

/* date strip */
.datestrip{display:flex;gap:8px;overflow-x:auto;padding:4px 0 8px;-webkit-overflow-scrolling:touch}
.datestrip::-webkit-scrollbar{display:none}
.dchip{flex:0 0 auto;width:54px;text-align:center;background:#fff;border:1px solid var(--line);border-radius:14px;padding:8px 0}
.dchip .dow{font-size:10px;color:var(--mut);text-transform:uppercase;font-weight:600}
.dchip .dn{font-family:'Poppins';font-weight:700;font-size:18px}
.dchip.sel{background:var(--coral);border-color:var(--coral);color:#fff}
.dchip.sel .dow{color:rgba(255,255,255,.85)}
.dchip .dot{width:5px;height:5px;border-radius:50%;background:var(--coral);margin:3px auto 0}
.dchip.sel .dot{background:#fff}

/* agenda list */
.agenda{margin-top:6px}
.appt{display:flex;gap:12px;align-items:stretch;background:#fff;border:1px solid var(--line);border-left-width:4px;border-radius:14px;padding:12px 14px;margin-bottom:10px}
.appt.s-confirmed{border-left-color:var(--green)}
.appt.s-pending{border-left-color:var(--amber)}
.appt.s-cancelled{border-left-color:var(--red);opacity:.7}
.appt .tcol{width:52px;flex-shrink:0}
.appt .tcol .t{font-family:'Poppins';font-weight:700;font-size:14px}
.appt .tcol .dur{font-size:11px;color:var(--mut)}
.appt .body{flex:1;min-width:0}
.appt .body .n{font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.appt .body .s{font-size:12.5px;color:var(--mut)}
.appt .body .meta{font-size:12px;color:var(--mut);margin-top:2px}
.empty{text-align:center;color:var(--mut);padding:40px 16px}
.empty .e{font-size:40px;margin-bottom:8px}

/* list items (services, staff, clients, requests) */
.li{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:13px 14px;margin-bottom:10px}
.li .av{width:40px;height:40px;border-radius:50%;background:var(--sand);display:grid;place-items:center;font-family:'Poppins';font-weight:700;color:var(--coral-deep);flex-shrink:0}
.li .grow{flex:1;min-width:0}
.li .grow .t{font-weight:600}
.li .grow .s{font-size:12.5px;color:var(--mut)}
.li .chev{color:var(--mut)}

/* forms */
label.fld{display:block;margin-bottom:12px}
label.fld .lab{font-size:12.5px;font-weight:600;color:var(--ink-soft);margin-bottom:5px;display:block}
input,select,textarea{width:100%;background:#fff;border:1px solid var(--line-2);border-radius:11px;padding:12px 13px;color:var(--ink);font-family:'Inter';font-size:15px;outline:none}
input:focus,select:focus,textarea:focus{border-color:var(--coral)}
textarea{resize:vertical;min-height:60px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{font-family:'Poppins';font-weight:600;font-size:13px;padding:9px 13px;border-radius:11px;border:1px solid var(--line-2);background:#fff}
.chip.sel{background:var(--coral);border-color:var(--coral);color:#fff}
.chip.off{color:var(--mut);background:var(--sand);opacity:.6;text-decoration:line-through}

/* sheet / modal */
.scrim{position:fixed;inset:0;z-index:60;background:rgba(42,32,27,.45);display:none;align-items:flex-end;justify-content:center}
.scrim.open{display:flex}
.sheet{background:var(--cream);width:100%;max-width:560px;border-radius:22px 22px 0 0;max-height:92vh;overflow-y:auto;padding:8px 18px max(18px,env(safe-area-inset-bottom));animation:up .28s cubic-bezier(.16,.8,.2,1)}
@keyframes up{from{transform:translateY(100%)}to{transform:none}}
.sheet .grip{width:40px;height:4px;border-radius:2px;background:var(--line-2);margin:8px auto 12px}
.sheet h3{font-size:19px;font-weight:700;margin-bottom:14px}
.sheet .actions{display:flex;gap:10px;margin-top:16px}

/* toast */
.toast{position:fixed;left:50%;bottom:104px;transform:translateX(-50%) translateY(20px);z-index:80;background:var(--ink);color:#fff;font-weight:600;font-size:14px;padding:12px 18px;border-radius:12px;opacity:0;transition:.3s;pointer-events:none;max-width:90%;text-align:center}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* login */
.login{min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:30px 22px;text-align:center;gap:6px}
.login img{height:60px;margin-bottom:8px}
.login h1{font-size:26px;font-weight:800}
.login p{color:var(--ink-soft);margin-bottom:14px}
.login .card{width:100%;max-width:380px;text-align:left}
.seg{display:flex;background:var(--sand);border-radius:12px;padding:4px;margin-bottom:14px}
.seg button{flex:1;border:none;background:none;padding:9px;border-radius:9px;font-family:'Poppins';font-weight:600;font-size:13.5px;color:var(--mut)}
.seg button.sel{background:#fff;color:var(--ink);box-shadow:0 4px 10px -6px rgba(0,0,0,.3)}

/* settings rows */
.set-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 0;border-bottom:1px solid var(--line)}
.set-row:last-child{border-bottom:none}
.set-row .t{font-weight:600}
.set-row .s{font-size:12.5px;color:var(--mut)}
.switch{width:46px;height:27px;border-radius:99px;background:var(--line-2);position:relative;transition:.2s;flex-shrink:0;border:none}
.switch.on{background:var(--green)}
.switch::after{content:"";position:absolute;top:3px;left:3px;width:21px;height:21px;border-radius:50%;background:#fff;transition:.2s}
.switch.on::after{left:22px}

.linkbox{display:flex;gap:8px;align-items:center;background:var(--sand);border:1px dashed var(--line-2);border-radius:12px;padding:11px 12px;font-size:13px;word-break:break-all}
