/* ==========================================================
   SAVFLOW PRO 3 — style.css
   Claymorphism design system — Light + Dark mode
   Font: Plus Jakarta Sans
========================================================== */

/* ─── DESIGN TOKENS ─── */
:root {
  --ff: "Plus Jakarta Sans", system-ui, sans-serif;
  --r-sm:  12px;
  --r-md:  18px;
  --r-lg:  24px;
  --r-xl:  32px;
  --r-pill: 999px;

  --t: .2s ease;

  /* Brand */
  --c-aqua:   #2ec4b6;
  --c-blue:   #4a90e2;
  --c-vio:    #7c5cbf;
  --c-ok:     #3ecf8e;
  --c-warn:   #f59e0b;
  --c-danger: #ef4444;
}

/* ─── LIGHT THEME ─── */
[data-theme="light"] {
  --bg:        #f0f4f8;
  --bg2:       #e8edf3;
  --surface:   #ffffff;
  --surface2:  #f5f7fa;
  --border:    rgba(0,0,0,.08);
  --shadow-out: 6px 6px 16px rgba(160,180,200,.45), -4px -4px 12px rgba(255,255,255,.85);
  --shadow-in:  inset 3px 3px 8px rgba(160,180,200,.35), inset -3px -3px 8px rgba(255,255,255,.90);
  --shadow-card: 8px 8px 24px rgba(160,180,200,.40), -4px -4px 14px rgba(255,255,255,.80);
  --txt:       #1e2a3a;
  --txt2:      #56687a;
  --txt3:      #8899aa;
  --topbar-bg: rgba(240,244,248,.80);
  --input-bg:  #edf0f5;
  --btn-bg:    #e8edf3;
  --btn-hover: #dde3eb;
  --highlight: rgba(46,196,182,.12);
}

/* ─── DARK THEME ─── */
[data-theme="dark"] {
  --bg:        #0d1117;
  --bg2:       #141b24;
  --surface:   #1c2535;
  --surface2:  #1a2030;
  --border:    rgba(255,255,255,.07);
  --shadow-out: 6px 6px 18px rgba(0,0,0,.55), -3px -3px 10px rgba(255,255,255,.04);
  --shadow-in:  inset 4px 4px 10px rgba(0,0,0,.55), inset -3px -3px 8px rgba(255,255,255,.04);
  --shadow-card: 8px 8px 28px rgba(0,0,0,.55), -3px -3px 12px rgba(255,255,255,.04);
  --txt:       #e8eef6;
  --txt2:      #8fa3b8;
  --txt3:      #4f6070;
  --topbar-bg: rgba(13,17,23,.80);
  --input-bg:  #111820;
  --btn-bg:    #1c2535;
  --btn-hover: #242f42;
  --highlight: rgba(46,196,182,.10);
}

/* ─── RESET ─── */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; min-height: 100vh; }

body {
  font-family: var(--ff);
  background: var(--bg);
  color: var(--txt);
  font-size: 14px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  transition: background var(--t), color var(--t);
}

/* ─── TYPOGRAPHY ─── */
h1,h2,h3,h4 { margin: 0; font-weight: 700; line-height: 1.25; }
h1 { font-size: 22px; }
h2 { font-size: 18px; }
h3 { font-size: 15px; }
p  { margin: 0; color: var(--txt2); font-size: 13px; }

.hidden { display: none !important; }
.muted-text { color: var(--txt3); font-size: 13px; }
.w-full { width: 100%; }

/* ─── LOADER ─── */
.loader-overlay {
  position: fixed; inset: 0; display: none;
  align-items: center; justify-content: center;
  background: rgba(0,0,0,.4); backdrop-filter: blur(8px);
  z-index: 200;
}
.loader-overlay.active { display: flex; }
.loader-clay {
  padding: 28px 32px; border-radius: var(--r-xl);
  background: var(--surface);
  box-shadow: var(--shadow-card);
  text-align: center; min-width: 160px;
}
.loader-ring {
  width: 44px; height: 44px; margin: 0 auto 12px;
  border-radius: 50%;
  border: 4px solid var(--border);
  border-top-color: var(--c-aqua);
  animation: spin 1s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.loader-clay p { margin: 0; color: var(--txt2); font-size: 13px; }

/* ─── TOASTS ─── */
.toast-container {
  position: fixed; right: 16px; bottom: 16px;
  display: flex; flex-direction: column; gap: 8px;
  z-index: 250; pointer-events: none;
}
.toast {
  min-width: 220px; max-width: 340px;
  padding: 12px 16px; border-radius: var(--r-lg);
  background: var(--surface);
  box-shadow: var(--shadow-card);
  font-weight: 600; font-size: 13px; color: var(--txt);
  pointer-events: all;
  transform: translateX(40px); opacity: 0;
  transition: transform .25s ease, opacity .25s ease;
}
.toast.show { transform: none; opacity: 1; }
.toast-success { border-left: 4px solid var(--c-ok);    }
.toast-error   { border-left: 4px solid var(--c-danger); }
.toast-info    { border-left: 4px solid var(--c-aqua);   }

/* ─── MODAL ─── */
.modal-overlay {
  position: fixed; inset: 0; display: flex;
  align-items: center; justify-content: center;
  background: rgba(0,0,0,.5); backdrop-filter: blur(6px);
  z-index: 180;
}
.modal-clay {
  width: min(480px, 95vw); padding: 24px; border-radius: var(--r-xl);
  background: var(--surface);
  box-shadow: var(--shadow-card);
}
.modal-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 18px;
}
.modal-head h3 { font-size: 16px; }
.modal-actions { display: flex; gap: 10px; justify-content: flex-end; margin-top: 18px; }

