/* ================================================================
   IAPPET — Design System v4.0
   Austero, editorial, corporativo. Cantos mínimos. Hierarquia clara.
   ================================================================ */

:root {
  --ink:        #1A1A1A;
  --ink-2:      #4A4A4A;
  --ink-3:      #8A8A8A;
  --ink-4:      #C4C4C4;
  --canvas:     #F6F5F3;
  --surface:    #FFFFFF;
  --surface-2:  #F0EFED;
  --rim:        #E2E1DE;
  --rim-2:      #CACAC4;
  --crimson:    #C8102E;
  --crimson-dk: #9E0B23;
  --crimson-bg: #FDF2F4;
  --amber:      #B45309;
  --amber-bg:   #FFFAEB;
  --slate:      #2D4A6B;
  --slate-bg:   #EEF4FC;
  --moss:       #2D6A4F;
  --moss-bg:    #EDFBF3;
  --font-display: 'DM Serif Display', Georgia, serif;
  --font-body:    'DM Sans', system-ui, -apple-system, sans-serif;
  --r-xs: 2px;  --r-sm: 4px;  --r-md: 6px;  --r-lg: 8px;
  --shadow-sm: 0 1px 3px rgba(26,26,26,.07);
  --shadow-md: 0 3px 14px rgba(26,26,26,.10);
  --shadow-lg: 0 8px 32px rgba(26,26,26,.14);
  --ease: cubic-bezier(.22,.68,0,1.05);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;text-size-adjust:100%}
body{font-family:var(--font-body);background:var(--canvas);color:var(--ink);min-height:100vh;font-size:15px;line-height:1.65;-webkit-font-smoothing:antialiased}
button{font-family:var(--font-body);cursor:pointer;border:none;outline:none}
button:focus-visible{outline:2px solid var(--crimson);outline-offset:2px}
input,select,textarea{font-family:var(--font-body);outline:none}
a{color:inherit}
strong{font-weight:600}

