:root{
  --purple:#7c3aed;--purple-2:#6d28d9;--purple-3:#5b21b6;--magenta:#c026d3;
  --grad:linear-gradient(135deg,#a855f7 0%,#7c3aed 55%,#6d28d9 100%);
  --grad-vivid:linear-gradient(135deg,#d946ef,#8b5cf6 55%,#6d28d9);
  --grad-soft:linear-gradient(135deg,#f5f0ff,#ede9fe);
  --ink:#181225;--ink-2:#3f3a52;--muted:#8b86a0;--line:#efecf6;--line-2:#e6e1f2;
  --bg:#f7f5fc;--bg-2:#f1edf9;--card:#ffffff;
  --ok:#15a34a;--ok-bg:#e7f8ee;--warn:#d97706;--warn-bg:#fff5e6;
  --bad:#e11d48;--bad-bg:#fdecf0;--info:#4f46e5;--info-bg:#eef0fe;
  --sh-sm:0 1px 2px rgba(24,18,37,.04),0 2px 8px rgba(91,33,182,.05);
  --sh:0 2px 6px rgba(24,18,37,.05),0 12px 28px -10px rgba(91,33,182,.16);
  --sh-lg:0 8px 20px -8px rgba(91,33,182,.18),0 24px 48px -16px rgba(91,33,182,.22);
  --r:18px;--r-lg:24px;--r-sm:13px;
  --safe-b:env(safe-area-inset-bottom,0px);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  background:var(--bg);color:var(--ink);font-size:15px;line-height:1.5;letter-spacing:-.01em;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  padding-bottom:calc(80px + var(--safe-b));
  background-image:radial-gradient(1200px 360px at 50% -120px,#efe7ff 0%,transparent 70%);
  background-repeat:no-repeat;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
img,svg{vertical-align:middle}
.app{max-width:480px;margin:0 auto;min-height:100vh;position:relative}
.icon{width:22px;height:22px;display:inline-block;stroke:currentColor;fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}

/* Header */
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:11px;
  padding:13px 18px 12px;background:rgba(247,245,252,.82);backdrop-filter:saturate(180%) blur(16px);
  -webkit-backdrop-filter:saturate(180%) blur(16px);border-bottom:1px solid rgba(230,225,242,.7)}
.topbar .mark{width:36px;height:36px;display:flex;align-items:center;justify-content:center;
  background:var(--grad);border-radius:12px;box-shadow:0 6px 16px -4px rgba(124,58,237,.55);flex:none}
.topbar .mark svg{width:22px;height:22px}
.topbar h1{font-size:17px;margin:0;font-weight:800;letter-spacing:-.4px;line-height:1.05}
.topbar h1 small{display:block;font-size:10px;font-weight:700;color:var(--purple);letter-spacing:1.4px;text-transform:uppercase;margin-top:1px}
.topbar .spacer{flex:1}
.chip-credits{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--line-2);
  color:var(--purple-2);font-weight:800;font-size:13px;padding:7px 13px 7px 10px;border-radius:999px;box-shadow:var(--sh-sm)}
.chip-credits .icon{width:15px;height:15px;stroke:var(--magenta)}
.chip-credits b{font-size:14px;letter-spacing:-.3px}

/* Layout */
.view{padding:18px 16px 8px;animation:fade .3s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.view-title{font-size:23px;font-weight:800;letter-spacing:-.6px;margin:6px 2px 3px}
.view-sub{color:var(--muted);font-size:13px;margin:0 2px 18px}
.view-sub a{color:var(--muted);font-weight:600}
.section-label{font-size:11.5px;font-weight:800;text-transform:uppercase;letter-spacing:.9px;
  color:var(--muted);margin:24px 4px 11px;display:flex;align-items:center;gap:7px}
.section-label .icon{width:15px;height:15px;stroke:var(--purple)}

/* Cards */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh);padding:6px 18px;margin-bottom:14px}
.card.pad{padding:18px}
.card.flat{box-shadow:none}

/* Hero */
.hero{position:relative;overflow:hidden;background:var(--grad-vivid);color:#fff;border-radius:var(--r-lg);
  padding:22px 22px 20px;box-shadow:0 20px 44px -18px rgba(124,58,237,.7);margin-bottom:18px}
.hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(420px 200px at 88% -30%,rgba(255,255,255,.32),transparent 60%),
  radial-gradient(300px 220px at 0% 120%,rgba(255,255,255,.14),transparent 60%)}
.hero>*{position:relative;z-index:1}
.hero .h-label{font-size:12px;letter-spacing:.4px;font-weight:700;opacity:.92;text-transform:capitalize}
.hero .h-big{font-size:33px;font-weight:800;letter-spacing:-1.2px;margin:7px 0 0;line-height:1.05}
.hero .h-row{display:flex;gap:10px;margin-top:18px}
.hero .h-row div{flex:1;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.18);
  border-radius:14px;padding:11px 12px;backdrop-filter:blur(4px)}