/* ─── TOPBAR ─── */
.topbar {
  position: sticky; top: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 12px 20px;
  background: var(--topbar-bg);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--border);
}
.brand-row { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.topbar-center { flex: 1; max-width: 260px; }
.topbar-right  { display: flex; align-items: center; gap: 8px; }

.logo-mark {
  width: 38px; height: 38px; border-radius: var(--r-md);
  background: linear-gradient(135deg, var(--c-aqua), var(--c-blue));
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 13px; color: #fff;
  box-shadow: var(--shadow-out);
}
.logo-mark.sm { width: 32px; height: 32px; font-size: 11px; border-radius: var(--r-sm); }

.brand-name  { font-size: 16px; font-weight: 800; }
.brand-pro   { color: var(--c-aqua); }
.brand-sub   { font-size: 12px; color: var(--txt3); margin-top: 2px; }

.user-chip {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 12px; border-radius: var(--r-pill);
  background: var(--surface2); box-shadow: var(--shadow-out);
  font-size: 13px; font-weight: 600;
}
.user-chip svg { width: 15px; height: 15px; opacity: .7; }
.role-tag {
  padding: 3px 8px; border-radius: var(--r-pill);
  background: var(--highlight); color: var(--c-aqua);
  font-size: 11px; font-weight: 700; border: 1px solid rgba(46,196,182,.25);
}

/* ─── TAB NAV ─── */
.tab-nav {
  display: flex; gap: 4px; padding: 12px 16px 0;
  overflow-x: auto; -webkit-overflow-scrolling: touch;
}
.tab-btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 10px 16px; border-radius: var(--r-lg) var(--r-lg) 0 0;
  background: var(--surface2);
  border: 1px solid var(--border); border-bottom: none;
  color: var(--txt2); font-family: var(--ff); font-size: 13px; font-weight: 600;
  cursor: pointer; white-space: nowrap;
  box-shadow: 3px 0 8px rgba(0,0,0,.12);
  transition: background var(--t), color var(--t), box-shadow var(--t);
}
.tab-btn svg { width: 15px; height: 15px; }
.tab-btn:hover { background: var(--btn-hover); color: var(--txt); }
.tab-btn.active {
  background: var(--surface); color: var(--txt);
  box-shadow: 4px 0 12px rgba(0,0,0,.18), 0 0 0 1px rgba(46,196,182,.2);
  border-color: rgba(46,196,182,.25);
}

/* ─── MAIN LAYOUT ─── */
.app-main {
  padding: 16px 16px 32px;
  max-width: 1000px; margin: 0 auto;
}
.tab-panel { display: block; }
.tab-panel.hidden { display: none; }

/* ─── CLAY CARD ─── */
.clay-card {
  background: var(--surface);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-card);
  padding: 24px;
  border: 1px solid var(--border);
}

.card-head { margin-bottom: 20px; }
.card-head h2 { margin: 8px 0 4px; }

/* ─── FORM ─── */
.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 14px;
}
.form-row { display: flex; flex-direction: column; gap: 6px; }
.form-row.full { grid-column: 1 / -1; }
.field-label { font-size: 12px; font-weight: 600; color: var(--txt2); text-transform: uppercase; letter-spacing: .4px; }

.clay-input {
  padding: 11px 14px; border-radius: var(--r-md);
  background: var(--input-bg);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-in);
  color: var(--txt); font-family: var(--ff); font-size: 14px;
  outline: none; width: 100%;
  transition: border-color var(--t), box-shadow var(--t);
}
.clay-input:focus {
  border-color: rgba(46,196,182,.5);
  box-shadow: var(--shadow-in), 0 0 0 3px rgba(46,196,182,.12);
}
.clay-input::placeholder { color: var(--txt3); }
.clay-input option       { background: var(--surface); color: var(--txt); }

textarea.clay-input { resize: vertical; min-height: 80px; }

.project-sel { font-weight: 600; }

