/**
 * theme.css  ·  Pawfile Design System
 * ─────────────────────────────────────────────────────────────────────────────
 * Single source of truth for every design token, surface, and component style.
 * Replaces the duplicated <style> blocks in index.html and customer-portal.html.
 *
 * Import order (in each HTML file):
 *   1. <link rel="stylesheet" href="/src/theme.css">   ← this file
 *   2. Tenant theme override injected at runtime via hydrateApp()
 *   3. Page-specific overrides (minimal, avoid if possible)
 *
 * Usage with tenant overrides:
 *   The hydrateApp() function injects a <style id="tenant-theme"> tag that
 *   sets :root { --amber: ...; --bark: ...; } — those overrides cascade over
 *   the defaults defined here.
 * ─────────────────────────────────────────────────────────────────────────────
 */

/* ══════════════════════════════════════════════════════════════════════════════
   1. Design Tokens — Light Mode (default)
   ══════════════════════════════════════════════════════════════════════════════ */

:root {
  /* ── Brand palette ── */
  --cream:        #f5f0e8;
  --warm-white:   #faf8f4;
  --bark:         #3d2b1f;
  --bark-light:   #5c4033;
  --amber:        #c8832a;
  --amber-light:  #e8a84a;
  --sage:         #7a9e7e;
  --sage-light:   #a8c5ab;
  --rust:         #b85c38;
  --sand:         #d4b896;
  --sand-light:   #ede0cc;
  --sky:          #4a90b8;
  --sky-light:    #a8d0e6;
  --lavender:     #8b7bc8;

  /* ── Semantic shadows ── */
  --shadow:       rgba(61, 43, 31, 0.12);
  --shadow-deep:  rgba(61, 43, 31, 0.22);

  /* ── Layout ── */
  --sidebar-w: 220px;

  /* ── Radius scale ── */
  --r-sm:   6px;
  --r-md:   10px;
  --r-lg:   14px;
  --r-xl:   18px;
  --r-pill: 999px;

  /* ── Surfaces (light) ── */
  --bg-page:          var(--cream);
  --bg-card:          var(--warm-white);
  --bg-card-solid:    #fff;
  --border-color:     var(--sand-light);
  --text-primary:     var(--bark);
  --text-secondary:   var(--bark-light);
  --text-muted:       #888;
  --input-bg:         #fff;
  --table-header-bg:  var(--bark);
  --table-row-hover:  var(--warm-white);
  --thead-text:       #f5f0e8;

  /* ── Pet Species Families (Light) ── */
  --dog-bg:       rgba(122, 158, 126, 0.18);
  --dog-text:     #2d6b35;
  --cat-bg:       rgba(139, 123, 200, 0.2);
  --cat-text:     #5a478a;
}

/* ══════════════════════════════════════════════════════════════════════════════
   2. Design Tokens — Dark Mode
   ══════════════════════════════════════════════════════════════════════════════ */

[data-theme="dark"] {
  --cream:       #1a1310;
  --warm-white:  #221c17;
  --bark:        #e8ddd0;
  --bark-light:  #c4b09a;
  --sand:        #5a4535;
  --sand-light:  #2e2219;

  --shadow:      rgba(0, 0, 0, 0.3);
  --shadow-deep: rgba(0, 0, 0, 0.5);

  --bg-page:         #141110;
  --bg-card:         #1e1812;
  --bg-card-solid:   #231d16;
  --border-color:    #352a20;
  --text-primary:    #e8ddd0;
  --text-secondary:  #c4b09a;
  --text-muted:      #8a7a6a;
  --input-bg:        #1e1812;
  --table-header-bg: #2a1e15;
  --table-row-hover: #2a2018;
  --amber-light:     #d4923c;
  --sage-light:      #5a7a5e;
  --sky-light:       #2a5a78;
  --thead-text:      #e8ddd0;

  /* ── Pet Species Families (Dark) ── */
  --dog-bg:       rgba(122, 158, 126, 0.22);
  --dog-text:     #a8c5ab;
  --cat-bg:       rgba(139, 123, 200, 0.25);
  --cat-text:     #b8aee8;

  /* Extra semantic helpers */
  --muted-label: #8a7a6a;
  --subtle:      #6a5a4a;
  --on-dark-card:#d0c4b4;
}