.hero .h-row .n{font-size:21px;font-weight:800;letter-spacing:-.5px}
.hero .h-row .l{font-size:10px;opacity:.9;text-transform:uppercase;letter-spacing:.4px;font-weight:700;margin-top:2px}

/* Appointment row */
.appt{display:flex;gap:13px;align-items:center;padding:14px 0;border-bottom:1px solid var(--line);transition:opacity .15s}
.appt:last-child{border-bottom:none}
.appt:active{opacity:.6}
.appt .time{flex:none;width:50px;text-align:center;padding:6px 0;background:var(--bg-2);border-radius:12px}
.appt .time .hh{font-size:15px;font-weight:800;letter-spacing:-.3px;color:var(--purple-2)}
.appt .time .dd{font-size:9px;color:var(--muted);text-transform:uppercase;font-weight:700;margin-top:1px}
.appt .body{flex:1;min-width:0}
.appt .body .nm{font-weight:700;font-size:14.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.appt .body .sv{font-size:12.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:800;padding:5px 10px;border-radius:999px;white-space:nowrap;letter-spacing:-.1px}
.badge::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
.badge.Pendente{background:var(--warn-bg);color:#b45309}
.badge.Confirmado{background:var(--ok-bg);color:#15803d}
.badge.Cancelado{background:var(--bad-bg);color:#be123c}
.badge.NaoCompareceu{background:#f3eefe;color:#6d28d9}
.badge.Concluido{background:var(--info-bg);color:#4338ca}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;
  background:var(--grad);color:#fff;border:none;border-radius:15px;padding:15px 18px;font-size:15px;
  font-weight:700;letter-spacing:-.2px;cursor:pointer;box-shadow:0 10px 22px -8px rgba(124,58,237,.6);
  transition:transform .08s,box-shadow .2s}
.btn:active{transform:translateY(1px) scale(.99)}
.btn .icon{width:19px;height:19px;stroke-width:2.1}
.btn.ghost{background:#fff;color:var(--purple-2);border:1.5px solid var(--line-2);box-shadow:var(--sh-sm)}
.btn.soft{background:var(--grad-soft);color:var(--purple-2);box-shadow:none;border:1px solid #e9e1fb}
.btn.sm{width:auto;padding:9px 15px;font-size:13px;border-radius:11px;box-shadow:none}
.btn.danger{background:var(--bad-bg);color:#be123c;box-shadow:none}
.btn-row{display:flex;gap:10px}.btn-row .btn{flex:1}

/* FAB */
.fab{position:fixed;left:50%;transform:translateX(-50%);bottom:calc(90px + var(--safe-b));z-index:30;
  width:auto;padding:14px 22px;border-radius:999px;font-weight:800;
  box-shadow:0 12px 28px -6px rgba(124,58,237,.65)}
.fab .icon{width:18px;height:18px}

/* Bottom nav */
.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:40;display:flex;max-width:480px;margin:0 auto;
  padding:9px 8px calc(10px + var(--safe-b));background:rgba(255,255,255,.9);
  backdrop-filter:saturate(180%) blur(18px);-webkit-backdrop-filter:saturate(180%) blur(18px);
  border-top:1px solid var(--line-2);box-shadow:0 -6px 24px -16px rgba(91,33,182,.3)}
.tabbar a{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:5px 2px;
  color:#a8a3bd;font-size:10px;font-weight:700;letter-spacing:-.1px;transition:color .15s}
.tabbar a .icon{width:23px;height:23px;stroke-width:1.9;transition:transform .18s}
.tabbar a.active{color:var(--purple-2)}
.tabbar a.active .icon{transform:translateY(-1px);stroke-width:2.2}

/* Forms */
.field{margin-bottom:15px}
.field label{display:block;font-size:12.5px;font-weight:700;color:var(--ink-2);margin-bottom:7px}
.field .hint{font-weight:500;color:var(--muted);font-size:11.5px}
.input,select,textarea{width:100%;border:1.5px solid var(--line-2);border-radius:13px;padding:13px 14px;
  font-size:15px;font-family:inherit;background:#fff;color:var(--ink);outline:none;transition:border-color .15s,box-shadow .15s;appearance:none}
.input:focus,select:focus,textarea:focus{border-color:var(--purple);box-shadow:0 0 0 4px rgba(124,58,237,.1)}
select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none' stroke='%238b86a0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 13px center;padding-right:40px}
textarea{resize:vertical;min-height:92px;line-height:1.5}
.row2{display:flex;gap:12px}.row2>*{flex:1}
.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 0;border-bottom:1px solid var(--line)}
.toggle-row:last-child{border-bottom:none}
.toggle-row .tl{font-weight:650;font-size:14px}
.toggle-row .ts{font-size:12px;color:var(--muted);margin-top:1px}
.switch{position:relative;width:46px;height:28px;flex:none}
.switch input{opacity:0;width:0;height:0}
.switch .sl{position:absolute;inset:0;background:#dcd6ea;border-radius:999px;transition:.22s;cursor:pointer}
.switch .sl::before{content:"";position:absolute;width:22px;height:22px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.22s;box-shadow:0 2px 5px rgba(0,0,0,.18)}
.switch input:checked+.sl{background:var(--grad)}
.switch input:checked+.sl::before{transform:translateX(18px)}

.counter{font-size:12px;font-weight:700;color:var(--muted);text-align:right;margin-top:7px}
.counter.warn{color:var(--bad)}

/* List items */
.list-item{display:flex;gap:12px;align-items:center;padding:13px 0;border-bottom:1px solid var(--line)}
.list-item:last-child{border-bottom:none}
.avatar{width:44px;height:44px;border-radius:13px;flex:none;display:flex;align-items:center;justify-content:center;
  background:var(--grad-soft);color:var(--purple-2);font-weight:800;font-size:15px;letter-spacing:-.3px}
.avatar.ic .icon{width:20px;height:20px;stroke:var(--purple-2)}
.list-item .body{flex:1;min-width:0}
.list-item .body .nm{font-weight:700;font-size:14.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.list-item .body .mt{font-size:12.5px;color:var(--muted);margin-top:1px}
.list-item .arrow{color:#cfc8e0}.list-item .arrow .icon{width:18px;height:18px;stroke-width:2.4}

/* Filters */
.filters{display:flex;gap:8px;overflow-x:auto;padding:2px 0 12px;scrollbar-width:none}
.filters::-webkit-scrollbar{display:none}
.filter{flex:none;background:#fff;border:1.5px solid var(--line-2);color:var(--ink-2);padding:9px 15px;
  border-radius:999px;font-size:13px;font-weight:700;white-space:nowrap;cursor:pointer;box-shadow:var(--sh-sm)}
.filter.active{background:var(--grad);color:#fff;border-color:transparent;box-shadow:0 6px 14px -6px rgba(124,58,237,.6)}

/* Flash */
.flash{display:flex;align-items:center;gap:9px;padding:13px 15px;border-radius:14px;font-size:13.5px;font-weight:600;margin:6px 16px 2px}
.flash::before{content:"";width:8px;height:8px;border-radius:50%;background:currentColor;flex:none}
.flash.success{background:var(--ok-bg);color:#15803d}
.flash.error{background:var(--bad-bg);color:#be123c}

/* Empty */
.empty{text-align:center;padding:40px 18px}
.empty .e-ico{width:60px;height:60px;margin:0 auto 14px;border-radius:18px;background:var(--grad-soft);display:flex;align-items:center;justify-content:center}
.empty .e-ico .icon{width:28px;height:28px;stroke:var(--purple-2)}
.empty .e-t{font-weight:750;color:var(--ink);margin-bottom:4px;font-size:15px}
.empty .muted{font-size:13px}

/* Note */
.note{display:flex;gap:10px;background:var(--info-bg);border:1px solid #e0e2fb;border-radius:13px;padding:12px 14px;font-size:12.5px;color:#4338ca;align-items:flex-start;margin-bottom:15px;line-height:1.45}
.note .icon{width:17px;height:17px;flex:none;stroke:#4f46e5;margin-top:1px}

.muted{color:var(--muted)}.center{text-align:center}.mb0{margin-bottom:0}
.cost-line{display:flex;justify-content:space-between;align-items:center;padding:9px 0;font-size:14px;color:var(--ink-2)}
.cost-line b{font-weight:800;color:var(--ink);font-size:15px}
.cost-line.total{border-top:1px dashed var(--line-2);margin-top:4px;padding-top:13px}
.cost-line.total b{color:var(--purple-2);font-size:18px}

/* Login */
.login-wrap{max-width:400px;margin:0 auto;padding:40px 24px;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;justify-content:center}
.login-logo{width:78px;height:78px;margin:0 auto 20px;background:var(--grad);border-radius:23px;display:flex;align-items:center;justify-content:center;box-shadow:0 20px 44px -14px rgba(124,58,237,.65)}
.login-logo svg{width:46px;height:46px}
.login-wrap h1{text-align:center;font-size:27px;font-weight:800;margin:0 0 4px;letter-spacing:-.7px}
.login-wrap .tag{text-align:center;color:var(--muted);margin:0 0 30px;font-size:14px;line-height:1.5}
.login-wrap .alt{text-align:center;font-size:13px;color:var(--muted);margin-top:22px;line-height:1.7}
.login-wrap .alt a{color:var(--purple-2);font-weight:700}

/* PWA Install Banner */
.pwa-banner {
  position: fixed;
  bottom: calc(75px + var(--safe-b)); /* just above the tabbar */
  left: 50%;
  transform: translateX(-50%);
  width: calc(100% - 32px);
  max-width: 448px;
  background: var(--card);
  border: 1px solid var(--line-2);
  border-radius: var(--r);
  box-shadow: var(--sh-lg);
  padding: 14px 16px;
  z-index: 99;
  animation: slideUp .4s cubic-bezier(0.16, 1, 0.3, 1);
}
@keyframes slideUp {
  from { opacity: 0; transform: translate(-50%, 20px); }
  to { opacity: 1; transform: translate(-50%, 0); }
}
.pwa-banner-content {
  display: flex;
  align-items: center;
  gap: 12px;
}
.pwa-banner-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  overflow: hidden;
  flex: none;
  box-shadow: var(--sh-sm);
}
.pwa-banner-icon img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.pwa-banner-text {
  flex: 1;
  min-width: 0;
}
.pwa-banner-text h3 {
  margin: 0;
  font-size: 14px;
  font-weight: 750;
  color: var(--ink);
  letter-spacing: -0.2px;
}
.pwa-banner-text p {
  margin: 2px 0 0;
  font-size: 11.5px;
  color: var(--muted);
  line-height: 1.35;
}
.pwa-banner-actions {
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex-none;
}
.pwa-banner-actions .btn {
  font-size: 12.5px;
  padding: 7px 14px;
  border-radius: 10px;
}