/* ─── BUTTONS ─── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 11px 18px; border-radius: var(--r-pill);
  border: 1px solid var(--border);
  background: var(--btn-bg);
  box-shadow: var(--shadow-out);
  color: var(--txt); font-family: var(--ff); font-size: 14px; font-weight: 600;
  cursor: pointer; white-space: nowrap;
  transition: transform var(--t), box-shadow var(--t), filter var(--t);
}
.btn svg { width: 16px; height: 16px; }
.btn:hover  { transform: translateY(-2px); filter: brightness(1.06); }
.btn:active { transform: translateY(0); box-shadow: var(--shadow-in); }

.btn-primary {
  background: linear-gradient(135deg, rgba(46,196,182,.25), rgba(74,144,226,.20));
  border-color: rgba(46,196,182,.3);
  color: var(--txt);
}
.btn-secondary {
  background: linear-gradient(135deg, rgba(74,144,226,.2), rgba(124,92,191,.15));
  border-color: rgba(74,144,226,.3);
}
.btn-ghost { background: transparent; box-shadow: none; }
.btn-ghost:hover { background: var(--btn-hover); box-shadow: var(--shadow-out); }
.btn-sm   { padding: 7px 12px; font-size: 12px; }
.btn-icon {
  width: 34px; height: 34px; padding: 0; border-radius: var(--r-sm);
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--btn-bg); border: 1px solid var(--border);
  box-shadow: var(--shadow-out); cursor: pointer; color: var(--txt2);
  transition: transform var(--t), box-shadow var(--t);
}
.btn-icon:hover { transform: translateY(-1px); color: var(--c-danger); }
.btn-icon svg   { width: 14px; height: 14px; }

.form-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 18px; }

/* ─── ITEM BUILDER ─── */
.item-builder {
  padding: 16px; border-radius: var(--r-lg);
  background: var(--surface2); border: 1px solid var(--border);
  margin-bottom: 14px;
}
.section-title {
  display: flex; align-items: center; gap: 7px;
  font-size: 13px; font-weight: 700; color: var(--txt2);
  text-transform: uppercase; letter-spacing: .4px;
  margin-bottom: 12px;
}
.section-title svg { width: 14px; height: 14px; }

/* ─── ITEMS LIST ─── */
.items-section { margin-bottom: 14px; }
.items-empty {
  padding: 14px; border-radius: var(--r-md);
  background: var(--surface2); color: var(--txt3);
  text-align: center; font-size: 13px;
  border: 1px dashed var(--border);
}
.item-row {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 10px 12px; border-radius: var(--r-md);
  background: var(--surface2); border: 1px solid var(--border);
  box-shadow: var(--shadow-out);
  margin-bottom: 8px;
}
.item-badge {
  padding: 3px 10px; border-radius: var(--r-pill);
  background: var(--highlight);
  color: var(--c-aqua); font-size: 11px; font-weight: 700;
  border: 1px solid rgba(46,196,182,.2); white-space: nowrap; flex-shrink: 0;
}
.item-body { flex: 1; min-width: 0; display: flex; flex-wrap: wrap; gap: 6px; }
.item-desig { font-size: 13px; font-weight: 600; color: var(--txt); }
.item-loc   {
  display: flex; align-items: center; gap: 4px;
  font-size: 12px; color: var(--txt2);
}
.item-loc svg { width: 11px; height: 11px; }
.item-rem   { font-size: 12px; color: var(--txt3); font-style: italic; }

