:root{
  /* Brand — pet/vet teal-green */
  --brand:#16a394; --brand-d:#0f857a; --brand-50:#effbf8; --brand-100:#d3f3ec;
  --accent:#ff7a59; --green:#0c9d61; --amber:#f6a609; --red:#e23b3b; --blue:#1a56db;
  /* Neutrals */
  --bg:#f5f7f8; --card:#fff; --ink:#13211f; --ink-2:#3a4744; --muted:#697572; --border:#e9edec;
  /* Elevation */
  --sh-1:0 1px 2px rgba(18,30,28,.05), 0 1px 3px rgba(18,30,28,.04);
  --sh-2:0 4px 14px rgba(18,30,28,.08);
  --sh-3:0 14px 34px rgba(18,30,28,.13);
  --shadow:var(--sh-1);
  /* Spacing 8pt */
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s5:20px; --s6:24px; --s7:32px; --s8:40px;
  /* Radius */
  --r1:10px; --r2:14px; --r3:18px; --r4:24px;
  /* Motion */
  --ease:cubic-bezier(.2,.7,.3,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--ink);line-height:1.45;-webkit-font-smoothing:antialiased;
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ── Topbar ──────────────────────────────────────────────── */
.topbar{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.86);
  backdrop-filter:saturate(1.6) blur(12px);-webkit-backdrop-filter:saturate(1.6) blur(12px);
  border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;
  padding:0 var(--s5);height:58px}
.brand{font-size:19px;font-weight:800;color:var(--brand);display:flex;align-items:center;gap:var(--s2);
  white-space:nowrap;letter-spacing:-.02em}
.brand .logo{font-size:24px;transition:transform .3s var(--ease)}
.brand:hover .logo{transform:rotate(-12deg) scale(1.12)}
.nav{display:flex;align-items:center;gap:var(--s1)}
.nav a{display:flex;align-items:center;gap:var(--s2);min-height:40px;padding:0 var(--s3);border-radius:var(--r1);
  color:var(--ink-2);font-weight:600;font-size:14px;position:relative;transition:background .15s,color .15s}
.nav a:hover{background:var(--bg);color:var(--ink)}
.nav a.active{background:var(--brand-50);color:var(--brand)}
.nav a.active::after{content:'';position:absolute;left:14px;right:14px;bottom:-1px;height:2px;
  background:var(--brand);border-radius:2px}
.nav a.icon-only{width:40px;padding:0;justify-content:center;color:var(--muted);font-size:18px}
.nav a.icon-only:hover{color:var(--ink)}
@media(max-width:720px){.topbar .nav a span{display:none}.topbar .brand>span:not(.logo){display:none}}

/* ── Layout ──────────────────────────────────────────────── */
.wrap{max-width:1280px;margin:0 auto;padding:24px 28px 64px;animation:pageIn .35s var(--ease)}
@keyframes pageIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--s4);flex-wrap:wrap;margin-bottom:var(--s5)}
.page-head h1{margin-bottom:2px}
.page-head .sub{margin-bottom:0}
.ph-actions{display:flex;gap:var(--s2);flex-wrap:wrap;align-items:center}
.page-back{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-weight:600;font-size:13px;margin-bottom:var(--s2)}
.page-back:hover{color:var(--brand)}
.split{display:grid;grid-template-columns:1.3fr 1fr;gap:18px}
@media(max-width:920px){.split{grid-template-columns:1fr}}

h1{font-size:26px;font-weight:800;letter-spacing:-.4px;line-height:1.18}
h2{font-size:18px;font-weight:800;letter-spacing:-.3px;margin-bottom:var(--s3)}
h3{font-size:15px;font-weight:700}
.sub{color:var(--muted);font-size:14px}
.muted{color:var(--muted)}

/* ── Cards ───────────────────────────────────────────────── */
.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:18px;box-shadow:var(--shadow)}
.card+.card{margin-top:14px}
.grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}

/* Animal card */
.acard{background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden;
  box-shadow:var(--shadow);transition:transform .14s var(--ease),box-shadow .14s var(--ease);
  display:flex;flex-direction:column;animation:cardIn .4s var(--ease) both}