/* ══════════════════════════════════════════════════════════════════════════════
   3. Base Reset
   ══════════════════════════════════════════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; }

body {
  margin:      0;
  font-family: 'Montserrat', sans-serif;
  background:  var(--bg-page);
  color:       var(--text-primary);
  -webkit-font-smoothing: antialiased;
}

/* ══════════════════════════════════════════════════════════════════════════════
   4. Dark Mode — Global Overrides
   ══════════════════════════════════════════════════════════════════════════════ */

[data-theme="dark"] body          { color: var(--text-primary); }
[data-theme="dark"] td            { color: var(--text-primary); }
[data-theme="dark"] .notes-box    { color: var(--text-primary); }
[data-theme="dark"] .dog-detail-card { color: var(--text-primary); }
[data-theme="dark"] .detail-item .val { color: var(--text-primary); }

/* Inline grey text overrides */
[data-theme="dark"] [style*="color:#aaa"],
[data-theme="dark"] [style*="color: #aaa"] { color: var(--text-muted)     !important; }
[data-theme="dark"] [style*="color:#888"],
[data-theme="dark"] [style*="color: #888"] { color: var(--text-muted)     !important; }
[data-theme="dark"] [style*="color:#bbb"],
[data-theme="dark"] [style*="color: #bbb"] { color: var(--subtle)         !important; }
[data-theme="dark"] [style*="color:#ccc"],
[data-theme="dark"] [style*="color: #ccc"] { color: var(--subtle)         !important; }
[data-theme="dark"] [style*="color:#555"],
[data-theme="dark"] [style*="color: #555"] { color: var(--text-secondary) !important; }
[data-theme="dark"] [style*="color:#666"],
[data-theme="dark"] [style*="color: #666"] { color: var(--text-secondary) !important; }
[data-theme="dark"] [style*="color:#777"],
[data-theme="dark"] [style*="color: #777"] { color: var(--text-muted)     !important; }

/* White backgrounds → dark card */
[data-theme="dark"] [style*="background:white"],
[data-theme="dark"] [style*="background: white"],
[data-theme="dark"] [style*="background:#fff"],
[data-theme="dark"] [style*="background: #fff"] { background: var(--bg-card-solid) !important; }

/* ══════════════════════════════════════════════════════════════════════════════
   5. Form Elements
   ══════════════════════════════════════════════════════════════════════════════ */

input[type=text],
input[type=email],
input[type=tel],
input[type=date],
input[type=time],
input[type=number],
select,
textarea {
  background:   var(--input-bg);
  color:        var(--text-primary);
  border:       1.5px solid var(--border-color);
  border-radius: var(--r-md);
  font-family:  inherit;
  font-size:    14px;
  padding:      8px 10px;
  outline:      none;
  transition:   border-color 0.15s;
}

input:focus, select:focus, textarea:focus {
  border-color: var(--amber);
}

[data-theme="dark"] select option {
  background: var(--bg-card-solid);
  color:      var(--text-primary);
}

/* ══════════════════════════════════════════════════════════════════════════════
   6. Accommodation & Pet Chips
   ══════════════════════════════════════════════════════════════════════════════ */

.pet-chip {
  display:       inline-flex;
  align-items:   center;
  gap:           4px;
  padding:       3px 9px;
  border-radius: var(--r-pill);
  font-size:     11px;
  font-weight:   600;
  background:    rgba(80, 120, 85, 0.18);
  color:         var(--bark);
}

.pet-chip.cat              { background: rgba(139,123,200,0.15); color: var(--lavender); }

/* Accommodation type chips */
.accom-dog-family { background: var(--dog-bg); color: var(--dog-text); }
.accom-cat-family { background: var(--cat-bg); color: var(--cat-text); }

/* Keep legacy classes for backward compatibility but link them to the new system */
.accom-standard, .accom-indoor, .accom-suite { background: var(--dog-bg); color: var(--dog-text); }
.accom-cat-standard, .accom-cat-suite { background: var(--cat-bg); color: var(--cat-text); }