/* ─── PHOTOS ─── */
.photos-section { margin-bottom: 14px; }
.file-input     { display: none; }
.photos-preview { display: flex; flex-direction: column; gap: 6px; margin-top: 8px; }
.photo-pill {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px; border-radius: var(--r-md);
  background: var(--surface2); border: 1px solid var(--border);
  box-shadow: var(--shadow-out);
}
.photo-pill svg { width: 15px; height: 15px; color: var(--c-blue); flex-shrink: 0; }
.photo-name     { flex: 1; font-size: 13px; font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.photo-link     { font-size: 12px; color: var(--c-aqua); text-decoration: none; white-space: nowrap; }
.photo-link:hover { text-decoration: underline; }

/* ─── PDF RESULT ─── */
.pdf-result {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 14px; border-radius: var(--r-lg);
  background: var(--surface2); border: 1px solid rgba(62,207,142,.2);
  box-shadow: var(--shadow-out); margin-top: 14px;
}
.pdf-result svg { width: 18px; height: 18px; color: var(--c-ok); }

/* ─── BADGES ─── */
.type-badge {
  display: inline-block; padding: 4px 10px; border-radius: var(--r-pill);
  font-size: 11px; font-weight: 700; letter-spacing: .4px;
}
.type-sav  { background: rgba(245,158,11,.15);  color: var(--c-warn);   border: 1px solid rgba(245,158,11,.3); }
.type-liv  { background: rgba(62,207,142,.15);  color: var(--c-ok);     border: 1px solid rgba(62,207,142,.3); }
.type-chan { background: rgba(74,144,226,.15);  color: var(--c-blue);   border: 1px solid rgba(74,144,226,.3); }

.stat-badge {
  display: inline-block; padding: 3px 10px; border-radius: var(--r-pill);
  font-size: 11px; font-weight: 700;
}
.clay-aqua   { background: rgba(46,196,182,.15);  color: var(--c-aqua);   border: 1px solid rgba(46,196,182,.3); }
.clay-blue   { background: rgba(74,144,226,.15);  color: var(--c-blue);   border: 1px solid rgba(74,144,226,.3); }
.clay-warn   { background: rgba(245,158,11,.15);  color: var(--c-warn);   border: 1px solid rgba(245,158,11,.3); }
.clay-ok     { background: rgba(62,207,142,.15);  color: var(--c-ok);     border: 1px solid rgba(62,207,142,.3); }
.clay-danger { background: rgba(239,68,68,.15);   color: var(--c-danger); border: 1px solid rgba(239,68,68,.3); }

.badge-late { background: rgba(239,68,68,.12); color: var(--c-danger); border: 1px solid rgba(239,68,68,.25); padding: 3px 8px; border-radius: var(--r-pill); font-size: 11px; font-weight: 700; }

/* ─── SUIVI / TICKET CARDS ─── */
.filters-bar {
  display: flex; gap: 12px; flex-wrap: wrap; align-items: flex-end;
  padding: 14px; border-radius: var(--r-lg);
  background: var(--surface2); border: 1px solid var(--border);
  margin-bottom: 16px;
}
.filters-bar .form-row { min-width: 140px; flex: 1; }

.suivi-meta { margin-bottom: 12px; }

.tickets-list { display: flex; flex-direction: column; gap: 12px; }

.ticket-card {
  padding: 16px; border-radius: var(--r-xl);
  background: var(--surface2); border: 1px solid var(--border);
  box-shadow: var(--shadow-card);
  transition: transform var(--t);
}
.ticket-card:hover { transform: translateY(-2px); }

.ticket-head {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 10px;
  margin-bottom: 10px;
}
.ticket-id { font-size: 13px; font-weight: 800; color: var(--txt); font-family: monospace; }
.ticket-badges { display: flex; gap: 6px; flex-wrap: wrap; }

.ticket-meta {
  display: flex; flex-wrap: wrap; gap: 10px;
  font-size: 12px; color: var(--txt2); margin-bottom: 8px;
}
.ticket-meta span { display: flex; align-items: center; gap: 4px; }
.ticket-meta svg  { width: 12px; height: 12px; }

.ticket-etape {
  font-size: 11px; color: var(--c-blue); font-weight: 700;
  text-transform: uppercase; letter-spacing: .5px; margin-bottom: 8px;
}

.ticket-items { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 8px; }
.item-chip {
  padding: 3px 8px; border-radius: var(--r-pill);
  background: var(--surface); border: 1px solid var(--border);
  font-size: 11px; font-weight: 600; color: var(--txt2);
}
.item-chip.more { color: var(--c-aqua); border-color: rgba(46,196,182,.2); }

.ticket-times {
  display: flex; flex-wrap: wrap; gap: 10px;
  font-size: 11px; color: var(--txt3); margin-bottom: 10px;
}

.ticket-actions { display: flex; gap: 8px; flex-wrap: wrap; }

.empty-state {
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  padding: 40px; color: var(--txt3);
}
.empty-state svg { width: 36px; height: 36px; opacity: .3; }

/* ─── DASHBOARD ─── */
.dash-kpis {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: 12px; margin-bottom: 20px;
}
.kpi-card {
  padding: 18px 16px; border-radius: var(--r-xl);
  background: var(--surface); border: 1px solid var(--border);
  box-shadow: var(--shadow-card); text-align: center;
}
.kpi-num   { font-size: 32px; font-weight: 800; color: var(--c-aqua); line-height: 1; margin-bottom: 4px; }
.kpi-label { font-size: 11px; color: var(--txt2); text-transform: uppercase; letter-spacing: .4px; }

.dash-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.dash-section {
  padding: 16px; border-radius: var(--r-xl);
  background: var(--surface2); border: 1px solid var(--border);
  box-shadow: var(--shadow-card);
}
.dash-title {
  font-size: 12px; font-weight: 700; color: var(--txt2);
  text-transform: uppercase; letter-spacing: .5px; margin-bottom: 12px;
}

.bar-list { display: flex; flex-direction: column; gap: 8px; }
.bar-row  { display: flex; align-items: center; gap: 8px; }
.bar-label { font-size: 12px; color: var(--txt2); min-width: 80px; flex-shrink: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bar-track { flex: 1; height: 8px; background: var(--surface); border-radius: 99px; overflow: hidden; box-shadow: var(--shadow-in); }
.bar-fill  { height: 100%; background: var(--c-aqua); border-radius: 99px; transition: width .5s ease; }
.bar-val   { font-size: 12px; font-weight: 700; color: var(--txt); min-width: 24px; text-align: right; }

.dash-table-wrap { overflow-x: auto; }
.dash-table {
  width: 100%; border-collapse: collapse; font-size: 12px;
}
.dash-table th {
  padding: 8px 10px; text-align: left;
  background: var(--surface); font-weight: 700; color: var(--txt2);
  border-bottom: 1px solid var(--border); white-space: nowrap;
}
.dash-table td {
  padding: 8px 10px; border-bottom: 1px solid var(--border); color: var(--txt);
}
.dash-table tr:last-child td { border-bottom: none; }
.dash-table tr:hover td { background: var(--surface); }

/* ─── LOGIN ─── */
.login-wrap {
  min-height: 100vh; display: flex;
  align-items: center; justify-content: center;
  background: var(--bg); padding: 20px;
}
.login-clay {
  width: min(400px, 100%); padding: 32px;
  border-radius: var(--r-xl);
  background: var(--surface);
  box-shadow: var(--shadow-card);
  border: 1px solid var(--border);
}
.login-logo {
  display: flex; align-items: center; gap: 14px;
  margin-bottom: 24px;
}
.login-footer {
  display: flex; align-items: center; gap: 8px;
  margin-top: 18px; color: var(--txt3); font-size: 12px;
}

/* ─── RESPONSIVE ─── */
@media (max-width: 760px) {
  .topbar { flex-wrap: wrap; gap: 10px; padding: 10px 14px; }
  .topbar-center { order: 3; width: 100%; max-width: 100%; }
  .topbar-right  { margin-left: auto; }
  .app-main  { padding: 10px 10px 24px; }
  .clay-card { padding: 16px; }
  .form-grid { grid-template-columns: 1fr; }
  .dash-grid { grid-template-columns: 1fr; }
  .dash-kpis { grid-template-columns: repeat(2, 1fr); }
  .kpi-num   { font-size: 26px; }
  .tab-nav   { padding: 8px 10px 0; gap: 2px; }
  .tab-btn   { padding: 8px 12px; font-size: 12px; }
  .tab-btn span { display: none; }
  .filters-bar { gap: 8px; }
  .filters-bar .form-row { min-width: 120px; }
}

@media (max-width: 420px) {
  .dash-kpis { grid-template-columns: 1fr 1fr; }
  .user-chip span:first-of-type { display: none; }
}
/* ─── ADMIN SUBNAV ─── */
.admin-subnav {
  display: flex; gap: 4px; flex-wrap: wrap;
  padding: 16px 0 12px;
}
.admin-subtab {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 9px 16px; border-radius: var(--r-pill);
  background: var(--surface2); border: 1px solid var(--border);
  box-shadow: var(--shadow-out);
  color: var(--txt2); font-family: var(--ff); font-size: 13px; font-weight: 600;
  cursor: pointer; white-space: nowrap;
  transition: background var(--t), color var(--t);
}
.admin-subtab svg { width: 14px; height: 14px; }
.admin-subtab:hover  { background: var(--btn-hover); color: var(--txt); }
.admin-subtab.active {
  background: linear-gradient(135deg, rgba(46,196,182,.2), rgba(74,144,226,.15));
  border-color: rgba(46,196,182,.35);
  color: var(--txt);
  box-shadow: var(--shadow-out), 0 0 0 1px rgba(46,196,182,.2);
}

/* ─── ADMIN PANELS ─── */
.admin-panel { margin-top: 0; }
.admin-panel.hidden { display: none; }

.admin-toolbar {
  display: flex; gap: 10px; flex-wrap: wrap;
  margin-bottom: 16px;
}

.admin-list { display: flex; flex-direction: column; gap: 8px; }

.admin-row {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 12px 16px; border-radius: var(--r-lg);
  background: var(--surface2); border: 1px solid var(--border);
  box-shadow: var(--shadow-out);
}
.admin-row-info {
  display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
  flex: 1; min-width: 0;
}
.admin-row-info b  { font-size: 13px; font-weight: 700; color: var(--txt); }
.admin-row-actions { display: flex; gap: 6px; flex-shrink: 0; }

/* ─── MASTER SHEET TABS ─── */
.master-sheet-tabs {
  display: flex; gap: 4px; flex-wrap: wrap;
  margin-bottom: 14px;
}
.master-tab {
  padding: 7px 14px; border-radius: var(--r-pill);
  background: var(--surface2); border: 1px solid var(--border);
  color: var(--txt2); font-family: var(--ff); font-size: 12px; font-weight: 600;
  cursor: pointer; white-space: nowrap;
  transition: background var(--t), color var(--t);
}
.master-tab:hover  { background: var(--btn-hover); color: var(--txt); }
.master-tab.active {
  background: var(--highlight); border-color: rgba(46,196,182,.35);
  color: var(--c-aqua);
}

/* ─── ADMIN MASTER TABLE ─── */
.admin-table-wrap { overflow-x: auto; }
.admin-master-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.admin-master-table th {
  padding: 8px 10px; text-align: left;
  background: var(--surface); font-weight: 700; color: var(--txt2);
  border-bottom: 1px solid var(--border); white-space: nowrap;
}
.admin-master-table td {
  padding: 8px 10px; border-bottom: 1px solid var(--border); color: var(--txt);
}
.admin-master-table tr:last-child td { border-bottom: none; }
.admin-master-table tr:hover td { background: var(--surface2); }

/* ─── SETTINGS FORM ─── */
.settings-form { display: flex; flex-direction: column; gap: 12px; margin-bottom: 16px; }
.settings-form .form-row { flex-direction: row; align-items: center; gap: 14px; }
.settings-form .field-label { flex-shrink: 0; min-width: 200px; }
.settings-val { flex: 1; }

/* ─── MODAL WIDE ─── */
.modal-wide {
  width: min(640px, 96vw);
  max-height: 86vh;
  overflow-y: auto;
}

/* ─── LOGO UPLOAD MODAL ─── */
.logo-upload-area {
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  padding: 28px; margin-bottom: 14px;
  border: 2px dashed var(--border); border-radius: var(--r-lg);
  background: var(--surface2); color: var(--txt2);
  text-align: center; cursor: pointer;
  transition: border-color var(--t), background var(--t);
}
.logo-upload-area:hover {
  border-color: rgba(46,196,182,.4);
  background: var(--highlight);
}
.logo-upload-area svg { width: 28px; height: 28px; opacity: .5; }
.logo-preview-wrap { margin-bottom: 14px; text-align: center; }

/* ─── DYNAMIC FIELDS (v5 engine) ─── */
.dynamic-field {
  display: flex; flex-direction: column; gap: 6px;
  margin-bottom: 12px;
}
.dynamic-field label {
  font-size: 12px; font-weight: 600; color: var(--txt2);
  text-transform: uppercase; letter-spacing: .4px;
}

/* ─── TICKET EXTRA DYNAMIC COLUMNS ─── */
.ticket-extra {
  display: flex; flex-wrap: wrap; gap: 6px;
  margin-bottom: 8px;
}
.extra-chip {
  padding: 3px 10px; border-radius: var(--r-pill);
  background: var(--surface); border: 1px solid var(--border);
  font-size: 11px; color: var(--txt2);
}
.extra-chip b { color: var(--txt); font-weight: 700; }

/* ==========================================================
   ADMIN DASHBOARD v6.0 — Enhanced Styles
========================================================== */

/* ─── ACCESS DENIED ─── */
.admin-denied {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 12px; padding: 80px 24px;
  text-align: center; color: var(--txt2);
}
.admin-denied svg { width: 48px; height: 48px; opacity: .4; }
.admin-denied h3  { font-size: 18px; color: var(--txt); }

/* ─── OVERVIEW CARD HEAD ─── */
.admin-overview-head {
  display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; gap: 10px;
}

/* ─── KPI GRID ─── */
.admin-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 14px;
  margin: 20px 0;
}
.admin-kpi-card {
  display: flex; align-items: center; gap: 14px;
  padding: 16px 18px; border-radius: var(--r-lg);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-card);
  background: var(--surface);
  transition: transform .15s ease, box-shadow .15s ease;
}
.admin-kpi-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-card), 0 4px 20px rgba(0,0,0,.15);
}
.kpi-icon {
  width: 40px; height: 40px; border-radius: var(--r-md);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.kpi-icon svg { width: 20px; height: 20px; }
.kpi-body { min-width: 0; }
.kpi-val   { font-size: 22px; font-weight: 800; color: var(--txt); line-height: 1.1; }
.kpi-label { font-size: 11px; color: var(--txt3); font-weight: 600; text-transform: uppercase; letter-spacing: .4px; margin-top: 2px; }

/* KPI Color Variants */
.admin-kpi-blue   .kpi-icon { background: rgba(74,144,226,.15);  color: var(--c-blue);   }
.admin-kpi-aqua   .kpi-icon { background: rgba(46,196,182,.15);  color: var(--c-aqua);   }
.admin-kpi-vio    .kpi-icon { background: rgba(124,92,191,.15);  color: var(--c-vio);    }
.admin-kpi-warn   .kpi-icon { background: rgba(245,158,11,.15);  color: var(--c-warn);   }
.admin-kpi-ok     .kpi-icon { background: rgba(62,207,142,.15);  color: var(--c-ok);     }
.admin-kpi-danger .kpi-icon { background: rgba(239,68,68,.15);   color: var(--c-danger); }

/* ─── OVERVIEW GRID ─── */
.admin-overview-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 20px;
  margin-top: 20px;
}
@media (max-width: 640px) {
  .admin-overview-grid { grid-template-columns: 1fr; }
}
.admin-overview-block {
  padding: 16px; border-radius: var(--r-lg);
  background: var(--surface2); border: 1px solid var(--border);
}