.acard:hover{transform:translateY(-4px);box-shadow:var(--sh-3)}
@keyframes cardIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.acard .thumb{height:130px;display:flex;align-items:center;justify-content:center;font-size:52px;color:#fff;
  background:linear-gradient(135deg,var(--brand),#46cdbb);position:relative;overflow:hidden}
.acard .thumb img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.acard .body{padding:14px;flex:1;display:flex;flex-direction:column;gap:6px}
.acard h3{font-size:16px}
.acard .meta{color:var(--muted);font-size:13px;display:flex;gap:10px;flex-wrap:wrap}

/* ── Buttons ─────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 18px;border-radius:11px;
  border:none;cursor:pointer;font-size:14px;font-weight:700;font-family:inherit;
  transition:background .15s,transform .08s,box-shadow .15s;text-decoration:none}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--brand);color:#fff;box-shadow:0 4px 14px rgba(22,163,148,.32)}
.btn-primary:hover{background:var(--brand-d)}
.btn-ghost{background:var(--bg);color:var(--ink);border:1px solid var(--border)}
.btn-ghost:hover{border-color:var(--brand);color:var(--brand)}
.btn-danger{background:#fdecec;color:var(--red)}
.btn-danger:hover{background:#f9dada}
.btn-sm{padding:7px 12px;font-size:13px;border-radius:9px}
.btn-block{width:100%}

/* ── Forms ───────────────────────────────────────────────── */
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:11px 14px;border:1px solid var(--border);
  border-radius:11px;font-size:15px;background:var(--card);color:var(--ink);font-family:inherit;transition:border-color .15s,box-shadow .15s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--brand);
  box-shadow:0 0 0 3px var(--brand-100)}
.field textarea{resize:vertical;min-height:64px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}
@media(max-width:560px){.form-grid{grid-template-columns:1fr}}
.form-grid .full{grid-column:1/-1}