[data-theme="dark"] .pet-chip           { background: rgba(80,120,85,0.3);    color: var(--text-primary); }
[data-theme="dark"] .pet-chip.cat       { background: rgba(80,30,100,0.3);    color: #c88ee8; }

/* ══════════════════════════════════════════════════════════════════════════════
   7. Client Tag Chips
   ══════════════════════════════════════════════════════════════════════════════ */

.client-tag {
  display:       inline-block;
  padding:       2px 8px;
  border-radius: var(--r-pill);
  font-size:     11px;
  font-weight:   600;
  border:        1.5px solid transparent;
}

.client-tag.vip           { background: rgba(200,131,42,0.12);  color: #7a5a10; border-color: rgba(200,131,42,0.35);  }
.client-tag.aggressive    { background: rgba(184,92,56,0.12);   color: #7a2810; border-color: rgba(184,92,56,0.35);   }
.client-tag.medication    { background: rgba(74,144,184,0.12);  color: #1a4a6a; border-color: rgba(74,144,184,0.35);  }
.client-tag.senior        { background: rgba(122,158,126,0.12); color: #2d5a35; border-color: rgba(122,158,126,0.35); }
.client-tag.anxious       { background: rgba(139,123,200,0.12); color: #3a2a6a; border-color: rgba(139,123,200,0.35); }
.client-tag.special-needs { background: rgba(139,123,200,0.10); color: #4a3a7a; border-color: rgba(139,123,200,0.28); }
.client-tag.deposit       { background: rgba(200,131,42,0.10);  color: #7a5010; border-color: rgba(200,131,42,0.28);  }

[data-theme="dark"] .client-tag.vip           { background: rgba(200,131,42,0.15);  color: #e8a84a; border-color: rgba(200,131,42,0.35);  }
[data-theme="dark"] .client-tag.aggressive    { background: rgba(184,92,56,0.15);   color: #d4886a; border-color: rgba(184,92,56,0.35);   }
[data-theme="dark"] .client-tag.medication    { background: rgba(74,144,184,0.15);  color: #7aaad0; border-color: rgba(74,144,184,0.35);  }
[data-theme="dark"] .client-tag.senior        { background: rgba(122,158,126,0.15); color: #a8c5ab; border-color: rgba(122,158,126,0.35); }
[data-theme="dark"] .client-tag.anxious       { background: rgba(139,123,200,0.15); color: #b8aee8; border-color: rgba(139,123,200,0.35); }
[data-theme="dark"] .client-tag.special-needs { background: rgba(139,123,200,0.12); color: #a8a0d8; border-color: rgba(139,123,200,0.28); }
[data-theme="dark"] .client-tag.deposit       { background: rgba(200,131,42,0.12);  color: #d4923c; border-color: rgba(200,131,42,0.28);  }

/* ══════════════════════════════════════════════════════════════════════════════
   8. Balance Badges
   ══════════════════════════════════════════════════════════════════════════════ */

.balance-unpaid  { background: rgba(184,92,56,0.12);   color: var(--rust);  }
.balance-partial { background: rgba(200,131,42,0.12);  color: var(--amber); }
.balance-paid    { background: rgba(122,158,126,0.12); color: var(--sage);  }

[data-theme="dark"] .balance-unpaid  { background: rgba(184,92,56,0.2);  }
[data-theme="dark"] .balance-partial { background: rgba(200,131,42,0.18); }
[data-theme="dark"] .balance-paid    { background: rgba(122,158,126,0.18); }

/* ══════════════════════════════════════════════════════════════════════════════
   9. Warning / Banner Components
   ══════════════════════════════════════════════════════════════════════════════ */

.vacc-warning {
  border: 1.5px solid var(--amber);
  border-radius: var(--r-md);
  padding: 10px 14px;
  background: rgba(200,131,42,0.08);
}
.vacc-warning-title,
.vacc-warning-item { color: #7a5010; font-size: 12px; font-weight: 600; }

.duplicate-warning  { background: rgba(200,131,42,0.08); border: 1.5px solid var(--amber); color: #7a5010; border-radius: var(--r-md); padding: 8px 12px; }
.not-welcome-warning{ background: rgba(184,92,56,0.08);  border: 1.5px solid var(--rust);  color: #7a2810; border-radius: var(--r-md); padding: 8px 12px; }

.first-visit-banner { border: 1.5px solid var(--sage); border-radius: var(--r-md); padding: 10px 14px; background: rgba(122,158,126,0.08); }
.first-visit-banner-text { color: #2d5a35; font-weight: 700; font-size: 13px; }
.first-visit-banner-sub  { color: #4a7a52; font-size: 11px; }

[data-theme="dark"] .vacc-warning        { background: rgba(120,80,0,0.15);      border-color: rgba(200,131,42,0.4); }
[data-theme="dark"] .vacc-warning-title,
[data-theme="dark"] .vacc-warning-item   { color: #e8c06a; }
[data-theme="dark"] .duplicate-warning   { background: rgba(120,80,0,0.18);      border-color: rgba(200,131,42,0.4); color: #e8c06a; }
[data-theme="dark"] .not-welcome-warning { background: rgba(184,92,56,0.15);     border-color: rgba(184,92,56,0.4);  color: #d4886a; }
[data-theme="dark"] .first-visit-banner  { background: rgba(122,158,126,0.15);   border-color: var(--sage); }
[data-theme="dark"] .first-visit-banner-text { color: #a8c5ab; }
[data-theme="dark"] .first-visit-banner-sub  { color: #7a9e7e; }

/* ══════════════════════════════════════════════════════════════════════════════
   10. Cards
   ══════════════════════════════════════════════════════════════════════════════ */

.arrival-card,
.departure-card {
  background:    var(--bg-card);
  border:        1.5px solid var(--border-color);
  border-radius: var(--r-lg);
  padding:       14px 16px;
}

.departure-card.has-bath     { background: rgba(210,235,250,0.4);  border-color: rgba(74,144,184,0.35); }
.departure-card.checked-out,
.arrival-card.checked-in     { background: rgba(220,240,222,0.4);  border-color: rgba(122,158,126,0.3); }

[data-theme="dark"] .arrival-card,
[data-theme="dark"] .departure-card            { background: var(--bg-card); border-color: var(--border-color); }
[data-theme="dark"] .departure-card.has-bath   { background: rgba(20,50,80,0.2);  border-color: rgba(74,144,184,0.35); }
[data-theme="dark"] .departure-card.checked-out,
[data-theme="dark"] .arrival-card.checked-in   { background: rgba(30,60,35,0.2);  border-color: rgba(122,158,126,0.3); }

/* ══════════════════════════════════════════════════════════════════════════════
   11. Autocomplete Dropdown
   ══════════════════════════════════════════════════════════════════════════════ */

.autocomplete-dropdown {
  position:      absolute;
  background:    var(--bg-card-solid);
  border:        2px solid var(--amber);
  border-radius: var(--r-md);
  box-shadow:    0 8px 24px var(--shadow-deep);
  z-index:       200;
  overflow-y:    auto;
  max-height:    320px;
}

.autocomplete-item {
  padding:       10px 14px;
  border-bottom: 1px solid var(--border-color);
  cursor:        pointer;
  color:         var(--text-primary);
}
.autocomplete-item:hover,
.autocomplete-item.highlighted { background: var(--bg-card); }
.autocomplete-item-name        { font-weight: 600; font-size: 13px; color: var(--text-primary); }
.autocomplete-item-sub         { font-size: 11px; color: var(--text-muted); }

[data-theme="dark"] .autocomplete-dropdown   { background: var(--bg-card-solid); border-color: var(--amber); }
[data-theme="dark"] .autocomplete-item       { border-color: var(--border-color); color: var(--text-primary); }
[data-theme="dark"] .autocomplete-item:hover,
[data-theme="dark"] .autocomplete-item.highlighted { background: var(--bg-card); }

/* ══════════════════════════════════════════════════════════════════════════════
   12. PIN Screen
   ══════════════════════════════════════════════════════════════════════════════ */

.pin-card  { background: var(--bg-card-solid); border-radius: var(--r-xl); box-shadow: 0 8px 32px var(--shadow-deep); }
.pin-btn   { background: var(--bg-card); border: 1.5px solid var(--border-color); color: var(--text-primary); border-radius: var(--r-md); cursor: pointer; transition: background 0.1s; }
.pin-btn:hover { background: var(--bg-page); }
.pin-title { color: var(--text-primary); }
.pin-sub   { color: var(--text-muted); }

[data-theme="dark"] .pin-card { background: var(--bg-card-solid); }
[data-theme="dark"] .pin-btn  { background: var(--bg-card); border-color: var(--border-color); color: var(--text-primary); }
[data-theme="dark"] .pin-btn:hover { background: var(--bg-page); }

/* ══════════════════════════════════════════════════════════════════════════════
   13. Toast Notifications
   ══════════════════════════════════════════════════════════════════════════════ */

#toast-container { position: fixed; bottom: 24px; right: 24px; z-index: 9999; display: flex; flex-direction: column; gap: 8px; }

.toast {
  display:       flex;
  align-items:   center;
  gap:           10px;
  padding:       12px 18px;
  border-radius: var(--r-lg);
  font-size:     13px;
  font-weight:   600;
  box-shadow:    0 4px 16px var(--shadow-deep);
  animation:     slideInRight 0.25s ease;
  background:    var(--bg-card-solid);
  color:         var(--text-primary);
}
.toast-success { background: rgba(122,158,126,0.15); color: #2d6b35; }
.toast-error   { background: rgba(184,92,56,0.15);   color: #7a2810; }
.toast-warning { background: rgba(200,131,42,0.12);  color: #7a5010; }
.toast.fade-out{ opacity: 0; transition: opacity 0.3s; }

@keyframes slideInRight {
  from { transform: translateX(60px); opacity: 0; }
  to   { transform: translateX(0);    opacity: 1; }
}
@keyframes slideUp {
  from { transform: translateY(20px); opacity: 0; }
  to   { transform: translateY(0);    opacity: 1; }
}

/* ══════════════════════════════════════════════════════════════════════════════
   14. Sync Bar
   ══════════════════════════════════════════════════════════════════════════════ */

#sync-bar {
  position:   fixed;
  bottom:     12px;
  left:       50%;
  transform:  translateX(-50%);
  background: var(--bark);
  color:      var(--cream);
  padding:    6px 16px;
  border-radius: var(--r-pill);
  font-size:  12px;
  font-weight: 600;
  display:    flex;
  align-items: center;
  gap:        8px;
  z-index:    999;
  box-shadow: 0 4px 16px var(--shadow-deep);
}

.sync-dot          { width: 8px; height: 8px; border-radius: 50%; background: var(--sage); }
.sync-dot.saving   { background: var(--amber); animation: pulse 1s infinite; }
.sync-dot.error    { background: var(--rust); }
@keyframes pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.4; }
}

/* ══════════════════════════════════════════════════════════════════════════════
   15. Metrics Alerts
   ══════════════════════════════════════════════════════════════════════════════ */

.mets-alert        { border-radius: var(--r-md); padding: 10px 14px; border: 1.5px solid transparent; display: flex; align-items: center; gap: 10px; }
.mets-alert.red    { background: rgba(184,92,56,0.1);  border-color: rgba(184,92,56,0.35); }
.mets-alert.amber  { background: rgba(200,131,42,0.1); border-color: rgba(200,131,42,0.35); }
.mets-alert.sky    { background: rgba(74,144,184,0.1); border-color: rgba(74,144,184,0.3); }
.mets-alert-text   { font-size: 13px; font-weight: 600; }
.mets-alert.red   .mets-alert-text { color: var(--rust);  }
.mets-alert.amber .mets-alert-text { color: var(--amber); }
.mets-alert.sky   .mets-alert-text { color: var(--sky);   }
.mets-alert-dismiss { cursor: pointer; opacity: 0.6; }
.mets-alert-dismiss:hover { opacity: 1; }

[data-theme="dark"] .mets-alert.red   { background: rgba(184,92,56,0.18);  border-color: rgba(184,92,56,0.4); }
[data-theme="dark"] .mets-alert.amber { background: rgba(120,80,0,0.2);    border-color: rgba(200,131,42,0.35); }
[data-theme="dark"] .mets-alert.sky   { background: rgba(20,60,100,0.25);  border-color: rgba(74,144,184,0.3); }
[data-theme="dark"] .mets-alert.red   .mets-alert-text { color: #d4886a; }
[data-theme="dark"] .mets-alert.amber .mets-alert-text { color: #e8c06a; }
[data-theme="dark"] .mets-alert.sky   .mets-alert-text { color: #8ac8e8; }
[data-theme="dark"] .mets-alert.red   .mets-alert-dismiss { color: #d4886a; }
[data-theme="dark"] .mets-alert.amber .mets-alert-dismiss { color: #e8c06a; }
[data-theme="dark"] .mets-alert.sky   .mets-alert-dismiss { color: #8ac8e8; }

/* ══════════════════════════════════════════════════════════════════════════════
   16. Misc shared utilities
   ══════════════════════════════════════════════════════════════════════════════ */

.tag-bath1 { background: rgba(74,144,184,0.12); color: #1a5a80; }
.tag-bath2 { background: rgba(122,158,126,0.12); color: #2d5a35; }
.tag-food  { background: rgba(200,131,42,0.12);  color: #7a5010; }
.tag-late  { background: rgba(184,92,56,0.12);   color: #7a2810; }
.first-visit-badge { background: rgba(122,158,126,0.12); color: #2d5a35; border: 1px solid var(--sage); border-radius: var(--r-pill); padding: 2px 8px; font-size: 11px; font-weight: 700; }

[data-theme="dark"] .tag-bath1 { background: rgba(74,144,184,0.2);   color: #90bfd4; }
[data-theme="dark"] .tag-bath2 { background: rgba(122,158,126,0.2);  color: #a8c5ab; }
[data-theme="dark"] .tag-food  { background: rgba(200,131,42,0.2);   color: #e8a84a; }
[data-theme="dark"] .tag-late  { background: rgba(184,92,56,0.2);    color: #d4886a; }
[data-theme="dark"] .first-visit-badge { background: rgba(122,158,126,0.2); color: #a8c5ab; border-color: var(--sage); }

/* Section / form block titles */
.section-title,
.form-block-title { color: var(--text-primary); font-weight: 700; }
.inner-tab        { color: var(--text-secondary); cursor: pointer; }
.inner-tab.active { color: var(--text-primary); font-weight: 700; }

[data-theme="dark"] .section-title,
[data-theme="dark"] .form-block-title { color: var(--text-primary); }
[data-theme="dark"] .inner-tab        { color: var(--text-secondary); }
[data-theme="dark"] .inner-tab.active { color: var(--text-primary); }

/* Calendar */
[data-theme="dark"] .cal-date          { color: var(--text-primary); }
[data-theme="dark"] .cal-day.other-month { opacity: 0.4; }

/* Dog/pet entry cards in forms */
[data-theme="dark"] .dog-entry,
[data-theme="dark"] .res-accom-entry,
[data-theme="dark"] .res-pet-entry,
[data-theme="dark"] .ra-pet-row  { background: var(--bg-card); }
[data-theme="dark"] .vacc-section { background: var(--bg-card); }
[data-theme="dark"] .option-row   { background: var(--bg-card); }

/* ══════════════════════════════════════════════════════════════════════════════
   17. Custom Scrollbars
   ══════════════════════════════════════════════════════════════════════════════ */

::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}
::-webkit-scrollbar-track {
  background: var(--bg-page);
}
::-webkit-scrollbar-thumb {
  background: var(--sand);
  border-radius: 10px;
  border: 2px solid var(--bg-page);
}
::-webkit-scrollbar-thumb:hover {
  background: var(--amber);
}

/* Dashboard Metrics */
.mets-val-predicted {
  color: var(--amber);
}
.mets-val-actual {
  color: var(--sage);
}
[data-theme="dark"] .mets-val-predicted {
  color: var(--amber-light) !important; /* Thematic amber-light for dark mode */
  text-shadow: 0 0 15px rgba(200, 131, 42, 0.4);
}
[data-theme="dark"] .mets-val-actual {
  text-shadow: 0 0 15px rgba(122, 158, 126, 0.3);
}

/* Firefox support */
* {
  scrollbar-width: thin;
  scrollbar-color: var(--sand) var(--bg-page);
}