/* ─── ACTIVITY LIST ─── */
.admin-activity-list { display: flex; flex-direction: column; gap: 6px; margin-top: 10px; }
.activity-row {
  display: flex; align-items: center; gap: 10px;
  padding: 6px 10px; border-radius: var(--r-sm);
  background: var(--surface); border: 1px solid var(--border);
  font-size: 12px;
}
.activity-type { padding: 2px 8px; border-radius: var(--r-pill); font-size: 10px; font-weight: 700; }
.activity-id   { font-weight: 700; color: var(--txt); font-family: monospace; }
.activity-proj, .activity-stat { color: var(--txt3); font-size: 11px; }

/* ─── ROLE BARS ─── */
.admin-role-bars { margin-top: 10px; }

/* ─── ADMIN ROW ENHANCEMENTS ─── */
.admin-row-inactive {
  opacity: .6;
  background: var(--surface2) !important;
}
.admin-row-logo {
  flex-shrink: 0; width: 44px; height: 44px;
  display: flex; align-items: center; justify-content: center;
}
.admin-proj-logo {
  width: 44px; height: 44px; border-radius: var(--r-sm);
  object-fit: cover; border: 1px solid var(--border);
}
.admin-proj-logo-placeholder {
  width: 44px; height: 44px; border-radius: var(--r-sm);
  border: 1px dashed var(--border);
  display: flex; align-items: center; justify-content: center;
  color: var(--txt3);
}
.admin-proj-logo-placeholder svg { width: 18px; height: 18px; }

