/* ================================================================
   VETTA SaaS Platform — Next-Gen Design System
   Fonts: Syne (display) + DM Sans (body) + DM Mono (code)
   ================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Syne:wght@700;800&family=DM+Sans:wght@300;400;500;600;700;800&family=DM+Mono:wght@400;500&family=Playfair+Display:ital,wght@0,700;0,900;1,700&display=swap');

/* ── DESIGN TOKENS ── */
:root {
  --blue:      #1565C0;
  --blue-d:    #0D47A1;
  --blue-m:    #1976D2;
  --blue-l:    #E3F2FD;
  --blue-ll:   #EFF6FF;
  --teal:      #0097A7;
  --teal-l:    #E0F7FA;
  --grad:      linear-gradient(135deg, #1565C0 0%, #0097A7 100%);
  --grad-soft: linear-gradient(135deg, #EFF6FF 0%, #E0F7FA 100%);

  --ink:    #0A0F1E;
  --ink-2:  #1E293B;
  --ink-3:  #475569;
  --ink-4:  #94A3B8;
  --ink-5:  #CBD5E1;
  --line:   #E2E8F0;
  --line-l: #F1F5F9;
  --bg:     #F8FAFC;
  --white:  #FFFFFF;

  --green:   #059669; --green-l:  #DCFCE7; --green-ll: #F0FDF4;
  --red:     #DC2626; --red-l:    #FEE2E2; --red-ll:   #FFF5F5;
  --amber:   #D97706; --amber-l:  #FEF3C7; --amber-ll: #FFFBEB;
  --purple:  #7C3AED; --purple-l: #EDE9FE; --purple-ll:#F5F3FF;

  --r-xs:  6px;  --r-sm:  8px;  --r-md:  12px;
  --r-lg:  16px; --r-xl:  20px; --r-2xl: 28px;

  --sh-xs: 0 1px 2px rgba(0,0,0,0.04);
  --sh-sm: 0 1px 3px rgba(0,0,0,0.06), 0 4px 16px rgba(0,0,0,0.06);
  --sh-md: 0 4px 8px rgba(0,0,0,0.05), 0 12px 32px rgba(0,0,0,0.08);
  --sh-lg: 0 24px 64px rgba(0,0,0,0.14);
  --sh-blue: 0 4px 24px rgba(21,101,192,.28);
  --sh-blue-lg: 0 8px 40px rgba(21,101,192,.38);
}

/* ── BASE RESETS ── */
.ds-wrap, .ds-wrap * { box-sizing: border-box; font-family: 'DM Sans', system-ui, sans-serif; }
.ds-wrap { -webkit-font-smoothing: antialiased; color: var(--ink); }

/* ================================================================
   DASHBOARD SHELL
   ================================================================ */
.ds-wrap {
  max-width: 1040px;
  margin: 0 auto;
  padding: 28px 20px 80px;
}

/* ── TOPBAR ── */
.ds-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 24px;
  padding: 18px 24px;
  background: var(--white);
  border-radius: var(--r-xl);
  border: 1px solid var(--line);
  box-shadow: var(--sh-sm);
  position: relative;
  overflow: hidden;
}
.ds-topbar::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 4px;
  background: var(--grad);
  border-radius: 0 2px 2px 0;
}
.ds-topbar-left { display: flex; align-items: center; gap: 14px; }
.ds-avatar {
  width: 46px; height: 46px;
  border-radius: 14px;
  background: var(--grad);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Syne', sans-serif;
  font-size: 18px; font-weight: 800; color: #fff;
  flex-shrink: 0; overflow: hidden;
}
.ds-avatar img { width: 100%; height: 100%; object-fit: cover; }
.ds-topbar-name {
  font-family: 'Syne', sans-serif;
  font-size: 16px; font-weight: 800; color: var(--ink);
  margin: 0 0 2px;
}
.ds-topbar-sub { font-size: 12px; color: var(--ink-4); margin: 0; }
.ds-topbar-right { display: flex; align-items: center; gap: 10px; }
.ds-premium-pill {
  display: flex; align-items: center; gap: 7px;
  background: linear-gradient(135deg, #1565C0, #0097A7);
  color: #fff;
  padding: 8px 16px;
  border-radius: 100px;
  font-size: 12px; font-weight: 700;
  box-shadow: var(--sh-blue);
}
.ds-upgrade-btn {
  display: flex; align-items: center; gap: 6px;
  background: var(--blue-ll);
  color: var(--blue);
  border: 1px solid var(--blue-l);
  border-radius: 100px;
  padding: 8px 16px;
  font-size: 12px; font-weight: 700;
  text-decoration: none;
  transition: all .15s;
}
.ds-upgrade-btn:hover { background: var(--blue-l); color: var(--blue); }

/* ── STAT ROW ── */
.ds-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 12px;
  margin-bottom: 20px;
}
.ds-stat {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 18px 20px;
  box-shadow: var(--sh-xs);
  position: relative;
  overflow: hidden;
  transition: box-shadow .15s, transform .15s;
}
.ds-stat:hover { box-shadow: var(--sh-sm); transform: translateY(-1px); }
.ds-stat-accent {
  position: absolute; top: 0; left: 0; right: 0;
  height: 3px;
}
.ds-stat-accent.blue   { background: var(--grad); }
.ds-stat-accent.green  { background: linear-gradient(90deg, var(--green), #34D399); }
.ds-stat-accent.amber  { background: linear-gradient(90deg, var(--amber), #FCD34D); }
.ds-stat-accent.purple { background: linear-gradient(90deg, var(--purple), #A78BFA); }
.ds-stat-num {
  font-family: 'Syne', sans-serif;
  font-size: 34px; font-weight: 800;
  color: var(--ink); line-height: 1;
  margin-bottom: 5px;
}
.ds-stat-lbl { font-size: 12px; color: var(--ink-4); font-weight: 500; }

/* ── NAV TABS ── */
.ds-nav {
  display: flex;
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 5px;
  margin-bottom: 24px;
  gap: 4px;
  box-shadow: var(--sh-xs);
}
.ds-nav-tab {
  flex: 1;
  display: flex; align-items: center; justify-content: center; gap: 7px;
  padding: 11px 12px;
  border: none;
  border-radius: 10px;
  background: transparent;
  font-family: 'DM Sans', sans-serif;
  font-size: 13px; font-weight: 700;
  color: var(--ink-4);
  cursor: pointer;
  transition: all .18s;
  white-space: nowrap;
  position: relative;
}
.ds-nav-tab i { font-size: 13px; }
.ds-nav-tab:hover:not(.active) { background: var(--blue-ll); color: var(--blue); }
.ds-nav-tab.active {
  background: var(--grad);
  color: #fff;
  box-shadow: var(--sh-blue);
}
.ds-badge {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 18px; height: 18px;
  border-radius: 100px;
  font-size: 10px; font-weight: 800;
  padding: 0 5px;
  background: rgba(255,255,255,.25);
  color: #fff;
}
.ds-nav-tab:not(.active) .ds-badge {
  background: var(--blue-l);
  color: var(--blue);
}

/* ── PANELS ── */
.ds-panel { display: none; }
.ds-panel.active { display: block; }

/* ── SECTION HEADER ── */
.ds-section-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 16px; gap: 12px; flex-wrap: wrap;
}
.ds-section-title {
  font-family: 'Syne', sans-serif;
  font-size: 15px; font-weight: 800;
  color: var(--ink); margin: 0;
  display: flex; align-items: center; gap: 8px;
}
.ds-section-title i { color: var(--blue); font-size: 14px; }

/* ── CARDS GRID ── */
.ds-pets-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 16px;
}

/* ================================================================
   PET CARD — Next-gen
   ================================================================ */
.vpc {
  background: var(--white);
  border-radius: 20px;
  border: 1px solid var(--line);
  box-shadow: var(--sh-sm);
  overflow: hidden;
  transition: box-shadow .2s, transform .2s;
}
.vpc:hover { box-shadow: var(--sh-md); transform: translateY(-3px); }
.vpc-body {
  display: flex; align-items: center; gap: 14px;
  padding: 18px 18px 14px;
}
.vpc-avatar {
  width: 56px; height: 56px; border-radius: 14px;
  background: var(--grad-soft);
  display: flex; align-items: center; justify-content: center;
  font-size: 28px; flex-shrink: 0; overflow: hidden;
}
.vpc-avatar img { width: 100%; height: 100%; object-fit: cover; }
.vpc-name {
  font-family: 'Syne', sans-serif;
  font-size: 16px; font-weight: 800; color: var(--ink);
  margin-bottom: 4px;
}
.vpc-meta { font-size: 12px; color: var(--ink-4); }
.vpc-meta .vpc-age {
  display: inline-block;
  background: var(--blue-ll); color: var(--blue);
  font-size: 11px; font-weight: 700;
  padding: 2px 8px; border-radius: 100px;
  margin-right: 5px;
}
.vpc-actions {
  display: flex; align-items: center;
  padding: 0 14px 14px; gap: 7px;
}
.vpc-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 7px 11px;
  border-radius: var(--r-sm);
  border: none;
  font-family: 'DM Sans', sans-serif;
  font-size: 11px; font-weight: 700;
  cursor: pointer; transition: all .15s;
  white-space: nowrap; line-height: 1;
}
.vpc-btn i { font-size: 12px; }
.vpc-btn-blue   { background: var(--blue-ll);   color: #1D4ED8; }
.vpc-btn-blue:hover   { background: var(--blue-l); }
.vpc-btn-purple { background: var(--purple-ll);  color: #5B21B6; }
.vpc-btn-purple:hover { background: var(--purple-l); }
.vpc-btn-teal   { background: var(--teal-l);     color: #00838F; }
.vpc-btn-teal:hover   { background: #B2EBF2; }
.vpc-btn-amber  { background: var(--amber-ll);   color: #92400E; }
.vpc-btn-amber:hover  { background: var(--amber-l); }
.vpc-btn-red { background: var(--red-ll); color: #B91C1C; padding: 7px 9px; margin-left: auto; }
.vpc-btn-red:hover { background: var(--red-l); }

/* ================================================================
   ADD PET FORM
   ================================================================ */
.ds-add-form {
  background: var(--white);
  border: 1px solid var(--line);
  border-top: 3px solid var(--blue);
  border-radius: var(--r-xl);
  padding: 24px;
  margin-bottom: 20px;
  box-shadow: var(--sh-sm);
}
.ds-add-form h3 {
  font-family: 'Syne', sans-serif;
  font-size: 15px; font-weight: 800;
  color: var(--ink); margin: 0 0 20px;
  display: flex; align-items: center; gap: 8px;
}
.ds-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.ds-form-grid .full { grid-column: 1 / -1; }
.ds-field { display: flex; flex-direction: column; gap: 5px; }
.ds-label {
  font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.8px;
  color: var(--ink-3);
}
.ds-input, .ds-select, .ds-textarea {
  padding: 11px 14px;
  border: 1.5px solid var(--line);
  border-radius: var(--r-md);
  font-family: 'DM Sans', sans-serif;
  font-size: 14px; color: var(--ink);
  background: var(--bg);
  outline: none;
  transition: border-color .15s, box-shadow .15s, background .15s;
  width: 100%;
}
.ds-input:focus, .ds-select:focus, .ds-textarea:focus {
  background: var(--white);
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(21,101,192,.1);
}
.ds-textarea { resize: vertical; min-height: 80px; }

/* ================================================================
   BUTTONS
   ================================================================ */
.ds-btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 10px 20px;
  border-radius: var(--r-md);
  border: none;
  font-family: 'DM Sans', sans-serif;
  font-size: 13px; font-weight: 700;
  cursor: pointer; transition: all .18s;
  text-decoration: none; line-height: 1;
}
.ds-btn-primary {
  background: var(--grad);
  color: #fff;
  box-shadow: var(--sh-blue);
}
.ds-btn-primary:hover { opacity: .9; transform: translateY(-1px); box-shadow: var(--sh-blue-lg); color: #fff; }
.ds-btn-ghost {
  background: var(--white);
  color: var(--ink-3);
  border: 1.5px solid var(--line);
}
.ds-btn-ghost:hover { border-color: var(--ink-4); color: var(--ink-2); }
.ds-btn-danger {
  background: var(--red-ll);
  color: var(--red);
  border: 1px solid var(--red-l);
}
.ds-btn-danger:hover { background: var(--red-l); color: var(--red); }
.ds-form-actions { display: flex; gap: 10px; margin-top: 18px; }

/* ================================================================
   EMPTY STATE
   ================================================================ */
.ds-empty {
  text-align: center;
  padding: 60px 24px;
  color: var(--ink-4);
}
.ds-empty-icon {
  font-size: 52px; margin-bottom: 14px;
  display: block;
  filter: grayscale(0.3);
}
.ds-empty h3 { font-size: 16px; font-weight: 700; color: var(--ink-3); margin: 0 0 6px; }
.ds-empty p  { font-size: 13px; margin: 0 0 20px; }

/* ================================================================
   MODAL
   ================================================================ */
.ds-modal-overlay {
  position: fixed; inset: 0;
  background: rgba(10,15,30,.72);
  z-index: 99999;
  display: none;
  align-items: center; justify-content: center;
  padding: 20px;
  backdrop-filter: blur(8px);
}
.ds-modal-overlay.is-open,
.vetta-modal-overlay.is-open {
  display: flex;
}
.vetta-modal-overlay { position: fixed; inset: 0; background: rgba(10,15,30,.72); z-index: 99999; display: none; align-items: center; justify-content: center; padding: 20px; backdrop-filter: blur(8px); }
.ds-modal, .vetta-modal {
  background: var(--white);
  border-radius: var(--r-2xl);
  width: 100%; max-width: 680px; max-height: 90vh;
  display: flex; flex-direction: column;
  box-shadow: var(--sh-lg);
  overflow: hidden;
  animation: dsModalIn .22s cubic-bezier(.34,1.2,.64,1);
}
@keyframes dsModalIn {
  from { transform: translateY(18px) scale(.97); opacity: 0; }
  to   { transform: translateY(0) scale(1); opacity: 1; }
}
.ds-modal-head, .vetta-modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 24px;
  border-bottom: 1px solid var(--line-l);
  flex-shrink: 0;
}
.ds-modal-head h3, .vetta-modal-header h3 {
  margin: 0; font-family: 'Syne', sans-serif;
  font-size: 15px; font-weight: 800; color: var(--ink);
}
.ds-modal-x, .vetta-modal-x {
  width: 32px; height: 32px; border-radius: 50%;
  border: none; background: var(--line-l);
  font-size: 15px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: var(--ink-3); transition: background .12s;
}
.ds-modal-x:hover, .vetta-modal-x:hover { background: var(--line); }
.ds-modal-body, .vetta-modal-body {
  overflow-y: auto; padding: 20px 24px; flex: 1;
}

/* ================================================================
   RECORD ITEMS
   ================================================================ */
.ds-record {
  border: 1px solid var(--line-l);
  border-radius: var(--r-md);
  padding: 14px 16px;
  margin-bottom: 10px;
  transition: border-color .15s;
}
.ds-record:hover { border-color: #93C5FD; }
.ds-record-head {
  display: flex; align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
}
.ds-record-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 10px; border-radius: 100px;
  font-size: 11px; font-weight: 700;
}
.ds-record-badge.vaccination { background: var(--green-l);  color: var(--green); }
.ds-record-badge.checkup     { background: var(--blue-l);   color: var(--blue); }
.ds-record-badge.surgery     { background: var(--red-l);    color: var(--red); }
.ds-record-badge.deworming   { background: var(--amber-l);  color: var(--amber); }
.ds-record-badge.other       { background: var(--line-l);   color: var(--ink-3); }
.ds-record-date  { font-size: 11px; color: var(--ink-4); }
.ds-record-title { font-size: 13px; font-weight: 700; margin: 4px 0 2px; }
.ds-record-meta  { font-size: 12px; color: var(--ink-3); }

/* ================================================================
   CLINIC ACCESS PANEL
   ================================================================ */
.ds-access-section { margin-bottom: 24px; }
.ds-access-head {
  display: flex; align-items: center; gap: 8px;
  font-family: 'Syne', sans-serif;
  font-size: 13px; font-weight: 800;
  margin-bottom: 12px; padding-bottom: 10px;
  border-bottom: 2px solid var(--line-l);
}
.ds-access-head.amber { color: var(--amber); border-color: var(--amber-l); }
.ds-access-head.green { color: var(--green); border-color: var(--green-l); }
.ds-access-count {
  background: currentColor;
  width: 18px; height: 18px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
}
.ds-access-count span { color: #fff; font-size: 9px; font-weight: 800; }
.ds-access-card {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 16px;
  border-radius: var(--r-lg);
  border: 1.5px solid;
  margin-bottom: 10px;
  transition: box-shadow .15s;
}
.ds-access-card:hover { box-shadow: var(--sh-sm); }
.ds-access-card.pending { background: var(--amber-ll); border-color: #FCD34D; }
.ds-access-card.active  { background: var(--green-ll); border-color: #86EFAC; }
.ds-access-icon { font-size: 24px; flex-shrink: 0; }
.ds-access-info { flex: 1; min-width: 0; }
.ds-access-info strong { display: block; font-size: 14px; font-weight: 700; color: var(--ink); }
.ds-access-info span   { font-size: 12px; color: var(--ink-3); }

/* ================================================================
   SUBSCRIPTION CARD
   ================================================================ */
.ds-sub-card {
  border-radius: var(--r-xl);
  padding: 28px;
  margin-bottom: 16px;
  position: relative;
  overflow: hidden;
}
.ds-sub-premium {
  background: var(--grad);
  color: #fff;
  box-shadow: var(--sh-blue-lg);
}
.ds-sub-free {
  background: var(--white);
  border: 1px solid var(--line);
  box-shadow: var(--sh-sm);
}
.ds-sub-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 20px 20px;
  pointer-events: none;
}
.ds-sub-badge {
  display: inline-flex; align-items: center; gap: 5px;
  background: rgba(255,255,255,.18);
  border: 1px solid rgba(255,255,255,.25);
  color: #fff; padding: 4px 12px;
  border-radius: 100px; font-size: 11px; font-weight: 700;
  margin-bottom: 12px;
}
.ds-sub-title {
  font-family: 'Syne', sans-serif;
  font-size: 22px; font-weight: 800; margin: 0 0 16px;
  color: #fff;
}
.ds-sub-free .ds-sub-title { color: var(--ink); }
.ds-sub-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 16px;
  position: relative;
}
.ds-sub-item span   { font-size: 9px; text-transform: uppercase; letter-spacing: 1px; opacity: .55; display: block; margin-bottom: 3px; }
.ds-sub-item strong { font-size: 14px; font-weight: 700; }
.ds-sub-premium .ds-sub-item span   { color: rgba(255,255,255,.6); }
.ds-sub-premium .ds-sub-item strong { color: #fff; }
.ds-sub-free    .ds-sub-item strong { color: var(--ink); }
.ds-sub-note {
  font-size: 12px; margin-top: 14px;
  opacity: .6; position: relative;
}
.ds-sub-note a { color: inherit; text-decoration: underline; }

/* ================================================================
   MEMBER CARD
   ================================================================ */
.ds-member-card {
  width: 100%; max-width: 360px; height: 210px;
  border-radius: 22px;
  background: var(--grad);
  position: relative; overflow: hidden;
  box-shadow: var(--sh-blue-lg);
  display: flex; flex-direction: column;
  justify-content: space-between;
  padding: 20px 24px;
  margin-bottom: 20px;
}
.ds-mc-shine {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,.15) 0%, transparent 55%);
}
.ds-mc-dots {
  position: absolute; inset: 0;
  background-image: radial-gradient(rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 18px 18px;
}
.ds-mc-glow {
  position: absolute; right: -30px; bottom: -30px;
  width: 180px; height: 180px; border-radius: 50%;
  background: rgba(255,255,255,.06);
}
.ds-mc-top { display: flex; align-items: center; justify-content: space-between; position: relative; }
.ds-mc-logo { font-family: 'Syne', sans-serif; font-size: 15px; font-weight: 800; color: #fff; letter-spacing: 4px; }
.ds-mc-logo img { height: 22px; filter: brightness(0) invert(1); vertical-align: middle; margin-right: 6px; }
.ds-mc-badge { background: rgba(255,255,255,.18); border: 1px solid rgba(255,255,255,.25); color: #fff; font-size: 10px; font-weight: 700; padding: 3px 10px; border-radius: 100px; }
.ds-mc-mid { position: relative; }
.ds-mc-num { font-family: 'DM Mono', monospace; font-size: 13px; font-weight: 500; color: rgba(255,255,255,.7); letter-spacing: 2px; }
.ds-mc-bot { display: flex; align-items: flex-end; justify-content: space-between; position: relative; }
.ds-mc-lbl { font-size: 8px; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,.4); margin-bottom: 2px; }
.ds-mc-val { font-size: 13px; font-weight: 700; color: rgba(255,255,255,.9); }

/* ================================================================
   PROFILE PANEL
   ================================================================ */
.ds-profile-hero {
  display: flex; align-items: center; gap: 18px;
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: 22px 26px;
  margin-bottom: 20px;
  box-shadow: var(--sh-sm);
  position: relative; overflow: hidden;
}
.ds-profile-hero::before {
  content: '';
  position: absolute; left: 0; top: 0; bottom: 0; width: 4px;
  background: var(--grad);
}
.ds-profile-avatar {
  width: 72px; height: 72px; border-radius: 18px;
  background: var(--grad);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Syne', sans-serif;
  font-size: 28px; font-weight: 800; color: #fff;
  flex-shrink: 0; overflow: hidden; position: relative;
}
.ds-profile-avatar img { width: 100%; height: 100%; object-fit: cover; }
.ds-avatar-btn {
  position: absolute; bottom: 0; right: 0;
  width: 24px; height: 24px; border-radius: 50%;
  background: var(--blue); border: 2px solid #fff;
  color: #fff; font-size: 9px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
}
.ds-profile-name {
  font-family: 'Syne', sans-serif;
  font-size: 18px; font-weight: 800; color: var(--ink); margin: 0 0 3px;
}
.ds-profile-email { font-size: 13px; color: var(--ink-4); margin: 0 0 8px; }
.ds-role-badge {
  display: inline-block;
  background: var(--blue-ll); color: var(--blue);
  font-size: 11px; font-weight: 700;
  padding: 3px 10px; border-radius: 100px;
}
.ds-profile-logout {
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--red-ll); color: var(--red);
  border: 1px solid var(--red-l); border-radius: 10px;
  padding: 9px 16px; font-size: 13px; font-weight: 700;
  text-decoration: none; margin-left: auto; flex-shrink: 0;
  transition: background .12s;
}
.ds-profile-logout:hover { background: var(--red-l); color: var(--red); }

.ds-profile-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 20px; align-items: start;
}
.ds-profile-col { display: flex; flex-direction: column; gap: 16px; }

/* Form card */
.ds-card {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: 24px;
  box-shadow: var(--sh-sm);
}
.ds-card-title {
  font-family: 'Syne', sans-serif;
  font-size: 14px; font-weight: 800; color: var(--ink);
  margin: 0 0 20px;
  display: flex; align-items: center; gap: 8px;
}
.ds-card-title i { color: var(--blue); }
.ds-field-group { display: flex; flex-direction: column; gap: 5px; margin-bottom: 14px; }
.ds-field-label {
  font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.8px; color: var(--ink-3);
}
.ds-field-input, .ds-field-select, .ds-field-textarea {
  padding: 11px 14px;
  border: 1.5px solid var(--line);
  border-radius: 10px;
  font-family: 'DM Sans', sans-serif;
  font-size: 14px; color: var(--ink);
  background: var(--bg);
  outline: none; width: 100%;
  transition: all .15s;
}
.ds-field-input:focus, .ds-field-select:focus, .ds-field-textarea:focus {
  background: var(--white);
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(21,101,192,.1);
}
.ds-field-pw { position: relative; }
.ds-field-pw .ds-field-input { padding-right: 42px; }
.ds-pw-eye {
  position: absolute; right: 12px; top: 50%;
  transform: translateY(-50%);
  background: none; border: none;
  color: var(--ink-5); cursor: pointer; font-size: 14px;
  display: flex; align-items: center;
}
.ds-pw-eye:hover { color: var(--ink-3); }

/* Status badges */
.ds-pill {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 10px; border-radius: 100px;
  font-size: 11px; font-weight: 700;
}
.ds-pill-green  { background: var(--green-l);  color: var(--green); }
.ds-pill-blue   { background: var(--blue-l);   color: var(--blue); }
.ds-pill-amber  { background: var(--amber-l);  color: var(--amber); }
.ds-pill-red    { background: var(--red-l);    color: var(--red); }
.ds-pill-purple { background: var(--purple-l); color: var(--purple); }
.ds-pill-gray   { background: var(--line-l);   color: var(--ink-3); }

/* ================================================================
   NOTIFICATION TOAST
   ================================================================ */
.ds-toast {
  position: fixed; bottom: 24px; right: 24px;
  background: var(--ink-2); color: #fff;
  padding: 14px 18px; border-radius: var(--r-lg);
  font-size: 13px; font-weight: 500;
  z-index: 999999; box-shadow: var(--sh-lg);
  display: flex; align-items: center; gap: 10px;
  max-width: 340px; animation: toastIn .22s ease;
}
.ds-toast.success { background: #052E16; border-left: 3px solid var(--green); }
.ds-toast.error   { background: #450A0A; border-left: 3px solid var(--red); }
@keyframes toastIn {
  from { transform: translateY(12px); opacity: 0; }
  to   { transform: translateY(0); opacity: 1; }
}

/* ================================================================
   LEGACY COMPATIBILITY (old class names → new styles)
   ================================================================ */
.vetta-dashboard { max-width: 1040px; margin: 0 auto; padding: 28px 20px 80px; font-family: 'DM Sans', sans-serif; }
.vetta-dash-header {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  margin-bottom: 24px; padding: 18px 24px;
  background: var(--white); border-radius: var(--r-xl); border: 1px solid var(--line);
  box-shadow: var(--sh-sm); position: relative; overflow: hidden;
}
.vetta-dash-header::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; background: var(--grad); border-radius: 0 2px 2px 0; }
.vetta-dash-welcome { display: flex; align-items: center; gap: 14px; }
.vetta-dash-avatar {
  width: 46px; height: 46px; border-radius: 14px;
  background: var(--grad); display: flex; align-items: center; justify-content: center;
  font-family: 'Syne', sans-serif; font-size: 18px; font-weight: 800; color: #fff;
  flex-shrink: 0; overflow: hidden;
}
.vetta-dash-avatar img { width: 100%; height: 100%; object-fit: cover; }
.vetta-dash-header h2 {
  margin: 0 0 2px; font-family: 'Syne', sans-serif;
  font-size: 16px; font-weight: 800; color: var(--ink);
}
.vetta-dash-header p { margin: 0; font-size: 12px; color: var(--ink-4); }
.vetta-premium-badge, .vetta-dash-upgrade-btn {
  display: flex; align-items: center; gap: 7px;
  background: var(--grad); color: #fff;
  padding: 8px 16px; border-radius: 100px;
  font-size: 12px; font-weight: 700;
  border: none; text-decoration: none; flex-shrink: 0;
  box-shadow: var(--sh-blue);
}
.vetta-dash-upgrade-btn { background: var(--blue-ll); color: var(--blue); box-shadow: none; border: 1px solid var(--blue-l); }

/* TABS LEGACY */
.vetta-dash-tabs {
  display: flex; background: var(--white);
  border: 1px solid var(--line); border-radius: var(--r-lg);
  padding: 5px; margin-bottom: 24px; gap: 4px; box-shadow: var(--sh-xs);
}
.vetta-dash-tab {
  flex: 1; display: flex; align-items: center; justify-content: center; gap: 7px;
  padding: 11px 12px; border: none; border-radius: 10px;
  background: transparent; font-family: 'DM Sans', sans-serif;
  font-size: 13px; font-weight: 700; color: var(--ink-4); cursor: pointer; transition: all .18s;
  white-space: nowrap;
}
.vetta-dash-tab i { font-size: 13px; }
.vetta-dash-tab:hover:not(.active) { background: var(--blue-ll); color: var(--blue); }
.vetta-dash-tab.active { background: var(--grad); color: #fff; box-shadow: var(--sh-blue); }
.vetta-tab-count {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 18px; height: 18px; border-radius: 100px;
  font-size: 10px; font-weight: 800; padding: 0 5px;
  background: rgba(255,255,255,.25); color: #fff;
}
.vetta-dash-tab:not(.active) .vetta-tab-count { background: var(--blue-l); color: var(--blue); }

/* PANELS LEGACY */
.vetta-dash-panel { display: none; }
.vetta-dash-panel.active { display: block; }

/* FORM CARDS LEGACY */
.vetta-form-card {
  background: var(--white); border: 1px solid var(--line);
  border-radius: var(--r-xl); padding: 24px; margin-bottom: 16px; box-shadow: var(--sh-sm);
}
.vetta-form-card h3 {
  margin: 0 0 20px; font-family: 'Syne', sans-serif;
  font-size: 14px; font-weight: 800; color: var(--ink);
  display: flex; align-items: center; gap: 8px;
}
.vetta-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.vetta-form-grid-3 { grid-template-columns: 1fr 1fr 1fr; }
.vetta-field-group { display: flex; flex-direction: column; gap: 5px; }
.vetta-field-group.full { grid-column: 1/-1; }
.vetta-field-label { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.8px; color: var(--ink-3); }
.vetta-field-input, .vetta-field-select {
  padding: 11px 14px; border: 1.5px solid var(--line); border-radius: 10px;
  font-family: 'DM Sans', sans-serif; font-size: 14px; color: var(--ink);
  background: var(--bg); outline: none; width: 100%; transition: all .15s;
}
.vetta-field-input:focus, .vetta-field-select:focus {
  background: var(--white); border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(21,101,192,.1);
}
.vetta-field-textarea { resize: vertical; min-height: 80px; }
.vetta-form-actions { display: flex; gap: 10px; margin-top: 16px; }

/* PASSWORD WRAP LEGACY */
.vetta-field-password-wrap { position: relative; display: block; }
.vetta-field-password-wrap .vetta-field-input { padding-right: 42px; }
.vetta-toggle-pass {
  position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
  background: none; border: none; color: var(--ink-5); cursor: pointer;
  padding: 4px; font-size: 14px; display: flex; align-items: center;
}
.vetta-toggle-pass:hover { color: var(--ink-3); }

/* BUTTONS LEGACY */
.vetta-btn-primary {
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--grad); color: #fff; padding: 10px 20px; border-radius: var(--r-md);
  border: none; font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 700;
  cursor: pointer; transition: all .18s; text-decoration: none; box-shadow: var(--sh-blue); line-height: 1;
}
.vetta-btn-primary:hover { opacity: .9; transform: translateY(-1px); color: #fff; }
.vetta-btn-secondary, .vetta-btn-ghost {
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--white); color: var(--ink-3); padding: 9px 18px; border-radius: var(--r-md);
  border: 1.5px solid var(--line); font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 600;
  cursor: pointer; transition: all .15s; line-height: 1;
}
.vetta-btn-secondary:hover, .vetta-btn-ghost:hover { border-color: var(--blue); color: var(--blue); }
.vetta-btn-sm { display: inline-flex; align-items: center; gap: 5px; padding: 7px 12px; border-radius: var(--r-sm); border: none; font-family: 'DM Sans', sans-serif; font-size: 12px; font-weight: 700; cursor: pointer; transition: all .15s; }
.vetta-btn-primary.vetta-btn-sm { background: var(--grad); color: #fff; }
.vetta-btn-outline.vetta-btn-sm { background: var(--blue-ll); color: var(--blue); border: 1px solid var(--blue-l); }
.vetta-btn-danger, .vetta-btn-sm.vetta-btn-danger { background: var(--red-ll); color: var(--red); border: 1px solid var(--red-l); }

/* EMPTY STATE LEGACY */
.vetta-empty-state { text-align: center; padding: 60px 24px; color: var(--ink-4); }
.vetta-empty-icon  { font-size: 52px; margin-bottom: 14px; display: block; }
.vetta-empty-state h3 { font-size: 16px; font-weight: 700; color: var(--ink-3); margin: 0 0 6px; }
.vetta-empty-state p  { font-size: 13px; margin: 0; }

/* STAT CARDS LEGACY */
.vetta-clinic-stats, .vetta-stat-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px,1fr)); gap: 12px; margin-bottom: 20px; }
.vetta-stat-card {
  background: var(--white); border: 1px solid var(--line); border-radius: var(--r-lg);
  padding: 18px 20px; box-shadow: var(--sh-xs);
}
.vetta-stat-number, .num { font-family: 'Syne', sans-serif; font-size: 34px; font-weight: 800; color: var(--ink); line-height: 1; }
.vetta-stat-label, .lbl  { font-size: 12px; color: var(--ink-4); margin-top: 5px; }

/* PATIENTS LEGACY */
.vetta-patients-list { display: flex; flex-direction: column; gap: 10px; }
.vetta-patient-item, .vetta-patient-row {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 16px; background: var(--white);
  border: 1px solid var(--line-l); border-radius: var(--r-lg);
  transition: all .15s;
}
.vetta-patient-item:hover, .vetta-patient-row:hover { border-color: #93C5FD; box-shadow: var(--sh-xs); }
.vetta-patient-emoji, .vetta-patient-avatar {
  width: 44px; height: 44px; border-radius: var(--r-sm);
  background: var(--blue-ll); display: flex; align-items: center; justify-content: center;
  font-size: 24px; flex-shrink: 0;
}
.vetta-patient-info { flex: 1; min-width: 0; }
.vetta-patient-info strong, .vetta-patient-name { display: block; font-size: 14px; font-weight: 700; color: var(--ink); }
.vetta-patient-info span, .vetta-patient-meta  { display: block; font-size: 12px; color: var(--ink-3); margin-top: 2px; }
.vetta-patient-info small { display: block; font-size: 11px; color: var(--ink-4); margin-top: 1px; }
.vetta-patient-actions { display: flex; gap: 8px; flex-shrink: 0; }

/* NOTICE LEGACY */
.vetta-notice {
  padding: 12px 16px; border-radius: var(--r-md);
  background: var(--blue-ll); color: var(--blue);
  font-size: 13px; font-weight: 500;
  display: flex; align-items: center; gap: 8px; margin-bottom: 16px;
}

/* REQUEST CARD LEGACY */
.vetta-request-card {
  background: var(--amber-ll); border: 1px solid #FCD34D;
  border-radius: var(--r-lg); padding: 14px 16px; margin-bottom: 10px;
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
}

/* GRANT LEGACY */
.vetta-grant-item {
  display: flex; align-items: center; gap: 12px;
  padding: 13px 15px; border-radius: var(--r-lg);
  background: var(--green-ll); border: 1px solid #86EFAC;
  margin-bottom: 10px;
}
.vetta-grant-icon { font-size: 24px; }
.vetta-grant-info { flex: 1; }
.vetta-grant-info strong { display: block; font-size: 14px; font-weight: 700; }
.vetta-grant-info span   { font-size: 12px; color: var(--ink-3); }
.vetta-btn-danger-sm {
  display: inline-flex; align-items: center; gap: 5px;
  background: var(--red-ll); color: var(--red); border: none; border-radius: var(--r-sm);
  padding: 7px 12px; font-family: 'DM Sans', sans-serif; font-size: 12px; font-weight: 700;
  cursor: pointer; transition: background .12s; flex-shrink: 0;
}
.vetta-btn-danger-sm:hover { background: var(--red-l); }

/* SECTION HEADING LEGACY */
.vetta-section-block { margin-bottom: 24px; }
.vetta-section-heading {
  font-family: 'Syne', sans-serif; font-size: 13px; font-weight: 800;
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 12px; padding-bottom: 10px;
  border-bottom: 2px solid var(--line-l);
}
.vetta-heading-amber { color: var(--amber); border-color: var(--amber-l); }
.vetta-heading-green { color: var(--green); border-color: var(--green-l); }
.vetta-heading-count {
  background: currentColor; color: white;
  font-size: 9px; font-weight: 800; width: 18px; height: 18px;
  border-radius: 50%; display: inline-flex; align-items: center; justify-content: center;
}
.vetta-cards-list { display: flex; flex-direction: column; gap: 10px; }
.vetta-access-card {
  display: flex; align-items: center; gap: 14px; padding: 14px 16px;
  border-radius: var(--r-lg); border: 1.5px solid; transition: box-shadow .15s;
}
.vetta-access-card:hover { box-shadow: var(--sh-sm); }
.vetta-access-pending { background: var(--amber-ll); border-color: #FCD34D; }
.vetta-access-active  { background: var(--green-ll);  border-color: #86EFAC; }
.vetta-access-icon { font-size: 24px; flex-shrink: 0; }
.vetta-access-info { flex: 1; min-width: 0; }
.vetta-access-info strong { font-size: 14px; font-weight: 700; color: var(--ink); display: block; }
.vetta-access-info span   { font-size: 12px; color: var(--ink-3); }

/* BADGE LEGACY */
.vetta-badge { display: inline-flex; align-items: center; gap: 3px; padding: 3px 9px; border-radius: 100px; font-size: 11px; font-weight: 700; }
.vetta-badge-active   { background: var(--green-l);  color: var(--green); }
.vetta-badge-inactive { background: var(--line-l);   color: var(--ink-3); }
.vetta-badge-pending  { background: var(--amber-l);  color: var(--amber); }
.vetta-badge-blue     { background: var(--blue-l);   color: var(--blue); }
.vetta-badge-green    { background: var(--green-l);  color: var(--green); }

/* SUBSCRIPTION LEGACY */
.vetta-sub-card { border-radius: var(--r-xl); padding: 28px; margin-bottom: 16px; position: relative; overflow: hidden; }
.vetta-sub-premium { background: var(--grad); color: #fff; box-shadow: var(--sh-blue-lg); }
.vetta-sub-free    { background: var(--white); border: 1px solid var(--line); }
.vetta-sub-card::before { content:''; position:absolute; inset:0; background-image:radial-gradient(rgba(255,255,255,.05) 1px, transparent 1px); background-size:20px 20px; pointer-events:none; }
.vetta-sub-badge { display:inline-flex; align-items:center; gap:5px; background:rgba(255,255,255,.18); border:1px solid rgba(255,255,255,.25); color:#fff; padding:4px 12px; border-radius:100px; font-size:11px; font-weight:700; margin-bottom:12px; }
.vetta-sub-card h3 { font-family:'Syne',sans-serif; font-size:22px; font-weight:800; margin:0 0 16px; }
.vetta-sub-premium h3 { color:#fff; }
.vetta-sub-details { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; position:relative; }
.vetta-sub-details > div { display:flex; flex-direction:column; gap:2px; }
.vetta-sub-details span   { font-size:9px; text-transform:uppercase; letter-spacing:1px; opacity:.55; }
.vetta-sub-details strong { font-size:14px; font-weight:700; }
.vetta-sub-premium .vetta-sub-details span   { color:rgba(255,255,255,.6); }
.vetta-sub-premium .vetta-sub-details strong { color:#fff; }
.vetta-sub-card p { font-size:12px; margin-top:14px; opacity:.7; position:relative; }
.vetta-sub-card p a { color:rgba(255,255,255,.8); text-decoration:underline; }

/* MEMBER CARD LEGACY */
.vetta-member-card { width:100%; max-width:360px; height:210px; border-radius:22px; background:var(--grad); position:relative; overflow:hidden; box-shadow:var(--sh-blue-lg); display:flex; flex-direction:column; justify-content:space-between; padding:20px 24px; margin-bottom:20px; }
.vmc-shine { position:absolute; inset:0; background:linear-gradient(135deg,rgba(255,255,255,.15) 0%,transparent 55%); }
.vmc-pattern { position:absolute; inset:0; background-image:radial-gradient(rgba(255,255,255,.05) 1px,transparent 1px); background-size:18px 18px; }
.vmc-paw-bg { position:absolute; right:-10px; bottom:-12px; font-size:100px; opacity:.06; pointer-events:none; }
.vmc-top { display:flex; align-items:center; justify-content:space-between; position:relative; }
.vmc-logo { display:flex; align-items:center; gap:8px; }
.vmc-logo img { height:22px; filter:brightness(0) invert(1); }
.vmc-logo-text { font-family:'Syne',sans-serif; font-size:14px; font-weight:800; color:#fff; letter-spacing:4px; }
.vmc-badge { background:rgba(255,255,255,.18); border:1px solid rgba(255,255,255,.25); color:#fff; font-size:10px; font-weight:700; padding:3px 10px; border-radius:100px; }
.vmc-middle { flex:1; display:flex; align-items:center; position:relative; }
.vmc-cardnum { font-family:'DM Mono',monospace; font-size:13px; font-weight:500; color:rgba(255,255,255,.7); letter-spacing:2px; }
.vmc-bottom { display:flex; align-items:flex-end; justify-content:space-between; position:relative; }
.vmc-label { font-size:8px; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,.4); margin-bottom:2px; }
.vmc-value { font-size:13px; font-weight:700; color:rgba(255,255,255,.9); font-family:'DM Mono',monospace; }

/* PROFILE LEGACY */
.vetta-profile-wrap { max-width: 860px; }
.vetta-profile-hero { display:flex; align-items:center; gap:18px; background:var(--white); border:1px solid var(--line); border-radius:var(--r-xl); padding:22px 26px; margin-bottom:20px; box-shadow:var(--sh-sm); position:relative; overflow:hidden; }
.vetta-profile-hero::before { content:''; position:absolute; left:0; top:0; bottom:0; width:4px; background:var(--grad); }
.vetta-profile-avatar-wrap { position:relative; flex-shrink:0; width:72px; height:72px; }
.vetta-profile-avatar-big { width:72px; height:72px; border-radius:18px; background:var(--grad); display:flex; align-items:center; justify-content:center; font-family:'Syne',sans-serif; font-size:28px; font-weight:800; color:#fff; overflow:hidden; }
.vetta-profile-avatar-big img { width:100%; height:100%; object-fit:cover; }
.vetta-avatar-change-btn { position:absolute; bottom:0; right:0; width:24px; height:24px; border-radius:50%; background:var(--blue); border:2px solid #fff; color:#fff; font-size:9px; cursor:pointer; display:flex; align-items:center; justify-content:center; }
.vetta-profile-hero-info { flex:1; min-width:0; }
.vetta-profile-hero-info h3 { margin:0 0 3px; font-family:'Syne',sans-serif; font-size:18px; font-weight:800; color:var(--ink); }
.vetta-profile-hero-info p  { margin:0 0 8px; color:var(--ink-4); font-size:13px; }
.vetta-profile-role-badge { display:inline-block; background:var(--blue-ll); color:var(--blue); font-size:11px; font-weight:700; padding:3px 10px; border-radius:100px; }
.vetta-profile-logout-btn { display:inline-flex; align-items:center; gap:7px; background:var(--red-ll); color:var(--red); border:1px solid var(--red-l); border-radius:10px; padding:9px 16px; font-size:13px; font-weight:700; text-decoration:none; flex-shrink:0; margin-left:auto; transition:background .12s; }
.vetta-profile-logout-btn:hover { background:var(--red-l); color:var(--red); }
.vetta-profile-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; align-items:start; }
.vetta-profile-col { display:flex; flex-direction:column; gap:16px; }
.vetta-card-activate { border-top:3px solid var(--blue) !important; }
.vetta-card-activate h3 { color:var(--blue) !important; }

/* FIELD PASSWORD LEGACY */
.vetta-field-password-wrap { position:relative; display:block; }
.vetta-field-password-wrap .vetta-field-input { padding-right:42px; }
.vetta-toggle-pass { position:absolute; right:12px; top:50%; transform:translateY(-50%); background:none; border:none; color:var(--ink-5); cursor:pointer; padding:4px; font-size:14px; display:flex; align-items:center; }
.vetta-toggle-pass:hover { color:var(--ink-3); }

/* ADD PET FORM LEGACY */
.vetta-add-pet-form { margin-bottom: 16px; }
.vetta-panel-actions { display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; gap:12px; flex-wrap:wrap; }

/* ALERTS LEGACY */
.vetta-auth-error, .vetta-auth-success { border-radius:10px; padding:10px 14px; font-size:13px; margin-bottom:14px; display:none; }
.vetta-auth-error   { background:var(--red-ll);   color:var(--red); }
.vetta-auth-success { background:var(--green-ll); color:var(--green); }
.vetta-auth-error.visible, .vetta-auth-success.visible { display:block; }

/* LOADING */
.vetta-loading { text-align:center; padding:40px; color:var(--ink-4); font-size:14px; }

/* RECORD LEGACY */
.vetta-record-item { border:1px solid var(--line-l); border-radius:var(--r-md); padding:14px 16px; margin-bottom:10px; transition:border-color .15s; }
.vetta-record-item:hover { border-color:#93C5FD; }
.vetta-record-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:6px; }
.vetta-record-badge { display:inline-flex; align-items:center; gap:4px; padding:3px 10px; border-radius:100px; font-size:11px; font-weight:700; }
.vetta-record-badge.vaccination { background:var(--green-l); color:var(--green); }
.vetta-record-badge.checkup     { background:var(--blue-l);  color:var(--blue); }
.vetta-record-badge.surgery     { background:var(--red-l);   color:var(--red); }
.vetta-record-badge.deworming   { background:var(--amber-l); color:var(--amber); }
.vetta-record-badge.other       { background:var(--line-l);  color:var(--ink-3); }
.vetta-record-date  { font-size:11px; color:var(--ink-4); }
.vetta-record-title { font-size:13px; font-weight:700; margin:4px 0 2px; }
.vetta-record-meta  { font-size:12px; color:var(--ink-3); }
.vetta-add-record-btn { display:inline-flex; align-items:center; gap:6px; background:var(--green-l); color:var(--green); padding:7px 12px; border-radius:var(--r-sm); border:none; font-family:'DM Sans',sans-serif; font-size:12px; font-weight:700; cursor:pointer; }

/* CLINIC CARD LEGACY */
.vetta-clinic-card { background:var(--white); border:1px solid var(--line); border-radius:var(--r-lg); padding:16px 18px; margin-bottom:10px; display:flex; align-items:center; justify-content:space-between; gap:12px; box-shadow:var(--sh-xs); }
.vetta-clinic-name  { font-size:14px; font-weight:700; margin-bottom:2px; }
.vetta-clinic-meta  { font-size:12px; color:var(--ink-3); }
.vetta-clinic-actions { display:flex; gap:8px; flex-shrink:0; }

/* PET ID CARD LEGACY */
.vetta-pet-id-overlay { position:fixed; inset:0; background:rgba(10,15,30,.78); z-index:99999; display:flex; align-items:center; justify-content:center; padding:20px; backdrop-filter:blur(8px); }
.vetta-pet-id-modal { background:var(--white); border-radius:var(--r-2xl); padding:24px; max-width:340px; width:100%; position:relative; box-shadow:var(--sh-lg); animation:dsModalIn .25s cubic-bezier(.34,1.2,.64,1); }
.vetta-pet-id-close { position:absolute; top:14px; right:14px; background:var(--bg); border:none; width:28px; height:28px; border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center; color:var(--ink-3); font-size:12px; }
.vetta-pet-id-card { background:var(--grad); border-radius:var(--r-lg); padding:20px; position:relative; overflow:hidden; margin-bottom:14px; }
.vetta-pet-id-card::before { content:''; position:absolute; inset:0; background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px); background-size:16px 16px; }
.vpid-header,.vpid-main,.vpid-footer { position:relative; }
.vpid-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.vpid-logo { font-size:11px; font-weight:800; color:rgba(255,255,255,.9); letter-spacing:2px; }
.vpid-type { font-size:9px; color:rgba(255,255,255,.5); letter-spacing:2px; text-transform:uppercase; }
.vpid-main { display:flex; align-items:center; gap:14px; margin-bottom:14px; }
.vpid-avatar { width:52px; height:52px; border-radius:50%; background:rgba(255,255,255,.2); border:2px solid rgba(255,255,255,.35); display:flex; align-items:center; justify-content:center; font-size:26px; flex-shrink:0; overflow:hidden; }
.vpid-avatar img { width:100%; height:100%; object-fit:cover; border-radius:50%; }
.vpid-name { font-size:20px; font-weight:800; color:#fff; }
.vpid-breed { font-size:12px; color:rgba(255,255,255,.6); margin-top:2px; }
.vpid-footer { display:flex; align-items:flex-end; justify-content:space-between; }
.vpid-owner-label { font-size:8px; letter-spacing:2px; color:rgba(255,255,255,.4); text-transform:uppercase; }
.vpid-owner-name  { font-size:13px; font-weight:600; color:rgba(255,255,255,.88); }
.vpid-owner-phone { font-size:11px; color:rgba(255,255,255,.5); margin-top:1px; }
.vpid-qr { background:#fff; border-radius:8px; padding:6px; flex-shrink:0; }
.vpid-actions { display:flex; gap:8px; }
.vpid-btn { flex:1; padding:10px; border:none; border-radius:var(--r-md); font-family:'DM Sans',sans-serif; font-size:13px; font-weight:600; cursor:pointer; display:flex; align-items:center; justify-content:center; gap:6px; }
.vpid-btn-share { background:var(--teal-l); color:var(--teal); }

/* UPCOMING */
.vetta-upcoming-item { display:flex; align-items:flex-start; gap:14px; padding:14px 0; border-bottom:1px solid var(--line-l); }
.vetta-upcoming-item:last-child { border-bottom:none; }
.vetta-upcoming-date-box { flex-shrink:0; width:50px; height:50px; background:var(--blue-l); border-radius:var(--r-md); display:flex; flex-direction:column; align-items:center; justify-content:center; }
.vetta-upcoming-date-box .day { font-family:'Syne',sans-serif; font-size:20px; font-weight:800; color:var(--blue); line-height:1; }
.vetta-upcoming-date-box .mon { font-size:9px; font-weight:700; color:var(--blue); text-transform:uppercase; }
.vetta-upcoming-info h4 { margin:2px 0 4px; font-size:14px; font-weight:700; }
.vetta-upcoming-info p  { margin:0; font-size:12px; color:var(--ink-3); }

/* FILE INPUT HIDDEN */
input[type="file"]#vetta-photo-input,
input[type="file"]#pet-photo { display: none !important; }

/* LIMIT NOTICE */
.vetta-limit-notice { display:inline-flex; align-items:center; gap:8px; background:var(--amber-ll); border:1px solid #FCD34D; color:var(--amber); border-radius:var(--r-md); padding:10px 16px; font-size:13px; font-weight:500; }
.vetta-limit-notice a { color:var(--amber); font-weight:700; }

/* NOTIFY TOAST */
.vetta-notify { position:fixed; bottom:24px; right:24px; background:var(--ink-2); color:#fff; padding:13px 18px; border-radius:var(--r-lg); font-size:13px; font-weight:500; z-index:99999; box-shadow:var(--sh-md); animation:dsModalIn .22s ease; max-width:320px; }
.vetta-notify.success { background:#052E16; border-left:3px solid var(--green); }
.vetta-notify.error   { background:#450A0A; border-left:3px solid var(--red); }

/* PHOTO UPLOAD */
.vetta-photo-upload-area { border:2px dashed var(--line); border-radius:var(--r-md); padding:20px; text-align:center; cursor:pointer; transition:all .15s; position:relative; }
.vetta-photo-upload-area:hover { border-color:var(--blue); background:var(--blue-ll); }
.vetta-photo-upload-area input { position:absolute; inset:0; opacity:0; cursor:pointer; width:100%; }

/* ================================================================
   AUTH (VX) — already defined but keep here as fallback
   ================================================================ */
/* (VX auth styles are appended separately below) */

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width: 768px) {
  .vetta-dashboard, .ds-wrap { padding: 14px 14px 60px; }
  .vetta-dash-header, .ds-topbar { padding: 14px 16px; border-radius: var(--r-lg); }
  .vetta-dash-tabs, .ds-nav { gap: 2px; padding: 4px; }
  .vetta-dash-tab, .ds-nav-tab { padding: 9px 6px; font-size: 11px; }
  .vetta-dash-tab i, .ds-nav-tab i { display: none; }
  .vetta-tab-count, .ds-badge { display: none; }
  .vetta-form-grid, .ds-form-grid { grid-template-columns: 1fr; }
  .vetta-sub-details, .ds-sub-grid { grid-template-columns: 1fr 1fr; }
  .vetta-profile-grid, .ds-profile-grid { grid-template-columns: 1fr; }
  .vetta-profile-hero, .ds-profile-hero { flex-wrap: wrap; }
  .vetta-profile-logout-btn, .ds-profile-logout { width: 100%; justify-content: center; margin-left: 0; margin-top: 10px; }
  .ds-pets-grid, .vetta-pets-grid { grid-template-columns: 1fr; }
  .ds-stats, .vetta-stat-cards, .vetta-clinic-stats { grid-template-columns: 1fr 1fr; }
  .vetta-form-grid-3 { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .ds-topbar-right .ds-premium-pill span:not(:first-child) { display: none; }
}

/* ================================================================
   VX AUTH — Luxury Split-Screen (preserved)
   ================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,700;0,900;1,700&display=swap');

.vx-auth { display:flex!important; min-height:100vh!important; margin:0 -9999px!important; padding:0 9999px!important; font-family:'DM Sans',sans-serif!important; position:relative!important; overflow:hidden!important; background:#050C1A!important; }
.vx-left { flex:0 0 48%!important; background:#060D1B!important; position:relative!important; overflow:hidden!important; padding:48px 56px!important; display:flex!important; align-items:center!important; }
.vx-mesh { position:absolute!important; inset:0!important; background:radial-gradient(ellipse 80% 60% at 20% 30%,rgba(21,101,192,.35) 0%,transparent 60%),radial-gradient(ellipse 60% 50% at 80% 70%,rgba(0,151,167,.25) 0%,transparent 55%),radial-gradient(ellipse 40% 40% at 50% 100%,rgba(21,101,192,.15) 0%,transparent 50%)!important; animation:meshPulse 8s ease-in-out infinite alternate!important; }
@keyframes meshPulse { 0%{opacity:.7;transform:scale(1)} 100%{opacity:1;transform:scale(1.04)} }
.vx-orb { position:absolute!important; border-radius:50%!important; filter:blur(60px)!important; pointer-events:none!important; animation:orbFloat 12s ease-in-out infinite!important; }
.vx-orb-1 { width:320px!important; height:320px!important; background:rgba(21,101,192,.4)!important; top:-80px!important; left:-80px!important; }
.vx-orb-2 { width:200px!important; height:200px!important; background:rgba(0,151,167,.35)!important; bottom:80px!important; right:-40px!important; animation-delay:4s!important; }
.vx-orb-3 { width:140px!important; height:140px!important; background:rgba(99,179,237,.2)!important; top:50%!important; left:40%!important; animation-delay:2s!important; }
@keyframes orbFloat { 0%,100%{transform:translateY(0) scale(1)} 50%{transform:translateY(-30px) scale(1.08)} }
.vx-left::before { content:''!important; position:absolute!important; inset:0!important; background-image:radial-gradient(rgba(255,255,255,.04) 1px,transparent 1px)!important; background-size:28px 28px!important; pointer-events:none!important; }
.vx-left-content { position:relative!important; z-index:2!important; width:100%!important; }
.vx-logo { display:flex!important; align-items:center!important; gap:10px!important; margin-bottom:52px!important; }
.vx-logo img { height:36px!important; filter:brightness(0) invert(1)!important; object-fit:contain!important; }
.vx-logo span { font-family:'Syne',sans-serif!important; font-size:20px!important; font-weight:800!important; color:#fff!important; letter-spacing:4px!important; }
.vx-headline { font-family:'Playfair Display',Georgia,serif!important; font-size:clamp(28px,3vw,42px)!important; font-weight:900!important; color:#fff!important; line-height:1.15!important; margin:0 0 18px!important; }
.vx-headline em { font-style:italic!important; background:linear-gradient(90deg,#63B3ED,#0097A7)!important; -webkit-background-clip:text!important; -webkit-text-fill-color:transparent!important; background-clip:text!important; }
.vx-sub { color:rgba(255,255,255,.52)!important; font-size:14px!important; line-height:1.7!important; margin:0 0 36px!important; max-width:360px!important; }
.vx-features { display:flex!important; flex-direction:column!important; gap:16px!important; margin-bottom:40px!important; }
.vx-feat { display:flex!important; align-items:center!important; gap:14px!important; }
.vx-feat-icon { width:38px!important; height:38px!important; border-radius:10px!important; background:rgba(255,255,255,.08)!important; border:1px solid rgba(255,255,255,.1)!important; display:flex!important; align-items:center!important; justify-content:center!important; color:#63B3ED!important; font-size:14px!important; flex-shrink:0!important; }
.vx-feat div strong { display:block!important; color:rgba(255,255,255,.88)!important; font-size:13px!important; font-weight:700!important; }
.vx-feat div span { color:rgba(255,255,255,.38)!important; font-size:12px!important; }
.vx-float-card { background:linear-gradient(135deg,#1565C0 0%,#0097A7 100%)!important; border-radius:18px!important; padding:18px 22px!important; position:relative!important; overflow:hidden!important; max-width:300px!important; box-shadow:0 20px 60px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.08)!important; animation:cardTilt 6s ease-in-out infinite!important; }
@keyframes cardTilt { 0%,100%{transform:perspective(800px) rotateY(-4deg) rotateX(2deg) translateY(0)} 50%{transform:perspective(800px) rotateY(4deg) rotateX(-2deg) translateY(-8px)} }
.vx-fc-shine { position:absolute!important; inset:0!important; background:linear-gradient(135deg,rgba(255,255,255,.18) 0%,transparent 55%)!important; pointer-events:none!important; }
.vx-float-card::after { content:''!important; position:absolute!important; inset:0!important; background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px)!important; background-size:14px 14px!important; pointer-events:none!important; }
.vx-fc-top { display:flex!important; align-items:center!important; justify-content:space-between!important; margin-bottom:14px!important; position:relative!important; z-index:1!important; }
.vx-fc-logo { font-family:'Syne',sans-serif!important; font-size:14px!important; font-weight:800!important; color:#fff!important; letter-spacing:3px!important; }
.vx-fc-badge { background:rgba(255,255,255,.18)!important; border:1px solid rgba(255,255,255,.25)!important; color:#fff!important; font-size:10px!important; font-weight:700!important; padding:3px 10px!important; border-radius:100px!important; }
.vx-fc-pet { font-size:44px!important; display:block!important; margin-bottom:10px!important; position:relative!important; z-index:1!important; }
.vx-fc-bottom { display:flex!important; justify-content:space-between!important; position:relative!important; z-index:1!important; }
.vx-fc-lbl { font-size:8px!important; letter-spacing:2px!important; text-transform:uppercase!important; color:rgba(255,255,255,.4)!important; margin-bottom:2px!important; }
.vx-fc-val { font-size:12px!important; font-weight:700!important; color:rgba(255,255,255,.88)!important; font-family:'DM Mono',monospace!important; }
.vx-right { flex:1!important; background:#fff!important; display:flex!important; align-items:center!important; justify-content:center!important; padding:48px 40px!important; position:relative!important; }
.vx-form-wrap { width:100%!important; max-width:420px!important; position:relative!important; z-index:1!important; }
.vx-tabs { display:flex!important; background:#F3F4F6!important; border-radius:12px!important; padding:4px!important; margin-bottom:32px!important; gap:3px!important; }
.vx-tab { flex:1!important; padding:11px 16px!important; border:none!important; border-radius:9px!important; background:transparent!important; font-family:'DM Sans',sans-serif!important; font-size:14px!important; font-weight:700!important; color:#6B7280!important; cursor:pointer!important; transition:all .18s!important; }
.vx-tab.active { background:#fff!important; color:#0D1B2A!important; box-shadow:0 1px 4px rgba(0,0,0,.1)!important; }
.vx-panel { display:none; }
.vx-panel.vx-active { display:block; }
.vx-field { margin-bottom:18px!important; }
.vx-label { display:block!important; font-size:11px!important; font-weight:700!important; text-transform:uppercase!important; letter-spacing:0.8px!important; color:#374151!important; margin-bottom:7px!important; }
.vx-optional { font-weight:400!important; color:#9CA3AF!important; text-transform:none!important; letter-spacing:0!important; }
.vx-input { width:100%!important; padding:13px 16px!important; background:#F9FAFB!important; border:1.5px solid #E5E7EB!important; border-radius:10px!important; font-family:'DM Sans',sans-serif!important; font-size:14px!important; color:#0D1B2A!important; outline:none!important; transition:all .15s!important; box-sizing:border-box!important; }
.vx-input:focus { background:#fff!important; border-color:#1565C0!important; box-shadow:0 0 0 3px rgba(21,101,192,.12)!important; }
.vx-input::placeholder { color:#C4C9D4!important; }
.vx-textarea { resize:vertical!important; min-height:90px!important; }
.vx-pass-wrap { position:relative!important; display:block!important; }
.vx-pass-wrap .vx-input { padding-right:44px!important; }
.vx-eye { position:absolute!important; right:13px!important; top:50%!important; transform:translateY(-50%)!important; background:none!important; border:none!important; color:#C4C9D4!important; cursor:pointer!important; padding:4px!important; font-size:14px!important; display:flex!important; align-items:center!important; }
.vx-eye:hover { color:#6B7280!important; }
.vx-strength { display:flex!important; align-items:center!important; gap:10px!important; margin-top:7px!important; }
.vx-strength-bar { flex:1!important; height:4px!important; background:#E5E7EB!important; border-radius:100px!important; overflow:hidden!important; }
.vx-strength-fill { height:100%!important; border-radius:100px!important; transition:width .3s,background .3s!important; width:0!important; }
.vx-strength-label { font-size:11px!important; font-weight:600!important; color:#9CA3AF!important; white-space:nowrap!important; }
.vx-check { margin-bottom:22px!important; }
.vx-check-label { display:flex!important; align-items:center!important; gap:10px!important; cursor:pointer!important; font-size:13px!important; color:#374151!important; }
.vx-check-label input[type=checkbox] { accent-color:#1565C0!important; width:16px!important; height:16px!important; }
.vx-check-label a { color:#1565C0!important; font-weight:600!important; }
.vx-checkmark { display:none!important; }
.vx-submit { display:flex!important; align-items:center!important; justify-content:center!important; gap:9px!important; width:100%!important; padding:15px 24px!important; background:linear-gradient(120deg,#1565C0 0%,#0097A7 100%)!important; color:#fff!important; border:none!important; border-radius:12px!important; font-family:'DM Sans',sans-serif!important; font-size:15px!important; font-weight:700!important; cursor:pointer!important; transition:all .2s!important; box-shadow:0 4px 20px rgba(21,101,192,.35)!important; position:relative!important; overflow:hidden!important; }
.vx-submit::after { content:''!important; position:absolute!important; inset:0!important; background:linear-gradient(120deg,rgba(255,255,255,.15) 0%,transparent 50%)!important; pointer-events:none!important; }
.vx-submit:hover { transform:translateY(-2px)!important; box-shadow:0 8px 30px rgba(21,101,192,.45)!important; color:#fff!important; }
.vx-submit:disabled { opacity:.65!important; transform:none!important; cursor:not-allowed!important; }
.vx-submit-outline { background:transparent!important; color:#1565C0!important; border:2px solid #1565C0!important; box-shadow:none!important; }
.vx-submit-outline:hover { background:#EFF6FF!important; box-shadow:none!important; }
.vx-alert { padding:12px 16px!important; border-radius:10px!important; font-size:13px!important; font-weight:500!important; margin-bottom:18px!important; display:none!important; }
.vx-alert.error   { background:#FEF2F2!important; color:#DC2626!important; border-left:3px solid #DC2626!important; display:block!important; }
.vx-alert.success { background:#F0FDF4!important; color:#16A34A!important; border-left:3px solid #16A34A!important; display:block!important; }
.vx-divider { display:flex!important; align-items:center!important; gap:12px!important; margin:22px 0!important; color:#D1D5DB!important; font-size:12px!important; font-weight:600!important; letter-spacing:.5px!important; text-transform:uppercase!important; }
.vx-divider::before,.vx-divider::after { content:''!important; flex:1!important; height:1px!important; background:#E5E7EB!important; }
.vx-cta { display:flex!important; align-items:center!important; gap:14px!important; background:#F8FAFF!important; border:1px solid #DBEAFE!important; border-radius:12px!important; padding:14px 16px!important; }
.vx-cta-icon { font-size:26px!important; flex-shrink:0!important; }
.vx-cta-text { flex:1!important; min-width:0!important; }
.vx-cta-text strong { display:block!important; font-size:13px!important; font-weight:700!important; color:#0D1B2A!important; }
.vx-cta-text span   { font-size:12px!important; color:#6B7280!important; }
.vx-cta-btn { background:#EFF6FF!important; color:#1565C0!important; border:1px solid #BFDBFE!important; border-radius:8px!important; padding:8px 14px!important; font-family:'DM Sans',sans-serif!important; font-size:12px!important; font-weight:700!important; cursor:pointer!important; white-space:nowrap!important; flex-shrink:0!important; }
.vx-cta-btn:hover { background:#DBEAFE!important; }
.vx-forgot { float:right!important; font-size:12px!important; color:#1565C0!important; font-weight:600!important; text-decoration:none!important; }
.vx-forgot:hover { text-decoration:underline!important; }
.vetta-field-error { font-size:11px!important; color:#DC2626!important; margin-top:4px!important; display:none!important; }
.vetta-field-error.visible { display:block!important; }
@media (max-width:900px) { .vx-auth{flex-direction:column!important;min-height:auto!important;margin:0!important;padding:0!important} .vx-left{flex:0 0 auto!important;padding:36px 28px 28px!important} .vx-float-card{display:none!important} .vx-right{padding:36px 24px!important} }
@media (max-width:500px) { .vx-left{padding:28px 20px 20px!important} .vx-features{display:none!important} }

/* ═══════════════════════════════════════════════
   VET DASHBOARD — Next-gen patient cards
   ═══════════════════════════════════════════════ */

/* Stat pill in header */
.vet-stat-pills {
  display: flex;
  gap: 10px;
  flex-shrink: 0;
}
.vet-stat-pill {
  background: linear-gradient(135deg, #EFF6FF, #E0F7FA);
  border: 1px solid #BFDBFE;
  border-radius: 14px;
  padding: 10px 20px;
  text-align: center;
  min-width: 80px;
}
.vet-stat-num {
  display: block;
  font-family: 'Syne', sans-serif;
  font-size: 26px;
  font-weight: 800;
  color: #1565C0;
  line-height: 1;
}
.vet-stat-lbl {
  display: block;
  font-size: 11px;
  color: #6B7280;
  font-weight: 600;
  margin-top: 3px;
}

/* Search bar */
.vet-search-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  background: #fff;
  border: 1.5px solid #E5E7EB;
  border-radius: 14px;
  padding: 12px 18px;
  margin-bottom: 18px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.05);
  transition: border-color .15s, box-shadow .15s;
}
.vet-search-bar:focus-within {
  border-color: #1565C0;
  box-shadow: 0 0 0 3px rgba(21,101,192,.1);
}
.vet-search-icon { font-size: 18px; flex-shrink: 0; }
.vet-search-input {
  flex: 1;
  border: none;
  outline: none;
  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
  color: #0D1B2A;
  background: transparent;
}
.vet-search-input::placeholder { color: #C4C9D4; }

/* Patient cards grid */
.vet-patients-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 14px;
}

.vet-patient-card {
  background: #fff;
  border: 1px solid #E5E7EB;
  border-radius: 18px;
  padding: 18px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.06), 0 4px 12px rgba(0,0,0,0.04);
  transition: box-shadow .2s, transform .2s, border-color .15s;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.vet-patient-card:hover {
  box-shadow: 0 4px 20px rgba(21,101,192,.12), 0 1px 4px rgba(0,0,0,.06);
  border-color: #93C5FD;
  transform: translateY(-2px);
}
.vet-patient-card.hidden { display: none; }

.vpc-vet-avatar {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 30px;
  flex-shrink: 0;
}

.vpc-vet-info { flex: 1; }
.vpc-vet-name {
  font-family: 'Syne', sans-serif;
  font-size: 16px;
  font-weight: 800;
  color: #0D1B2A;
  margin-bottom: 4px;
}
.vpc-vet-meta {
  font-size: 12px;
  color: #6B7280;
  margin-bottom: 6px;
}
.vpc-vet-owner {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: #F1F5F9;
  color: #475569;
  font-size: 11px;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 100px;
}

/* Row layout: avatar left, info + actions right */
.vet-patient-card {
  flex-direction: row;
  align-items: center;
}
.vpc-vet-body {
  display: flex;
  align-items: center;
  gap: 14px;
  flex: 1;
  min-width: 0;
}
.vpc-vet-actions {
  display: flex;
  flex-direction: column;
  gap: 7px;
  flex-shrink: 0;
}
.vpc-vet-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  padding: 8px 14px;
  border-radius: 10px;
  border: none;
  font-family: 'DM Sans', sans-serif;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: all .15s;
  white-space: nowrap;
}
.vpc-vet-btn-primary {
  background: linear-gradient(135deg, #1565C0, #0097A7);
  color: #fff;
  box-shadow: 0 2px 8px rgba(21,101,192,.3);
}
.vpc-vet-btn-primary:hover {
  box-shadow: 0 4px 16px rgba(21,101,192,.4);
  transform: translateY(-1px);
}
.vpc-vet-btn-ghost {
  background: #F1F5F9;
  color: #475569;
  border: 1px solid #E2E8F0;
}
.vpc-vet-btn-ghost:hover {
  background: #E2E8F0;
  color: #1E293B;
}

/* ── AUTH FORM POLISH ── */
/* Better tab active state */
.vx-tab.active {
  background: #fff !important;
  color: #0D1B2A !important;
  box-shadow: 0 2px 8px rgba(0,0,0,.12), 0 0 0 1px rgba(0,0,0,.06) !important;
  font-weight: 800 !important;
}

/* Input focus glow more pronounced */
.vx-input:focus {
  background: #fff !important;
  border-color: #1565C0 !important;
  box-shadow: 0 0 0 4px rgba(21,101,192,.1) !important;
}

/* Submit button shimmer animation */
@keyframes shimmer {
  0%   { transform: translateX(-100%) skewX(-15deg); }
  100% { transform: translateX(200%) skewX(-15deg); }
}
.vx-submit::before {
  content: '';
  position: absolute;
  top: 0; left: 0; bottom: 0;
  width: 60px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.25), transparent);
  animation: shimmer 2.5s infinite;
  pointer-events: none;
}

/* Larger, more luxurious headline */
.vx-headline {
  font-size: clamp(32px, 3.5vw, 48px) !important;
  letter-spacing: -0.5px !important;
}

/* Float card more visible */
.vx-float-card {
  margin-top: 12px !important;
  box-shadow: 0 24px 70px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.1) !important;
}

/* Responsive vet grid */
@media (max-width: 640px) {
  .vet-patients-grid { grid-template-columns: 1fr; }
  .vpc-vet-actions { flex-direction: row; }
  .vet-patient-card { flex-wrap: wrap; }
}