/* ── TOPBAR ───────────────────────────────────────────────────── */
.topbar{position:sticky;top:0;z-index:300;background:var(--ink);height:54px;display:flex;align-items:center;justify-content:space-between;padding:0 2rem;border-bottom:1px solid rgba(255,255,255,.06)}
.logo{display:flex;align-items:center;gap:10px;user-select:none}
.logo-mark{width:30px;height:30px;background:var(--crimson);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:16px;color:#fff;flex-shrink:0}
.logo-name{font-family:var(--font-display);font-size:19px;color:#fff;letter-spacing:.01em}
.logo-name span{color:var(--crimson)}
.topbar-clinic{display:flex;align-items:center;gap:7px;font-size:11px;color:rgba(255,255,255,.45);font-weight:500;letter-spacing:.05em;text-transform:uppercase}
.clinic-dot{width:6px;height:6px;border-radius:50%;background:var(--moss);flex-shrink:0}

/* ── PROGRESS ─────────────────────────────────────────────────── */
.progress-rail{background:var(--surface);border-bottom:1px solid var(--rim);padding:0 2rem}
.progress-inner{max-width:680px;margin:0 auto;display:flex;align-items:center;padding:11px 0}
.p-step{display:flex;align-items:center;gap:7px;font-size:11.5px;font-weight:600;color:var(--ink-4);letter-spacing:.03em;white-space:nowrap}
.p-step.is-done{color:var(--ink-2)}.p-step.is-active{color:var(--ink)}
.p-node{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--rim-2);background:var(--canvas);display:flex;align-items:center;justify-content:center;font-size:9.5px;font-weight:700;flex-shrink:0;transition:all .2s var(--ease)}
.p-step.is-done .p-node{background:var(--ink);border-color:var(--ink);color:#fff}
.p-step.is-active .p-node{background:var(--crimson);border-color:var(--crimson);color:#fff}
.p-line{flex:1;height:1px;background:var(--rim);margin:0 5px}
.p-line.is-done{background:var(--rim-2)}
@media(max-width:520px){.p-step-label{display:none}}

/* ── LAYOUT ───────────────────────────────────────────────────── */
.main{max-width:680px;margin:0 auto;padding:2rem 1rem 6rem}

/* ── PANEL ────────────────────────────────────────────────────── */
.panel{background:var(--surface);border:1px solid var(--rim);border-radius:var(--r-lg);padding:2.25rem 2rem;box-shadow:var(--shadow-md);animation:panelIn .28s var(--ease) both}
@keyframes panelIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.panel-eyebrow{font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--crimson);margin-bottom:5px}
.panel-title{font-family:var(--font-display);font-size:26px;line-height:1.15;color:var(--ink);margin-bottom:5px}
.panel-sub{font-size:13.5px;color:var(--ink-3);margin-bottom:1.75rem;line-height:1.6}

/* ── SPECIES ──────────────────────────────────────────────────── */
.species-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:1.5rem}
.species-card{border:1.5px solid var(--rim);border-radius:var(--r-md);padding:1.75rem 1rem 1.5rem;background:var(--canvas);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:10px;transition:border-color .16s,background .16s;position:relative}
.species-card:hover{border-color:var(--rim-2);background:var(--surface)}
.species-card.is-sel{border-color:var(--crimson);background:var(--surface)}
.species-card.is-sel::after{content:'✓';position:absolute;top:8px;right:10px;width:18px;height:18px;border-radius:50%;background:var(--crimson);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center}
.s-icon{font-size:44px;line-height:1}
.s-name{font-family:var(--font-display);font-size:18px;color:var(--ink)}
.species-card.is-sel .s-name{color:var(--crimson)}

/* ── FORM ─────────────────────────────────────────────────────── */
.field{margin-bottom:1.25rem}
.field-label{display:block;font-size:11.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2);margin-bottom:6px}
.field-label span{font-weight:400;text-transform:none;color:var(--ink-3);font-size:11px}
.f-input{width:100%;height:48px;border:1.5px solid var(--rim-2);border-radius:var(--r-md);background:var(--canvas);padding:0 13px;font-size:15px;color:var(--ink);transition:border-color .14s,background .14s}
.f-input:focus{border-color:var(--ink);background:var(--surface)}
.f-input.is-err{border-color:#D44;background:#FFF5F5}
input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{opacity:1}

/* ── SEX ──────────────────────────────────────────────────────── */
.sex-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.sex-card{height:48px;border:1.5px solid var(--rim-2);border-radius:var(--r-md);background:var(--canvas);display:flex;align-items:center;justify-content:center;gap:8px;font-size:14px;font-weight:600;color:var(--ink-3);cursor:pointer;transition:all .14s}
.sex-macho.is-sel{background:#EEF4FC;border-color:#3B82F6;color:#1E3A8A}
.sex-femea.is-sel{background:#FDF2F8;border-color:#EC4899;color:#831843}

/* ── ALERTS ───────────────────────────────────────────────────── */
.alert{border-radius:var(--r-md);padding:11px 14px;font-size:13px;line-height:1.55;display:flex;gap:10px;align-items:flex-start;margin:10px 0}
.alert-icon{font-size:15px;flex-shrink:0;line-height:1.45}
.a-warn{background:var(--amber-bg);border:1px solid #E6A830;color:#7C3D0A}
.a-info{background:var(--slate-bg);border:1px solid #93B4D9;color:#1A3A5C}
.a-block{background:var(--crimson-bg);border:1px solid #DDA0A8;color:#6E0E1C}
.a-ok{background:var(--moss-bg);border:1px solid #6DC993;color:#1A4A32}

/* ── CATALOG ──────────────────────────────────────────────────── */
.cat-strip{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.cat-pill{padding:4px 12px;border-radius:var(--r-md);border:1.5px solid var(--rim);font-size:11.5px;font-weight:700;background:var(--surface);color:var(--ink-3);cursor:pointer;transition:all .13s}
.cat-pill:hover{border-color:var(--ink-3);color:var(--ink-2)}
.cat-pill.is-on{background:var(--ink);border-color:var(--ink);color:#fff}
.search-wrap{position:relative;margin-bottom:12px}
.search-wrap input{width:100%;height:42px;border:1.5px solid var(--rim-2);border-radius:var(--r-md);background:var(--canvas);padding:0 13px 0 36px;font-size:13.5px;color:var(--ink);transition:border-color .13s}
.search-wrap input:focus{border-color:var(--ink);background:var(--surface)}
.search-ico{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:14px;color:var(--ink-3);pointer-events:none}

/* ── SERVICE CARDS ────────────────────────────────────────────── */
.svc-list{display:flex;flex-direction:column;gap:7px}
.svc-card{border:1.5px solid var(--rim);border-radius:var(--r-md);padding:13px 15px;display:flex;align-items:flex-start;gap:11px;cursor:pointer;background:var(--surface);transition:border-color .13s}
.svc-card:hover{border-color:var(--rim-2)}
.svc-card.is-sel{border-color:var(--ink)}
.svc-card.is-locked{cursor:default;background:var(--surface-2);border-style:dashed}
.svc-chk{width:20px;height:20px;flex-shrink:0;margin-top:2px;border:1.5px solid var(--rim-2);border-radius:var(--r-xs);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;transition:all .13s}
.svc-card.is-sel .svc-chk{background:var(--ink);border-color:var(--ink)}
.svc-card.is-locked .svc-chk{background:var(--rim);border-color:var(--rim);color:var(--ink-3);font-size:12px}
.svc-body{flex:1;min-width:0}
.svc-name{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:2px}
.svc-value{font-size:12px;color:var(--ink-3);line-height:1.5}
.svc-tags{display:flex;gap:5px;flex-wrap:wrap;margin-top:7px}
.tag{font-size:10px;font-weight:700;padding:2px 7px;border-radius:var(--r-xs);white-space:nowrap;text-transform:uppercase;letter-spacing:.03em}
.tag-warn{background:var(--amber-bg);color:var(--amber);border:1px solid #E6A830}
.tag-info{background:var(--slate-bg);color:var(--slate);border:1px solid #93B4D9}
.tag-lock{background:var(--surface-2);color:var(--ink-3);border:1px solid var(--rim)}
.tag-moss{background:var(--moss-bg);color:var(--moss);border:1px solid #6DC993}
.svc-right{text-align:right;flex-shrink:0}
.svc-price{font-family:var(--font-display);font-size:15px;color:var(--ink);white-space:nowrap}

/* ── SCHEDULING ───────────────────────────────────────────────── */
.sched-box{background:var(--slate-bg);border:1px solid #93B4D9;border-radius:var(--r-md);padding:14px 16px;margin:1rem 0}
.sched-title{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--slate);margin-bottom:10px}
.sched-row{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:8px}
.sched-chip{padding:5px 12px;border-radius:var(--r-md);border:1.5px solid #93B4D9;font-size:12.5px;font-weight:600;color:var(--slate);cursor:pointer;background:var(--surface);transition:all .13s}
.sched-chip.is-on{background:var(--slate);border-color:var(--slate);color:#fff}
.sched-note{font-size:11.5px;color:var(--slate);opacity:.8;margin-top:4px}

/* ── PAGINATION ───────────────────────────────────────────────── */
.pagination{display:flex;justify-content:center;gap:6px;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--rim)}
.page-btn{width:34px;height:34px;border-radius:var(--r-sm);border:1px solid var(--rim-2);background:var(--canvas);color:var(--ink-2);font-weight:600;font-size:12px;cursor:pointer;transition:all .13s}
.page-btn.is-active{background:var(--ink);border-color:var(--ink);color:#fff}

/* ── PET TABS ─────────────────────────────────────────────────── */
.pet-tabs{display:flex;gap:7px;margin-bottom:1.25rem;overflow-x:auto;padding-bottom:3px}
.pet-tab{padding:5px 13px;border-radius:var(--r-md);border:1.5px solid var(--rim-2);font-size:13px;font-weight:600;background:var(--surface);color:var(--ink-2);cursor:pointer;white-space:nowrap;display:flex;align-items:center;gap:6px;transition:all .13s}
.pet-tab.is-on{background:var(--ink);border-color:var(--ink);color:#fff}
.pet-tab-add{border-style:dashed;color:var(--ink-3);font-size:12px}
.pet-tab-add.disabled{opacity:.4;cursor:not-allowed}

/* ── CART ─────────────────────────────────────────────────────── */
.cart-section-title{font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-3);padding-bottom:7px;border-bottom:1px solid var(--rim);margin-bottom:2px}
.cart-row{display:flex;align-items:flex-start;gap:10px;padding:9px 0;border-bottom:1px solid var(--rim)}
.cart-row:last-child{border-bottom:none}
.cart-name{flex:1;font-size:13.5px;font-weight:500;color:var(--ink)}
.cart-sub{font-size:11.5px;color:var(--ink-3);margin-top:2px}
.cart-price{font-family:var(--font-display);font-size:14px;color:var(--ink);flex-shrink:0}
.cart-del{width:24px;height:24px;border-radius:var(--r-sm);border:1px solid var(--rim);background:none;display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--ink-3);cursor:pointer;transition:all .13s;flex-shrink:0;margin-top:1px}
.cart-del:hover{background:var(--crimson-bg);border-color:#DDA0A8;color:var(--crimson)}

/* ── TOTALS ───────────────────────────────────────────────────── */
.totals-block{background:var(--canvas);border:1px solid var(--rim);border-radius:var(--r-md);padding:14px 16px;margin-top:12px}
.total-row{display:flex;justify-content:space-between;align-items:baseline;padding:3px 0}
.total-label{font-size:12.5px;color:var(--ink-2)}
.total-val{font-family:var(--font-display);font-size:14.5px;color:var(--ink)}
.total-row.is-main{border-top:1px solid var(--rim-2);margin-top:8px;padding-top:10px}
.total-row.is-main .total-label{font-size:14px;font-weight:700;color:var(--ink)}
.total-row.is-main .total-val{font-size:22px}
.total-row.is-sinal .total-val{color:var(--amber)}

/* ── BUTTONS ──────────────────────────────────────────────────── */
.btn-row{display:grid;gap:9px;grid-template-columns:48px 1fr;align-items:center;margin-top:1.5rem}
.btn-back{width:48px;height:48px;border-radius:var(--r-md);border:1.5px solid var(--rim-2);background:var(--canvas);font-size:17px;color:var(--ink-2);display:flex;align-items:center;justify-content:center;transition:all .13s}
.btn-back:hover{border-color:var(--ink);color:var(--ink)}
.btn{height:48px;border-radius:var(--r-md);font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:7px;width:100%;letter-spacing:.015em;transition:all .14s}
.btn-ink{background:var(--ink);color:#fff}
.btn-ink:hover:not(:disabled){background:#2C2C2C}
.btn-ink:disabled{background:var(--rim);color:var(--ink-4);cursor:not-allowed}
.btn-crimson{background:var(--crimson);color:#fff}
.btn-crimson:hover:not(:disabled){background:var(--crimson-dk)}
.btn-crimson:disabled{background:var(--rim);color:var(--ink-4);cursor:not-allowed}
.btn-ghost{background:none;border:1.5px solid var(--rim-2);color:var(--ink-2);margin-top:8px}
.btn-ghost:hover{border-color:var(--ink-2);color:var(--ink)}
.btn-full{grid-column:1/-1}
.btn-sm{height:34px;font-size:12.5px;padding:0 14px;border-radius:var(--r-sm);font-weight:700}

/* ── VALIDATION CODE ──────────────────────────────────────────── */
.val-code-box{background:var(--ink);color:#fff;border-radius:var(--r-md);padding:14px 18px;text-align:center;margin:1.25rem 0}
.val-code-label{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:5px}
.val-code{font-family:var(--font-display);font-size:28px;letter-spacing:.12em;color:#fff}
.val-code-note{font-size:11.5px;color:rgba(255,255,255,.4);margin-top:5px}

/* ── CONFIRM ──────────────────────────────────────────────────── */
.confirm-head{text-align:center;padding-bottom:1.5rem;border-bottom:1px solid var(--rim);margin-bottom:1.5rem}
.confirm-mark{font-size:48px;display:block;margin-bottom:.75rem}
.confirm-h{font-family:var(--font-display);font-size:26px;color:var(--ink);margin-bottom:4px}
.confirm-sub{font-size:13.5px;color:var(--ink-3);max-width:340px;margin:0 auto;line-height:1.6}
.wa-btn-primary{display:flex;align-items:center;justify-content:center;gap:8px;height:52px;background:#25D366;color:#fff;border-radius:var(--r-md);font-size:15px;font-weight:700;text-decoration:none;margin:1.25rem 0 .5rem;width:100%;cursor:pointer;transition:background .14s}
.wa-btn-primary:hover{background:#1EB657}

/* ── MODAL ────────────────────────────────────────────────────── */
.modal-backdrop{position:fixed;inset:0;z-index:800;background:rgba(10,10,10,.65);display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .2s ease both}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal-box{background:var(--surface);border-radius:var(--r-lg);width:100%;max-width:560px;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:slideUp .25s var(--ease) both}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.modal-header{padding:1.75rem 1.75rem 1rem;border-bottom:1px solid var(--rim)}
.modal-title{font-family:var(--font-display);font-size:22px;color:var(--ink);margin-bottom:4px}
.modal-sub{font-size:13px;color:var(--ink-3)}
.modal-body{overflow-y:auto;padding:1.25rem 1.75rem;flex:1}
.terms-section{margin-bottom:1.1rem}
.terms-section-title{font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-2);margin-bottom:5px}
.terms-section p{font-size:13px;color:var(--ink-2);line-height:1.65}
.modal-footer{padding:1rem 1.75rem 1.5rem;border-top:1px solid var(--rim)}
.terms-check-row{display:flex;align-items:flex-start;gap:10px;cursor:pointer;margin-bottom:1rem}
.terms-check-row input[type=checkbox]{width:16px;height:16px;margin-top:2px;accent-color:var(--ink);cursor:pointer;flex-shrink:0}
.terms-check-row span{font-size:13px;color:var(--ink-2);line-height:1.55}
.modal-actions{display:flex;gap:10px;justify-content:flex-end}

/* ── CELEBRAÇÃO ───────────────────────────────────────────────── */
.celeb-overlay{position:fixed;inset:0;z-index:900;background:var(--ink);display:flex;align-items:center;justify-content:center;flex-direction:column;animation:fadeIn .3s ease both}
.celeb-content{text-align:center;padding:2rem}
.celeb-icon{font-size:64px;display:block;margin-bottom:1.25rem;animation:bounceIn .5s var(--ease)}
@keyframes bounceIn{0%{transform:scale(.4);opacity:0}70%{transform:scale(1.15)}100%{transform:scale(1);opacity:1}}
.celeb-title{font-family:var(--font-display);font-size:36px;color:#fff;margin-bottom:.5rem}
.celeb-sub{font-size:15px;color:rgba(255,255,255,.55);margin-bottom:2rem}
.celeb-ring-wrap{position:relative;width:88px;height:88px;margin:0 auto 1.25rem}
.celeb-svg{width:88px;height:88px;transform:rotate(-90deg)}
.celeb-track{fill:none;stroke:rgba(255,255,255,.12);stroke-width:4}
.celeb-arc{fill:none;stroke:var(--crimson);stroke-width:4;stroke-linecap:round;stroke-dasharray:138.2;stroke-dashoffset:0;transition:stroke-dashoffset 1s linear}
.celeb-count{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-display);font-size:32px;color:#fff}
.celeb-wa-link{display:block;margin-top:1rem;padding:10px 24px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:var(--r-md);color:#fff;font-size:14px;font-weight:600;text-decoration:none;cursor:pointer;transition:background .14s}
.celeb-wa-link:hover{background:rgba(255,255,255,.2)}

/* ════════════════════════════════════════════════════════════════
   PAINEL ADMIN — /admin
   ════════════════════════════════════════════════════════════════ */
.admin-wrap,.master-wrap{max-width:900px;margin:0 auto;padding:2rem 1rem 6rem}
.panel-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:2rem;gap:1rem;flex-wrap:wrap}
.panel-header-left{}
.panel-h1{font-family:var(--font-display);font-size:28px;color:var(--ink);margin-bottom:2px}
.panel-h1-sub{font-size:13px;color:var(--ink-3)}
.panel-header-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}

/* Tabs */
.admin-tabs{display:flex;gap:0;border-bottom:1px solid var(--rim);margin-bottom:1.75rem}
.admin-tab{padding:9px 20px;font-size:13px;font-weight:600;color:var(--ink-3);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .14s;background:none;white-space:nowrap;position:relative}
.admin-tab:hover{color:var(--ink-2)}
.admin-tab.is-on{color:var(--ink);border-bottom-color:var(--ink)}
.admin-section{display:none}.admin-section.is-on{display:block}

/* Notif badge */
.notif-badge{display:inline-block;background:var(--crimson);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px;margin-left:5px;vertical-align:middle}

/* Quote search */
.code-lookup{display:flex;gap:10px;margin-bottom:1.5rem}
.code-lookup input{flex:1;height:48px;border:1.5px solid var(--rim-2);border-radius:var(--r-md);background:var(--canvas);padding:0 14px;font-size:16px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink)}
.code-lookup input:focus{border-color:var(--ink);background:var(--surface)}

/* Quote result */
.quote-result{background:var(--surface);border:1px solid var(--rim);border-radius:var(--r-lg);padding:1.5rem}
.quote-result-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--rim)}
.quote-result-code{font-family:var(--font-display);font-size:22px;color:var(--ink);letter-spacing:.08em}
.quote-result-date{font-size:12px;color:var(--ink-3);margin-top:3px}
.quote-status{font-size:11px;font-weight:700;padding:3px 10px;border-radius:var(--r-sm);text-transform:uppercase;letter-spacing:.05em}
.qs-pending{background:var(--amber-bg);color:var(--amber);border:1px solid #E6A830}
.qs-attended{background:var(--moss-bg);color:var(--moss);border:1px solid #6DC993}
.qs-cancelled{background:var(--crimson-bg);color:var(--crimson);border:1px solid #DDA0A8}

/* Services table */
.svc-table{width:100%;border-collapse:collapse;font-size:13.5px}
.svc-table th{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);text-align:left;padding:8px 12px;border-bottom:1.5px solid var(--rim);background:var(--canvas);white-space:nowrap}
.svc-table td{padding:9px 12px;border-bottom:1px solid var(--rim);vertical-align:middle}
.svc-table tr:hover td{background:var(--canvas)}
.svc-table input[type=text],.svc-table input[type=number],.svc-table select{height:32px;border:1px solid var(--rim-2);border-radius:var(--r-sm);background:var(--canvas);padding:0 7px;font-size:12.5px;color:var(--ink);width:100%}
.svc-table input:focus,.svc-table select:focus{border-color:var(--ink);background:var(--surface)}

/* Toggle switch */
.toggle-pill{position:relative;width:38px;height:22px;cursor:pointer;flex-shrink:0}
.toggle-pill input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;inset:0;background:var(--rim-2);border-radius:11px;transition:background .2s}
.toggle-slider::before{content:'';position:absolute;width:16px;height:16px;border-radius:50%;background:#fff;top:3px;left:3px;transition:transform .2s}
.toggle-pill input:checked+.toggle-slider{background:var(--moss)}
.toggle-pill input:checked+.toggle-slider::before{transform:translateX(16px)}

/* Tag editor */
.tag-editor{display:flex;flex-wrap:wrap;gap:5px;align-items:center}
.tag-editable{display:flex;align-items:center;gap:3px}
.tag-editable button{background:none;border:none;cursor:pointer;color:inherit;font-size:11px;padding:0 2px;line-height:1}
.tag-add-btn{padding:2px 7px;border-radius:var(--r-xs);border:1px dashed var(--rim-2);background:none;font-size:10px;font-weight:700;color:var(--ink-3);cursor:pointer}
.tag-add-btn:hover{border-color:var(--ink-2);color:var(--ink-2)}

/* Notification card */
.notif-card{background:var(--crimson-bg);border:1px solid #DDA0A8;border-radius:var(--r-md);padding:14px 16px;margin-bottom:10px;display:flex;align-items:flex-start;gap:12px}
.notif-card-info{flex:1}
.notif-card-title{font-size:14px;font-weight:700;color:var(--crimson)}
.notif-card-desc{font-size:12.5px;color:var(--ink-2);margin-top:2px}

/* ════════════════════════════════════════════════════════════════
   PAINEL MASTER
   ════════════════════════════════════════════════════════════════ */
.clinic-card{background:var(--surface);border:1px solid var(--rim);border-radius:var(--r-lg);padding:1.25rem 1.5rem;margin-bottom:10px;display:flex;align-items:flex-start;gap:14px;flex-wrap:wrap}
.clinic-card-info{flex:1;min-width:200px}
.clinic-card-name{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:2px}
.clinic-card-meta{font-size:12px;color:var(--ink-3)}
.clinic-card-actions{display:flex;gap:7px;align-items:center;flex-wrap:wrap}
.status-pill{font-size:10.5px;font-weight:700;padding:3px 10px;border-radius:var(--r-sm);text-transform:uppercase;letter-spacing:.05em}
.sp-active{background:var(--moss-bg);color:var(--moss);border:1px solid #6DC993}
.sp-inactive{background:var(--crimson-bg);color:var(--crimson);border:1px solid #DDA0A8}
.sp-crmv{background:var(--amber-bg);color:var(--amber);border:1px solid #E6A830}
.kill-btn{height:32px;padding:0 12px;border-radius:var(--r-sm);font-size:12px;font-weight:700;cursor:pointer;transition:all .14s}
.kill-deactivate{background:var(--crimson-bg);color:var(--crimson);border:1px solid #DDA0A8}
.kill-deactivate:hover{background:var(--crimson);color:#fff}
.kill-activate{background:var(--moss-bg);color:var(--moss);border:1px solid #6DC993}
.kill-activate:hover{background:var(--moss);color:#fff}
.kill-crmv{background:var(--amber-bg);color:var(--amber);border:1px solid #E6A830}
.kill-crmv:hover{background:var(--amber);color:#fff}
.kill-neutral{background:var(--surface-2);color:var(--ink-2);border:1px solid var(--rim-2)}
.kill-neutral:hover{background:var(--ink);color:#fff;border-color:var(--ink)}

/* Billing rows */
.billing-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--rim);flex-wrap:wrap}
.billing-row:last-child{border-bottom:none}
.billing-desc{flex:1;font-size:13.5px;color:var(--ink)}
.billing-date{font-size:12px;color:var(--ink-3);white-space:nowrap}
.billing-amount{font-family:var(--font-display);font-size:14px;color:var(--ink);white-space:nowrap}
.billing-late{color:var(--crimson);font-weight:700}

/* CSV export button */
.btn-csv{height:34px;padding:0 14px;border-radius:var(--r-sm);border:1.5px solid var(--rim-2);background:var(--canvas);color:var(--ink-2);font-size:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .14s;white-space:nowrap}
.btn-csv:hover{border-color:var(--ink);color:var(--ink)}

/* Login */
.login-wrap{max-width:380px;margin:3rem auto 0}
.login-box{background:var(--surface);border:1px solid var(--rim);border-radius:var(--r-lg);padding:2rem;box-shadow:var(--shadow-md)}
.login-title{font-family:var(--font-display);font-size:24px;color:var(--ink);margin-bottom:.25rem}
.login-sub{font-size:13px;color:var(--ink-3);margin-bottom:1.5rem}
.login-err{font-size:12.5px;color:var(--crimson);margin-top:8px;min-height:18px}

/* ── LGPD ─────────────────────────────────────────────────────── */
.lgpd-banner{position:fixed;bottom:0;left:0;right:0;z-index:500;background:var(--ink);color:rgba(255,255,255,.7);font-size:12.5px;line-height:1.5;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:13px 2rem;border-top:1px solid rgba(255,255,255,.1);transform:translateY(100%);transition:transform .3s var(--ease)}
.lgpd-banner.is-visible{transform:translateY(0)}
.lgpd-btn{flex-shrink:0;background:var(--crimson);color:#fff;border-radius:var(--r-sm);padding:5px 15px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .13s}
.lgpd-btn:hover{background:var(--crimson-dk)}

/* ── MISC ─────────────────────────────────────────────────────── */
.divider{height:1px;background:var(--rim);margin:1rem 0}
.empty-state{text-align:center;padding:3rem 1rem;color:var(--ink-3);font-size:13px}
.copy-btn{background:var(--slate-bg);color:var(--slate);border:1px solid #93B4D9;border-radius:var(--r-sm);padding:2px 8px;font-size:11px;font-weight:700;cursor:pointer;transition:all .13s}
.copy-btn:hover{background:var(--slate);color:#fff}

/* ── RESPONSIVE ───────────────────────────────────────────────── */
@media(max-width:480px){
  .topbar{padding:0 1rem}
  .progress-rail{padding:0 1rem}
  .main{padding:1.25rem .75rem 5rem}
  .panel{padding:1.75rem 1.25rem}
  .panel-title{font-size:22px}
  .lgpd-banner{flex-direction:column;text-align:center;padding:13px 1.25rem}
  .modal-header,.modal-body,.modal-footer{padding-left:1.25rem;padding-right:1.25rem}
  .admin-tab{padding:9px 12px;font-size:12px}
  .svc-table{font-size:12px}
  .svc-table th,.svc-table td{padding:7px 8px}
}

/* ── AJUSTES DA TABELA COM SCROLL FIXO E PAGINAÇÃO (V4.3) ────── */
.svc-table-wrap {
    width: 100%;
    overflow-x: auto;
    overflow-y: auto;
    max-height: 60vh; /* Mantém o cabeçalho fixo na tela */
    border-radius: var(--r-md);
    border: 1px solid var(--rim);
    position: relative;
    background: var(--surface);
}
.svc-table {
    min-width: 850px;
    width: 100%;
    border-collapse: separate; /* Necessário para o sticky funcionar com bordas */
    border-spacing: 0;
}
.svc-table th {
    position: sticky;
    top: 0;
    z-index: 10;
    background: var(--surface-2);
    border-bottom: 1.5px solid var(--rim);
}
/* O Segredo: Fixando a coluna de ações à direita */
.svc-table th:last-child,
.svc-table td:last-child {
    position: sticky;
    right: 0;
    background: var(--surface);
    z-index: 5;
    box-shadow: -3px 0 8px rgba(0,0,0,0.04);
}
.svc-table th:last-child {
    z-index: 15; /* Topo e Direita ao mesmo tempo */
    background: var(--surface-2);
}
.svc-table tr:hover td {
    background: var(--canvas);
}
.svc-table tr.row-inactive td {
    background-color: var(--surface-2);
    color: var(--ink-3);
}
.svc-table tr.row-inactive td input,
.svc-table tr.row-inactive td select {
    opacity: 0.6;
}
#svcModal {
    z-index: 1000;
}