/* ─── STATUS BADGES ─── */
.status-badge {
  padding: 2px 10px; border-radius: var(--r-pill);
  font-size: 11px; font-weight: 700;
}
.badge-active  { background: rgba(62,207,142,.18); color: var(--c-ok); border: 1px solid rgba(62,207,142,.3); }
.badge-inactive{ background: rgba(239,68,68,.12);  color: var(--c-danger); border: 1px solid rgba(239,68,68,.25); }

/* ─── ADMIN USER AVATAR ─── */
.admin-row-avatar {
  flex-shrink: 0; width: 38px; height: 38px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; font-weight: 800; color: #fff;
}
.admin-row-avatar.clay-blue   { background: var(--c-blue); }
.admin-row-avatar.clay-danger { background: var(--c-danger); }
.admin-row-avatar.clay-warn   { background: var(--c-warn); }
.admin-row-avatar.clay-aqua   { background: var(--c-aqua); }

.role-tag-sm {
  padding: 2px 8px; border-radius: var(--r-pill);
  font-size: 10px; font-weight: 700;
}
.role-tag-sm.clay-blue   { background: rgba(74,144,226,.15); color: var(--c-blue); }
.role-tag-sm.clay-danger { background: rgba(239,68,68,.12);  color: var(--c-danger); }
.role-tag-sm.clay-warn   { background: rgba(245,158,11,.15); color: var(--c-warn); }