/* ── Auth ────────────────────────────────────────────────── */
.auth{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;
  background:linear-gradient(135deg,var(--brand),#3fd3bd)}
.auth-card{background:var(--card);border-radius:22px;padding:36px;width:100%;max-width:400px;
  box-shadow:0 24px 70px rgba(0,0,0,.22);animation:popIn .4s var(--ease)}
@keyframes popIn{from{opacity:0;transform:translateY(18px) scale(.96)}to{opacity:1;transform:none}}
.auth-card .brand{justify-content:center;font-size:28px;margin-bottom:4px}
.auth-card .logo{font-size:34px}
.auth-sub{text-align:center;color:var(--muted);font-size:14px;margin-bottom:22px}

/* ── Stats ───────────────────────────────────────────────── */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:22px}
.stat{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:18px;box-shadow:var(--shadow);
  position:relative;overflow:hidden;animation:cardIn .4s var(--ease) both}
.stat .n{font-size:30px;font-weight:800;line-height:1}
.stat .l{color:var(--muted);font-size:13px;font-weight:600;margin-top:6px}
.stat .ic{position:absolute;top:14px;right:14px;font-size:22px;opacity:.85;
  width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  background:var(--brand-50);color:var(--brand)}

/* ── Table ───────────────────────────────────────────────── */
.table-wrap{overflow-x:auto;border-radius:14px;border:1px solid var(--border);background:var(--card);box-shadow:var(--shadow)}
.table{width:100%;border-collapse:collapse;font-size:14px}
.table th{text-align:left;color:var(--muted);font-size:11.5px;text-transform:uppercase;letter-spacing:.03em;
  padding:12px 14px;border-bottom:1px solid var(--border);background:#fbfcfc}
.table td{padding:12px 14px;border-bottom:1px solid var(--border)}
.table tr:last-child td{border-bottom:none}
.table tbody tr{transition:background .12s;cursor:pointer}
.table tbody tr:hover td{background:var(--brand-50)}

/* ── Pills / chips ───────────────────────────────────────── */
.pill{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:20px;font-size:12px;font-weight:700}
.s-available{background:var(--brand-50);color:var(--brand-d)}
.s-owned{background:#e8f0fe;color:var(--blue)}
.s-sold{background:#fff4e5;color:#b76e00}
.s-deceased{background:#eef0f1;color:var(--muted)}
.s-quarantined{background:#fdecec;color:var(--red)}
/* approval stages */
.s-review1{background:#fff4e5;color:#b76e00}
.s-review2{background:#e8f0fe;color:var(--blue)}
.s-admin{background:#f3e8ff;color:#7e22ce}
.s-approved{background:var(--brand-50);color:var(--brand-d)}
.s-rejected{background:#fdecec;color:var(--red)}

/* approval stepper */
.stepper{display:flex;align-items:center;gap:0;margin:4px 0 2px;flex-wrap:wrap}
.stepper .stp{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--muted)}
.stepper .stp .dot{width:24px;height:24px;border-radius:50%;background:var(--bg);border:2px solid var(--border);
  display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--muted)}
.stepper .stp.done .dot{background:var(--brand);border-color:var(--brand);color:#fff}
.stepper .stp.curr .dot{border-color:var(--brand);color:var(--brand)}
.stepper .stp.curr{color:var(--ink)}
.stepper .seg{width:34px;height:2px;background:var(--border);margin:0 6px}
.stepper .seg.done{background:var(--brand)}

/* approval timeline */
.timeline{list-style:none;margin:6px 0 0;padding:0}
.timeline li{position:relative;padding:0 0 14px 22px;border-left:2px solid var(--border)}
.timeline li:last-child{border-left-color:transparent}
.timeline li::before{content:'';position:absolute;left:-6px;top:3px;width:10px;height:10px;border-radius:50%;background:var(--brand)}
.timeline li.rej::before{background:var(--red)}
.timeline .tl-main{font-weight:600;font-size:14px}
.timeline .tl-sub{color:var(--muted);font-size:12.5px}
.chip.due{background:#fff4e5;color:#b76e00}
.chip.overdue{background:#fdecec;color:var(--red)}
.chip.ok{background:var(--brand-50);color:var(--brand-d)}

/* Key/value profile grid */
.kv{display:grid;grid-template-columns:auto 1fr;gap:8px 18px;font-size:14px}
.kv dt{color:var(--muted);font-weight:600}
.kv dd{color:var(--ink)}

/* Photo upload field with preview */
.photo-field{display:flex;align-items:center;gap:14px}
.photo-prev{width:64px;height:64px;border-radius:14px;object-fit:cover;background:var(--brand-50);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;color:var(--brand);font-size:24px}
.chip{display:inline-flex;align-items:center;gap:4px;background:var(--bg);border-radius:20px;padding:3px 10px;
  font-size:12px;font-weight:600;color:var(--muted)}

/* ── Avatar ──────────────────────────────────────────────── */
.avatar{width:40px;height:40px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;
  font-weight:800;font-size:18px;color:#fff;background:linear-gradient(135deg,var(--brand),#46cdbb);flex-shrink:0}
.user-cell{display:flex;align-items:center;gap:12px}

/* ── Searchbar / filters ─────────────────────────────────── */
.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:18px}
.searchbar{flex:1;min-width:220px;position:relative}
.searchbar i{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--muted)}
.searchbar input{width:100%;padding:11px 14px 11px 40px;border:1px solid var(--border);border-radius:12px;
  font-size:15px;background:var(--card);font-family:inherit}
.searchbar input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-100)}
.filters{display:flex;gap:8px;flex-wrap:wrap}
.filters a{padding:8px 14px;border-radius:20px;background:var(--card);border:1px solid var(--border);
  font-size:13px;font-weight:600;color:var(--muted);transition:all .15s}
.filters a.active{background:var(--brand);color:#fff;border-color:var(--brand)}

/* ── Sub-record sections (detail tabs) ───────────────────── */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:16px}
.tabs button{background:none;border:none;font-family:inherit;font-size:14px;font-weight:700;color:var(--muted);
  padding:10px 16px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s}
.tabs button.active{color:var(--brand);border-bottom-color:var(--brand)}
.tabpane{display:none;animation:pageIn .3s var(--ease)}
.tabpane.active{display:block}
.row-line{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}
.row-line:last-child{border-bottom:none}
.row-line .rl-main{font-weight:600}
.row-line .rl-sub{color:var(--muted);font-size:13px}

/* ── Empty state ─────────────────────────────────────────── */
.empty{text-align:center;padding:56px 20px;color:var(--muted)}
.empty .em-ic{font-size:52px;margin-bottom:12px;opacity:.5}

/* ── Toasts ──────────────────────────────────────────────── */
.toasts{position:fixed;top:72px;right:18px;z-index:3000;display:flex;flex-direction:column;gap:8px}
.toast{background:var(--ink);color:#fff;padding:12px 18px;border-radius:12px;font-weight:600;font-size:14px;
  box-shadow:var(--sh-3);display:flex;align-items:center;gap:9px;max-width:340px;
  opacity:0;transform:translateX(24px);transition:opacity .35s var(--ease),transform .35s var(--ease)}
.toast.in{opacity:1;transform:none}
.toast.success{background:var(--green)}.toast.error{background:var(--red)}.toast.info{background:var(--blue)}

/* ── Modal ───────────────────────────────────────────────── */
.modal{position:fixed;inset:0;z-index:4000;background:rgba(15,25,23,.5);display:none;align-items:center;
  justify-content:center;padding:18px;opacity:0;transition:opacity .2s}
.modal.open{display:flex;opacity:1}
.modal-card{background:var(--card);border-radius:18px;padding:24px;width:100%;max-width:540px;max-height:90vh;
  overflow-y:auto;box-shadow:0 24px 70px rgba(0,0,0,.3);
  transform:translateY(16px) scale(.97);transition:transform .25s cubic-bezier(.2,.8,.3,1.1)}
.modal.open .modal-card{transform:none}
.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.modal-head h2{margin:0}
.modal-x{background:var(--bg);border:none;border-radius:10px;width:36px;height:36px;cursor:pointer;
  font-size:18px;color:var(--muted);transition:background .15s}
.modal-x:hover{background:var(--border)}
.modal-foot{display:flex;justify-content:flex-end;gap:10px;margin-top:8px}

/* ── Photo / detail header ───────────────────────────────── */
.animal-hero{display:flex;gap:18px;align-items:center;margin-bottom:6px}
.animal-hero .pic{width:88px;height:88px;border-radius:20px;flex-shrink:0;overflow:hidden;
  background:linear-gradient(135deg,var(--brand),#46cdbb);display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:40px;box-shadow:var(--sh-2)}
.animal-hero .pic img{width:100%;height:100%;object-fit:cover}