.you-tag {
  padding: 1px 7px; border-radius: var(--r-pill);
  background: rgba(46,196,182,.15); color: var(--c-aqua);
  font-size: 10px; font-weight: 700;
}

/* ─── SEARCH WRAP ─── */
.admin-search-wrap {
  position: relative; flex: 1; max-width: 280px;
}
.admin-search-icon {
  position: absolute; left: 10px; top: 50%; transform: translateY(-50%);
  width: 14px; height: 14px; color: var(--txt3); pointer-events: none;
}
.admin-search-input {
  padding-left: 32px !important; height: 36px; font-size: 13px;
}

/* ─── DB TABS ─── */
.admin-db-tabs {
  display: flex; gap: 4px; flex-wrap: wrap; margin-bottom: 14px;
}
.admin-db-tab {
  padding: 7px 14px; border-radius: var(--r-pill);
  background: var(--surface2); border: 1px solid var(--border);
  color: var(--txt2); font-family: var(--ff); font-size: 12px; font-weight: 600;
  cursor: pointer; white-space: nowrap;
  transition: background var(--t), color var(--t);
}
.admin-db-tab:hover  { background: var(--btn-hover); color: var(--txt); }
.admin-db-tab.active {
  background: var(--highlight); border-color: rgba(46,196,182,.35); color: var(--c-aqua);
}

/* ─── DB TOOLBAR ─── */
.admin-db-toolbar { align-items: center; }

/* ─── DB FULL TABLE ─── */
.admin-db-full-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.admin-db-full-table th {
  padding: 8px 10px; text-align: left;
  background: var(--surface); font-weight: 700; color: var(--txt2);
  border-bottom: 1px solid var(--border); white-space: nowrap; position: sticky; top: 0; z-index: 2;
}
.admin-db-full-table td {
  padding: 7px 10px; border-bottom: 1px solid var(--border); color: var(--txt);
  max-width: 200px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.admin-db-full-table tr:last-child td { border-bottom: none; }
.admin-db-full-table tr:hover td { background: var(--surface2); }
.db-check-col   { width: 36px; }
.db-actions-col { width: 90px; text-align: right; }
.db-cell        { cursor: default; }

/* ─── BULK BAR ─── */
.db-bulk-bar {
  display: none; align-items: center; gap: 12px;
  padding: 10px 14px; margin-top: 8px;
  border-radius: var(--r-lg); background: var(--surface2);
  border: 1px solid rgba(239,68,68,.3);
}
.db-bulk-bar.active { display: flex; }

/* ─── BUTTON DANGER GHOST ─── */
.btn-danger-ghost { color: var(--c-danger) !important; }
.btn-danger-ghost:hover { background: rgba(239,68,68,.1) !important; }

/* ─── BUTTON VARIANTS ─── */
.btn-ok   { background: rgba(62,207,142,.15) !important; color: var(--c-ok) !important; border-color: rgba(62,207,142,.3) !important; }
.btn-ok:hover { background: rgba(62,207,142,.25) !important; }
.btn-warn { background: rgba(245,158,11,.15) !important; color: var(--c-warn) !important; border-color: rgba(245,158,11,.3) !important; }
.btn-warn:hover { background: rgba(245,158,11,.25) !important; }
.btn-danger { background: rgba(239,68,68,.15) !important; color: var(--c-danger) !important; border-color: rgba(239,68,68,.3) !important; }
.btn-danger:hover { background: rgba(239,68,68,.25) !important; }

/* ─── SETTINGS ENHANCED ─── */
.settings-tiles {
  display: flex; flex-direction: column; gap: 10px; margin-bottom: 20px;
}
.settings-tile {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 16px; border-radius: var(--r-lg);
  background: var(--surface2); border: 1px solid var(--border);
}
.settings-tile-icon {
  width: 38px; height: 38px; border-radius: var(--r-md);
  background: var(--highlight); border: 1px solid rgba(46,196,182,.2);
  display: flex; align-items: center; justify-content: center;
  color: var(--c-aqua); flex-shrink: 0;
}
.settings-tile-icon svg { width: 18px; height: 18px; }
.settings-tile-body { flex: 1; }
.settings-tile-title { font-weight: 700; font-size: 13px; color: var(--txt); }
.settings-tile-desc  { font-size: 12px; color: var(--txt3); margin-top: 2px; }
.settings-tile-toggle { flex-shrink: 0; }

.admin-settings-divider {
  display: flex; align-items: center; gap: 10px;
  margin: 20px 0 14px;
  font-size: 12px; font-weight: 700; color: var(--txt3); text-transform: uppercase; letter-spacing: .5px;
}
.admin-settings-divider::before, .admin-settings-divider::after {
  content: ""; flex: 1; height: 1px; background: var(--border);
}

.settings-form-row {
  display: flex !important; flex-direction: row !important; align-items: center; gap: 10px;
}
.settings-key-col { flex-shrink: 0; min-width: 200px; }
.settings-key-badge {
  padding: 3px 10px; border-radius: var(--r-pill);
  background: var(--surface2); border: 1px solid var(--border);
  font-size: 12px; font-weight: 700; font-family: monospace; color: var(--c-aqua);
}
.settings-desc { font-size: 11px; color: var(--txt3); display: block; margin-top: 2px; }

/* ─── ASSIGN MODAL CHECKS ─── */
.assign-project-checks {
  display: flex; flex-direction: column; gap: 8px;
  max-height: 200px; overflow-y: auto;
  padding: 8px; border-radius: var(--r-md);
  background: var(--surface2); border: 1px solid var(--border);
}
.assign-check-label {
  display: flex; align-items: center; gap: 8px;
  cursor: pointer; padding: 4px 6px; border-radius: var(--r-sm);
  transition: background var(--t);
}
.assign-check-label:hover { background: var(--highlight); }
.assign-check-label input { cursor: pointer; accent-color: var(--c-aqua); }

/* ─── ADMIN SUBTAB v6 — override for 5 items ─── */
.admin-subnav {
  display: flex; gap: 6px; flex-wrap: wrap;
  padding: 16px; margin-bottom: 0;
}

/* ─── DB TABLE WRAP scroll ─── */
.admin-table-wrap { max-height: 500px; overflow: auto; }