/* ========================================================
   Aurora — Interactive Design System
   ======================================================== */

:root,
:root[data-theme="dark"]{
  --au-bg-base:   #050614;
  --au-blob-1:    #7c3aed;
  --au-blob-2:    #06b6d4;
  --au-blob-3:    #ec4899;

  --au-surface:        rgba(255,255,255,0.03);
  --au-surface-2:      rgba(255,255,255,0.06);
  --au-surface-strong: rgba(20, 22, 40, 0.65);
  --au-border:         rgba(255,255,255,0.08);
  --au-border-2:       rgba(255,255,255,0.16);

  --au-text-1: #ffffff;
  --au-text-2: #c9cce0;
  --au-text-3: #7c809b;
  --au-text-4: #4b4f6b;

  --au-accent:   #06b6d4;
  --au-accent-2: #8b5cf6;
  --au-accent-3: #ec4899;

  --au-ok:   #10b981;
  --au-warn: #f59e0b;
  --au-bad:  #ef4444;

  --au-glow-c: 6, 182, 212;
  --au-glow-v: 139, 92, 246;
  --au-glow-p: 236, 72, 153;

  --au-r-sm: 10px;
  --au-r:    16px;
  --au-r-lg: 24px;
  --au-r-xl: 32px;

  --au-blur: 16px;
}

:root[data-theme="light"]{
  --au-bg-base:   #f7f8ff;
  --au-blob-1:    #8b5cf6;
  --au-blob-2:    #06b6d4;
  --au-blob-3:    #f472b6;

  --au-surface:        rgba(255,255,255,0.55);
  --au-surface-2:      rgba(255,255,255,0.75);
  --au-surface-strong: rgba(255,255,255,0.92);
  --au-border:         rgba(15,23,42,0.06);
  --au-border-2:       rgba(15,23,42,0.14);

  --au-text-1: #0b0d23;
  --au-text-2: #393d5c;
  --au-text-3: #696e8c;
  --au-text-4: #9aa0bd;

  --au-accent:   #0891b2;
  --au-accent-2: #7c3aed;
  --au-accent-3: #db2777;

  --au-ok:   #059669;
  --au-warn: #d97706;
  --au-bad:  #dc2626;

  --au-glow-c: 8, 145, 178;
  --au-glow-v: 124, 58, 237;
  --au-glow-p: 219, 39, 119;
}

/* ====== shell overrides so the existing topbar matches ====== */
:root, :root[data-theme="dark"]{
  --wm-bg:        transparent;
  --wm-surface:   var(--au-surface);
  --wm-surface2:  var(--au-surface-2);
  --wm-border:    var(--au-border);
  --wm-text:      var(--au-text-1);
  --wm-muted:     var(--au-text-3);
  --wm-accent:    var(--au-accent);
  --wm-accent2:   var(--au-accent-2);
  --wm-danger:    var(--au-bad);
  --wm-blur:      blur(var(--au-blur));
  --wm-shadow:    0 12px 40px rgba(var(--au-glow-c), 0.10);
}

/* ====== BODY + AURORA BG ====== */
html, body{
  background: var(--au-bg-base);
  color: var(--au-text-1);
  min-height: 100vh;
  margin: 0;
}
body.aur-body{
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "SF Pro Text", "Inter", "Tahoma", system-ui, sans-serif;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

/* Aurora background — animated blobs */
.aur-aurora{
  position: fixed;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
}
.aur-aurora__blob{
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0.45;
  will-change: transform;
}
.aur-aurora__blob--1{
  width: 600px; height: 600px;
  top: -200px; inset-inline-start: -150px;
  background: var(--au-blob-1);
  animation: aur-float-1 22s ease-in-out infinite;
}
.aur-aurora__blob--2{
  width: 500px; height: 500px;
  top: 30%; inset-inline-end: -120px;
  background: var(--au-blob-2);
  animation: aur-float-2 28s ease-in-out infinite;
}
.aur-aurora__blob--3{
  width: 540px; height: 540px;
  bottom: -200px; inset-inline-start: 30%;
  background: var(--au-blob-3);
  animation: aur-float-3 24s ease-in-out infinite;
  opacity: 0.35;
}
@keyframes aur-float-1{
  0%, 100%{ transform: translate(0, 0) scale(1); }
  33%{ transform: translate(80px, 50px) scale(1.1); }
  66%{ transform: translate(-50px, 90px) scale(0.95); }
}
@keyframes aur-float-2{
  0%, 100%{ transform: translate(0, 0) scale(1); }
  50%{ transform: translate(-120px, -80px) scale(1.15); }
}
@keyframes aur-float-3{
  0%, 100%{ transform: translate(0, 0) scale(1); }
  40%{ transform: translate(80px, -50px) scale(0.9); }
  80%{ transform: translate(-90px, 30px) scale(1.1); }
}
:root[data-theme="light"] .aur-aurora__blob{ opacity: 0.25; }

/* Grain overlay */
.aur-aurora::after{
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.04;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* Cursor-tracking glow (set via JS) */
.aur-cursor-glow{
  position: fixed;
  width: 480px; height: 480px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(var(--au-glow-c), 0.18) 0%, transparent 60%);
  pointer-events: none;
  z-index: 1;
  transform: translate(-50%, -50%);
  transition: opacity .2s;
  opacity: 0;
  will-change: transform;
}
.aur-body.aur-has-cursor .aur-cursor-glow{ opacity: 1; }

body.aur-body > main,
body.aur-body > .aur-shell-content{ position: relative; z-index: 2; }

/* Scrollbar */
*{ scrollbar-width: thin; scrollbar-color: var(--au-border-2) transparent; }
*::-webkit-scrollbar{ width: 10px; height: 10px; }
*::-webkit-scrollbar-track{ background: transparent; }
*::-webkit-scrollbar-thumb{ background: var(--au-border); border-radius: 10px; border: 2px solid transparent; background-clip: padding-box; }
*::-webkit-scrollbar-thumb:hover{ background: var(--au-border-2); background-clip: padding-box; }

::selection{ background: rgba(var(--au-glow-c), 0.45); color: var(--au-text-1); }

/* ======================================================
   STOCK PAGE
   ====================================================== */
.aur-stock{
  position: relative;
  max-width: 1400px;
  margin: 0 auto;
  padding: 100px 24px 60px;
  z-index: 2;
}

/* ====== HERO ====== */
.aur-hero{
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: end;
  margin-bottom: 32px;
}
.aur-hero__title{
  margin: 0 0 8px;
  font-size: clamp(32px, 5vw, 52px);
  font-weight: 800;
  letter-spacing: -0.035em;
  line-height: 1;
  background: linear-gradient(135deg, var(--au-text-1) 0%, var(--au-accent) 60%, var(--au-accent-2) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.aur-hero__sub{
  margin: 0;
  color: var(--au-text-3);
  font-size: 14px;
}

/* Quick stats row */
.aur-quickstats{
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.aur-qstat{
  position: relative;
  min-width: 100px;
  padding: 14px 18px;
  border-radius: var(--au-r);
  background: var(--au-surface);
  border: 1px solid var(--au-border);
  backdrop-filter: blur(var(--au-blur));
  -webkit-backdrop-filter: blur(var(--au-blur));
  transition: border-color .25s, transform .25s;
}
.aur-qstat:hover{
  border-color: var(--au-border-2);
  transform: translateY(-2px);
}
.aur-qstat__lbl{
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--au-text-3);
  margin-bottom: 6px;
}
.aur-qstat__val{
  font-size: 28px;
  font-weight: 800;
  color: var(--au-text-1);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.aur-qstat--ok  .aur-qstat__val{ color: var(--au-ok); }
.aur-qstat--bad .aur-qstat__val{ color: var(--au-bad); }
.aur-qstat--accent{ background: linear-gradient(135deg, rgba(var(--au-glow-c),0.18), rgba(var(--au-glow-v),0.10)); border-color: transparent; }
.aur-qstat--accent .aur-qstat__val{
  background: linear-gradient(135deg, var(--au-accent), var(--au-accent-2));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* ====== SEARCHBAR ====== */
.aur-controls{
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 28px;
}
.aur-search-wrap{
  position: relative;
  flex: 1;
  min-width: 280px;
  max-width: 560px;
}
.aur-search{
  width: 100%;
  height: 56px;
  padding: 0 24px 0 56px;
  border-radius: 18px;
  border: 1px solid var(--au-border);
  background: var(--au-surface-strong);
  backdrop-filter: blur(var(--au-blur));
  -webkit-backdrop-filter: blur(var(--au-blur));
  color: var(--au-text-1);
  font-size: 16px;
  font-family: inherit;
  font-weight: 500;
  outline: none;
  transition: border-color .2s, box-shadow .2s, transform .15s;
}
.aur-search::placeholder{ color: var(--au-text-3); font-weight: 400; }
.aur-search:focus{
  border-color: var(--au-accent);
  box-shadow: 0 0 0 6px rgba(var(--au-glow-c), 0.12), 0 16px 40px rgba(var(--au-glow-c), 0.18);
  transform: translateY(-1px);
}
.aur-search-icon{
  position: absolute;
  inset-inline-start: 18px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--au-text-3);
  pointer-events: none;
  transition: color .2s;
}
.aur-search:focus ~ .aur-search-icon{ color: var(--au-accent); }
.aur-search-hint{
  position: absolute;
  inset-inline-end: 16px;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  gap: 4px;
  pointer-events: none;
}
.aur-kbd{
  font-family: ui-monospace, "SF Mono", "Cascadia Code", Menlo, monospace;
  font-size: 11px;
  font-weight: 700;
  padding: 3px 7px;
  border-radius: 6px;
  background: var(--au-surface-2);
  border: 1px solid var(--au-border);
  color: var(--au-text-3);
  letter-spacing: 0;
}

/* Filter chips */
.aur-chip{
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 40px;
  padding: 0 16px;
  border-radius: 14px;
  border: 1px solid var(--au-border);
  background: var(--au-surface);
  backdrop-filter: blur(var(--au-blur));
  -webkit-backdrop-filter: blur(var(--au-blur));
  color: var(--au-text-2);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  user-select: none;
  transition: border-color .2s, background .2s, color .2s;
}
.aur-chip:hover{
  border-color: var(--au-border-2);
  color: var(--au-text-1);
}
.aur-chip.is-active{
  background: linear-gradient(135deg, rgba(var(--au-glow-c),0.16), rgba(var(--au-glow-v),0.10));
  border-color: rgba(var(--au-glow-c), 0.4);
  color: var(--au-accent);
  box-shadow: 0 4px 20px rgba(var(--au-glow-c), 0.18);
}
.aur-chip select{
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}
.aur-chip__arrow{ opacity: .5; }
.aur-chip input[type="checkbox"]{
  width: 14px;
  height: 14px;
  accent-color: var(--au-accent);
  cursor: pointer;
}

.aur-btn{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 40px;
  padding: 0 16px;
  border-radius: 14px;
  font-size: 13px;
  font-weight: 700;
  font-family: inherit;
  cursor: pointer;
  white-space: nowrap;
  border: 1px solid var(--au-border);
  background: var(--au-surface);
  color: var(--au-text-1);
  backdrop-filter: blur(var(--au-blur));
  -webkit-backdrop-filter: blur(var(--au-blur));
  transition: background .2s, border-color .2s, transform .08s, box-shadow .2s;
}
.aur-btn:hover{ background: var(--au-surface-2); border-color: var(--au-border-2); }
.aur-btn:active{ transform: scale(.97); }
.aur-btn--primary{
  background: linear-gradient(135deg, var(--au-accent), var(--au-accent-2));
  border-color: transparent;
  color: #fff;
  box-shadow: 0 8px 24px rgba(var(--au-glow-c), 0.4);
}
.aur-btn--primary:hover{
  box-shadow: 0 12px 32px rgba(var(--au-glow-c), 0.55);
}

.aur-spacer{ flex: 1; min-width: 4px; }

/* ====== BENTO GRID ====== */
.aur-bento{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 18px;
  perspective: 1000px;
}

/* The card */
.aur-card{
  position: relative;
  padding: 20px;
  border-radius: var(--au-r-lg);
  background: var(--au-surface-strong);
  border: 1px solid var(--au-border);
  backdrop-filter: blur(var(--au-blur));
  -webkit-backdrop-filter: blur(var(--au-blur));
  cursor: pointer;
  overflow: hidden;
  transform-style: preserve-3d;
  will-change: transform;
  transition: border-color .25s, box-shadow .25s;
  contain: layout style;
  --tilt-x: 0deg;
  --tilt-y: 0deg;
  --mx: 50%;
  --my: 50%;
  transform: perspective(900px) rotateX(var(--tilt-x)) rotateY(var(--tilt-y));
}
.aur-card::before{
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(280px circle at var(--mx) var(--my), rgba(var(--au-glow-c), 0.16) 0%, transparent 50%);
  opacity: 0;
  transition: opacity .2s;
  border-radius: inherit;
}
.aur-card:hover::before{ opacity: 1; }
.aur-card:hover{
  border-color: rgba(var(--au-glow-c), 0.4);
  box-shadow: 0 20px 60px rgba(var(--au-glow-c), 0.18), 0 0 0 1px rgba(var(--au-glow-c), 0.2);
}
.aur-card--zero{
  border-color: rgba(239, 68, 68, 0.18);
}
.aur-card--zero:hover{
  border-color: rgba(239, 68, 68, 0.5);
  box-shadow: 0 20px 60px rgba(239, 68, 68, 0.18);
}
.aur-card--zero::before{
  background: radial-gradient(280px circle at var(--mx) var(--my), rgba(239, 68, 68, 0.16) 0%, transparent 50%);
}

.aur-card__head{
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 14px;
  position: relative;
  z-index: 1;
}
.aur-card__info{ min-width: 0; flex: 1; }
.aur-card__brand{
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--au-accent);
  margin-bottom: 4px;
}
.aur-card__model{
  font-size: 17px;
  font-weight: 800;
  color: var(--au-text-1);
  line-height: 1.25;
  letter-spacing: -0.02em;
  margin-bottom: 6px;
  word-break: break-word;
}
.aur-card__desc{
  font-size: 12px;
  color: var(--au-text-3);
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.aur-card__id{
  display: inline-block;
  margin-top: 8px;
  padding: 2px 8px;
  font-family: ui-monospace, "SF Mono", Menlo, monospace;
  font-size: 10px;
  color: var(--au-text-3);
  background: var(--au-surface-2);
  border-radius: 4px;
}

/* Big total */
.aur-card__total{
  flex-shrink: 0;
  text-align: center;
  min-width: 76px;
}
.aur-card__total-n{
  font-size: 36px;
  font-weight: 900;
  line-height: 1;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.04em;
  background: linear-gradient(135deg, var(--au-accent), var(--au-accent-2));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  transition: filter .25s;
}
.aur-card:hover .aur-card__total-n{
  filter: drop-shadow(0 0 12px rgba(var(--au-glow-c), 0.5));
}
.aur-card__total--zero .aur-card__total-n{
  background: linear-gradient(135deg, var(--au-bad), #f97316);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.aur-card__total-lbl{
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--au-text-3);
  margin-top: 4px;
}

/* Sparkline-style warehouse bar */
.aur-spark{
  position: relative;
  z-index: 1;
  display: flex;
  align-items: stretch;
  gap: 2px;
  height: 28px;
  border-radius: 8px;
  overflow: hidden;
  background: var(--au-surface-2);
  margin-bottom: 12px;
}
.aur-spark__seg{
  position: relative;
  flex: 1;
  background: var(--au-surface);
  transition: background .2s;
  cursor: help;
}
.aur-spark__seg::after{
  content: attr(data-label) " — " attr(data-qty);
  position: absolute;
  bottom: calc(100% + 6px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--au-text-1);
  color: var(--au-bg-base);
  font-size: 10px;
  font-weight: 700;
  padding: 4px 8px;
  border-radius: 5px;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity .15s;
  z-index: 10;
}
.aur-spark__seg:hover::after{ opacity: 1; }
.aur-spark__seg--has{ background: linear-gradient(180deg, var(--au-ok), color-mix(in srgb, var(--au-ok) 65%, transparent)); }
.aur-spark__seg--low{ background: linear-gradient(180deg, var(--au-warn), color-mix(in srgb, var(--au-warn) 65%, transparent)); }
.aur-spark__seg--zero{ background: transparent; }

/* WH chips below sparkline */
.aur-card__whs{
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 4px;
}
.aur-wh{
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 9px 4px;
  border-radius: 8px;
  background: var(--au-surface);
  transition: background .2s;
}
.aur-wh__lbl{
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.08em;
  color: var(--au-text-3);
}
.aur-wh__qty{
  font-size: 17px;
  font-weight: 900;
  color: var(--au-text-1);
  font-variant-numeric: tabular-nums;
  line-height: 1;
  letter-spacing: -0.02em;
}
.aur-wh--has{ background: rgba(16, 185, 129, 0.10); }
.aur-wh--has .aur-wh__qty{ color: var(--au-ok); }
.aur-wh--has .aur-wh__lbl{ color: var(--au-ok); opacity: 0.7; }
.aur-wh--low{ background: rgba(245, 158, 11, 0.10); }
.aur-wh--low .aur-wh__qty{ color: var(--au-warn); }
.aur-wh--low .aur-wh__lbl{ color: var(--au-warn); opacity: 0.7; }
.aur-wh--focus{
  box-shadow: 0 0 0 2px var(--au-accent);
}

/* Stagger-in animation */
@keyframes aur-card-in{
  from{ opacity: 0; transform: translateY(12px) perspective(900px); }
  to  { opacity: 1; transform: translateY(0) perspective(900px); }
}
.aur-card{ animation: aur-card-in .35s cubic-bezier(.2,.8,.2,1) both; }
.aur-card:nth-child(2){ animation-delay: .03s; }
.aur-card:nth-child(3){ animation-delay: .06s; }
.aur-card:nth-child(4){ animation-delay: .09s; }
.aur-card:nth-child(5){ animation-delay: .12s; }
.aur-card:nth-child(6){ animation-delay: .15s; }
.aur-card:nth-child(7){ animation-delay: .18s; }
.aur-card:nth-child(8){ animation-delay: .21s; }
.aur-card:nth-child(n+9){ animation-delay: .24s; }

/* Empty + loading states */
.aur-empty, .aur-loading{
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 80px 20px;
  gap: 14px;
  color: var(--au-text-3);
  text-align: center;
  border-radius: var(--au-r-lg);
  border: 1px dashed var(--au-border-2);
  background: var(--au-surface);
  backdrop-filter: blur(var(--au-blur));
  -webkit-backdrop-filter: blur(var(--au-blur));
}
.aur-empty__icon{
  width: 56px; height: 56px;
  border-radius: 50%;
  background: var(--au-surface-2);
  display: flex; align-items: center; justify-content: center;
  font-size: 24px;
  opacity: 0.6;
}
.aur-loading__bars{
  display: flex; gap: 6px;
}
.aur-loading__bars span{
  width: 6px; height: 32px;
  border-radius: 999px;
  background: var(--au-accent);
  animation: aur-bars 1s ease-in-out infinite;
}
.aur-loading__bars span:nth-child(2){ animation-delay: .15s; }
.aur-loading__bars span:nth-child(3){ animation-delay: .30s; }
.aur-loading__bars span:nth-child(4){ animation-delay: .45s; }
@keyframes aur-bars{
  0%, 100%{ transform: scaleY(0.4); opacity: 0.5; }
  50%{ transform: scaleY(1); opacity: 1; }
}

.aur-more{
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 18px;
  border-radius: var(--au-r);
  background: linear-gradient(135deg, rgba(var(--au-glow-c),0.10), rgba(var(--au-glow-v),0.06));
  border: 1px dashed rgba(var(--au-glow-c), 0.35);
  font-size: 13px;
  color: var(--au-text-2);
}
.aur-more b{ color: var(--au-accent); font-weight: 800; }

/* ====== SIDE SHEET (replaces modal) ====== */
.aur-sheet-back{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.45);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s;
  z-index: 998;
}
.aur-sheet-back.is-open{ opacity: 1; pointer-events: auto; }

.aur-sheet{
  position: fixed;
  top: 0;
  inset-inline-end: 0;
  height: 100vh;
  width: min(560px, 92vw);
  background: var(--au-surface-strong);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-inline-start: 1px solid var(--au-border-2);
  z-index: 999;
  transform: translateX(100%);
  transition: transform .35s cubic-bezier(.2,.8,.2,1);
  display: flex;
  flex-direction: column;
  box-shadow: -20px 0 60px rgba(0,0,0,0.4);
}
[dir="rtl"] .aur-sheet{ transform: translateX(-100%); }
.aur-sheet.is-open{ transform: translateX(0); }

.aur-sheet__head{
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 20px 22px;
  border-bottom: 1px solid var(--au-border);
  flex-shrink: 0;
}
.aur-sheet__title{
  margin: 0;
  font-size: 19px;
  font-weight: 800;
  color: var(--au-text-1);
  letter-spacing: -0.02em;
}
.aur-sheet__sub{
  font-size: 12px;
  color: var(--au-text-3);
  margin-top: 4px;
  font-family: ui-monospace, Menlo, monospace;
}
.aur-sheet__close{
  width: 36px; height: 36px;
  border-radius: 10px;
  background: var(--au-surface-2);
  border: 1px solid var(--au-border);
  color: var(--au-text-2);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .15s, color .15s;
  font-size: 16px;
}
.aur-sheet__close:hover{
  background: var(--au-bad);
  color: #fff;
  border-color: transparent;
}

.aur-sheet__body{
  padding: 18px 22px 24px;
  overflow-y: auto;
  flex: 1;
}

.aur-sheet__tools{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: flex-end;
  padding-bottom: 16px;
  margin-bottom: 16px;
  border-bottom: 1px solid var(--au-border);
}
.aur-field{ display: flex; flex-direction: column; gap: 5px; }
.aur-field label{
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--au-text-3);
}
.aur-field input,
.aur-field select{
  height: 36px;
  border: 1px solid var(--au-border);
  background: var(--au-surface);
  border-radius: 10px;
  padding: 0 12px;
  font-size: 13px;
  color: var(--au-text-1);
  outline: none;
  min-width: 130px;
  font-family: inherit;
}
.aur-field input:focus,
.aur-field select:focus{
  border-color: var(--au-accent);
  box-shadow: 0 0 0 3px rgba(var(--au-glow-c), 0.2);
}

.aur-pager{
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
  font-size: 12px;
  color: var(--au-text-3);
}
.aur-pager__nav{
  display: flex;
  align-items: center;
  gap: 6px;
}
.aur-pager__nav button{
  height: 30px;
  padding: 0 12px;
  border-radius: 8px;
  border: 1px solid var(--au-border);
  background: var(--au-surface);
  color: var(--au-text-2);
  cursor: pointer;
  font-size: 12px;
  font-family: inherit;
}
.aur-pager__nav button:hover{ background: var(--au-surface-2); color: var(--au-text-1); }
.aur-pager__nav button:disabled{ opacity: .4; cursor: not-allowed; }
.aur-pager__pill{
  padding: 4px 12px;
  border-radius: 8px;
  background: rgba(var(--au-glow-c), 0.16);
  color: var(--au-accent);
  font-weight: 800;
  font-size: 12px;
  font-variant-numeric: tabular-nums;
}

.aur-moves{
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.aur-move{
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  border-radius: 12px;
  background: var(--au-surface);
  border: 1px solid var(--au-border);
  transition: border-color .15s, background .15s;
}
.aur-move:hover{
  border-color: var(--au-border-2);
  background: var(--au-surface-2);
}
.aur-move__badge{
  width: 36px; height: 36px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  font-weight: 800;
}
.aur-move__badge--in{
  background: rgba(16, 185, 129, 0.16);
  color: var(--au-ok);
}
.aur-move__badge--out{
  background: rgba(239, 68, 68, 0.16);
  color: var(--au-bad);
}
.aur-move__badge--transfer{
  background: rgba(var(--au-glow-c), 0.16);
  color: var(--au-accent);
}
.aur-move__main{ min-width: 0; }
.aur-move__type{
  font-size: 13px;
  font-weight: 700;
  color: var(--au-text-1);
}
.aur-move__meta{
  font-size: 11px;
  color: var(--au-text-3);
  margin-top: 2px;
}
.aur-move__qty{
  font-size: 18px;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: var(--au-text-1);
  white-space: nowrap;
}
.aur-move--zero .aur-move__qty{ color: var(--au-text-3); }

.aur-mv-empty{
  padding: 60px 20px;
  text-align: center;
  color: var(--au-text-3);
  font-size: 13px;
}

/* ====== THEME TOGGLE (override placement) ====== */
.aur-theme-toggle{
  position: fixed;
  top: 22px;
  inset-inline-end: 22px;
  z-index: 1100;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--au-surface-strong);
  border: 1px solid var(--au-border-2);
  color: var(--au-text-1);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s, transform .2s, box-shadow .25s;
  box-shadow: 0 8px 24px rgba(0,0,0,.25);
}
.aur-theme-toggle:hover{
  transform: scale(1.08) rotate(15deg);
  box-shadow: 0 8px 32px rgba(var(--au-glow-c), 0.35);
}
.aur-theme-toggle svg{ width: 20px; height: 20px; }
.aur-theme-toggle .icon-sun{ display: none; }
.aur-theme-toggle .icon-moon{ display: block; }
:root[data-theme="light"] .aur-theme-toggle .icon-sun{ display: block; }
:root[data-theme="light"] .aur-theme-toggle .icon-moon{ display: none; }

/* ======================================================
   DASHBOARD — Aurora styling for db-* classes
   ====================================================== */

.aur-dash{
  position: relative;
  max-width: 1400px;
  margin: 0 auto;
  padding: 100px 24px 60px;
  z-index: 2;
}

/* Hero greeting */
.aur-dash-hello{
  font-size: 13px;
  font-weight: 700;
  color: var(--au-text-3);
  letter-spacing: 0.08em;
  margin-bottom: 4px;
}
.aur-dash-sync{
  margin: -16px 0 28px;
  font-size: 12px;
  color: var(--au-text-3);
  font-family: ui-monospace, Menlo, monospace;
}
.aur-dash-sync b{ color: var(--au-text-2); font-weight: 700; }

/* Sections */
.aur-dash-section{
  position: relative;
  margin-bottom: 24px;
  padding: 22px 24px;
  border-radius: var(--au-r-lg);
  background: var(--au-surface-strong);
  border: 1px solid var(--au-border);
  backdrop-filter: blur(var(--au-blur));
  -webkit-backdrop-filter: blur(var(--au-blur));
  overflow: hidden;
}
.aur-dash-section::before{
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg, rgba(var(--au-glow-c), 0.3), transparent 40%, rgba(var(--au-glow-v), 0.2));
  mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  mask-composite: exclude;
  -webkit-mask-composite: xor;
  pointer-events: none;
  opacity: 0.5;
}
.aur-dash-section > *{ position: relative; z-index: 1; }

.aur-dash-section__head{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.aur-dash-section__head h2{
  margin: 0;
  font-size: 18px;
  font-weight: 800;
  color: var(--au-text-1);
  letter-spacing: -0.02em;
}
.aur-dash-section__head h2::before{
  content: "";
  display: inline-block;
  width: 4px;
  height: 16px;
  background: linear-gradient(180deg, var(--au-accent), var(--au-accent-2));
  border-radius: 2px;
  margin-inline-end: 10px;
  vertical-align: middle;
}

/* 2-column grid */
.aur-dash-grid2{
  display: grid;
  grid-template-columns: 1.3fr 0.7fr;
  gap: 20px;
  margin-bottom: 24px;
}
.aur-dash-grid2 .aur-dash-section{ margin-bottom: 0; }

/* Live pulse badge */
.aur-pulse{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 4px 12px;
  border-radius: 999px;
  background: rgba(16, 185, 129, 0.12);
  color: var(--au-ok);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.aur-pulse::before{
  content: "";
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--au-ok);
  box-shadow: 0 0 0 0 var(--au-ok);
  animation: aur-pulse 1.8s cubic-bezier(0.66, 0, 0, 1) infinite;
}
@keyframes aur-pulse{
  0%{ box-shadow: 0 0 0 0 rgba(16,185,129,0.7); }
  100%{ box-shadow: 0 0 0 12px rgba(16,185,129,0); }
}

/* ====== Quick actions (db-q) — tilt cards ====== */
.db-quick{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 14px;
  perspective: 1000px;
}
.db-q{
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 10px;
  text-decoration: none;
  padding: 18px;
  border-radius: var(--au-r);
  background: var(--au-surface);
  border: 1px solid var(--au-border);
  color: var(--au-text-1);
  min-height: 130px;
  cursor: pointer;
  overflow: hidden;
  transform-style: preserve-3d;
  will-change: transform;
  --tilt-x: 0deg; --tilt-y: 0deg; --mx: 50%; --my: 50%;
  transform: perspective(900px) rotateX(var(--tilt-x)) rotateY(var(--tilt-y));
  transition: border-color .25s, box-shadow .25s;
  animation: aur-card-in .3s cubic-bezier(.2,.8,.2,1) both;
}
.db-q::before{
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(260px circle at var(--mx) var(--my), rgba(var(--au-glow-c), 0.18) 0%, transparent 50%);
  opacity: 0;
  transition: opacity .2s;
  border-radius: inherit;
}
.db-q:hover::before{ opacity: 1; }
.db-q:hover{
  border-color: rgba(var(--au-glow-c), 0.4);
  box-shadow: 0 16px 48px rgba(var(--au-glow-c), 0.18);
}
.db-q > *{ position: relative; z-index: 1; }
.db-q .ic{
  width: 42px; height: 42px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 12px;
  letter-spacing: 0.06em;
  background: linear-gradient(135deg, rgba(var(--au-glow-c), 0.18), rgba(var(--au-glow-v), 0.08));
  border: 1px solid rgba(var(--au-glow-c), 0.22);
  color: var(--au-accent);
}
.db-q .tt{
  font-weight: 800;
  font-size: 15px;
  color: var(--au-text-1);
  letter-spacing: -0.01em;
}
.db-q .dd{
  font-size: 12px;
  color: var(--au-text-3);
  line-height: 1.5;
}

/* ====== Rows (alerts, online, moves) ====== */
.db-empty{
  padding: 24px 14px;
  text-align: center;
  color: var(--au-text-3);
  font-size: 13px;
  border-radius: 12px;
  border: 1px dashed var(--au-border-2);
  background: var(--au-surface);
}
.db-row{
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 12px;
  background: var(--au-surface);
  border: 1px solid var(--au-border);
  margin-top: 8px;
  transition: border-color .15s, background .15s, transform .12s;
}
.db-row:hover{
  border-color: var(--au-border-2);
  background: var(--au-surface-2);
  transform: translateY(-1px);
}
.db-row .t{
  font-weight: 700;
  font-size: 13px;
  color: var(--au-text-1);
}
.db-row .s{
  font-size: 11.5px;
  color: var(--au-text-3);
  margin-top: 4px;
  line-height: 1.5;
}
.db-row .r{
  font-size: 11px;
  color: var(--au-text-3);
  white-space: nowrap;
  font-family: ui-monospace, Menlo, monospace;
}

/* Section titles inside alerts */
.dashSectionTitle{
  margin: 14px 0 8px;
  font-weight: 800;
  font-size: 13px;
  color: var(--au-text-2);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}
.dashGroup{
  margin: 12px 0;
  padding: 12px;
  border: 1px solid var(--au-border);
  border-radius: 12px;
  background: var(--au-surface);
}
.dashGroupHead{
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}
.dashGroupTitle{
  font-weight: 800;
  font-size: 12px;
  color: var(--au-accent);
  letter-spacing: 0.08em;
}
.dashGroupMeta{ font-size: 11px; color: var(--au-text-3); }

/* badges in rows */
.badge{
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
  background: var(--au-surface-2);
  color: var(--au-text-2);
  border: 1px solid var(--au-border);
  font-variant-numeric: tabular-nums;
}
.badge.warn{
  background: rgba(245, 158, 11, 0.16);
  color: var(--au-warn);
  border-color: transparent;
}
.badge.danger{ background: rgba(239, 68, 68, 0.16); color: var(--au-bad); border-color: transparent; }
.badge.ok{ background: rgba(16, 185, 129, 0.16); color: var(--au-ok); border-color: transparent; }

/* Online rows */
.db-online .db-row{
  background: rgba(16, 185, 129, 0.08);
  border-color: rgba(16, 185, 129, 0.18);
}
.db-online .db-row .r{
  color: var(--au-ok);
  font-weight: 700;
}
.db-online .db-row .r::before{
  content: "";
  display: inline-block;
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--au-ok);
  margin-inline-end: 6px;
  box-shadow: 0 0 0 2px rgba(16,185,129,0.3);
  animation: aur-pulse 1.8s cubic-bezier(0.66, 0, 0, 1) infinite;
  vertical-align: middle;
}

/* Moves grid */
.db-moves{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 10px;
}
.db-moves .db-row{ margin-top: 0; }

/* Btn small (legacy) */
.btn.sm{
  height: 30px;
  padding: 0 12px;
  font-size: 12px;
  border-radius: 8px;
  border: 1px solid var(--au-border);
  background: var(--au-surface);
  color: var(--au-text-2);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  font-weight: 700;
}
.btn.sm:hover{ background: var(--au-surface-2); color: var(--au-text-1); }
.btn.sm.primary{
  background: linear-gradient(135deg, var(--au-accent), var(--au-accent-2));
  border-color: transparent;
  color: #fff;
  box-shadow: 0 4px 16px rgba(var(--au-glow-c), 0.3);
}

/* ====== Quick stock search ====== */
.db-stock-search{
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}
.db-stock-search #dashStockQ{
  flex: 1;
  min-width: 240px;
  height: 44px;
  padding: 0 16px;
  border-radius: 12px;
  border: 1px solid var(--au-border);
  background: var(--au-surface);
  color: var(--au-text-1);
  font-size: 14px;
  font-family: inherit;
  outline: none;
}
.db-stock-search #dashStockQ:focus{
  border-color: var(--au-accent);
  box-shadow: 0 0 0 3px rgba(var(--au-glow-c), 0.2);
  background: var(--au-surface-2);
}
.db-stock-results{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 10px;
  margin-top: 14px;
}
.db-stock-card{
  padding: 14px;
  border-radius: 12px;
  background: var(--au-surface);
  border: 1px solid var(--au-border);
  transition: border-color .15s, transform .15s;
}
.db-stock-card:hover{
  border-color: var(--au-accent);
  transform: translateY(-1px);
}
.db-stock-card .title{
  font-weight: 800;
  font-size: 13px;
  color: var(--au-text-1);
}
.db-stock-card .meta{
  color: var(--au-text-3);
  font-size: 11.5px;
  margin-top: 5px;
}
.db-stock-card .meta b{ color: var(--au-accent); }
.db-wh-mini{
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 10px;
}
.db-wh-mini span{
  border: 1px solid var(--au-border);
  background: var(--au-surface-2);
  border-radius: 6px;
  padding: 3px 8px;
  font-size: 11px;
  color: var(--au-text-3);
  font-variant-numeric: tabular-nums;
}
.db-wh-mini b{ color: var(--au-text-1); font-weight: 800; }

/* ====== AI FAB + Panel (re-skin) ====== */
.ai-fab{
  position: fixed;
  inset-inline-end: 22px;
  bottom: 22px;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 20px 0 16px;
  height: 54px;
  border-radius: 999px;
  border: 1px solid rgba(var(--au-glow-v), 0.4);
  background: linear-gradient(135deg, var(--au-accent-2), var(--au-accent-3));
  color: #fff;
  font-size: 14px;
  font-weight: 800;
  cursor: pointer;
  z-index: 1200;
  box-shadow: 0 12px 40px rgba(var(--au-glow-v), 0.5);
  transition: transform .25s, box-shadow .25s;
}
.ai-fab:hover{
  transform: translateY(-2px) scale(1.03);
  box-shadow: 0 16px 50px rgba(var(--au-glow-v), 0.65);
}
.ai-fab-icon{ font-size: 18px; line-height: 1; }
.ai-fab.listening{
  background: linear-gradient(135deg, #dc2626, #b91c1c);
  animation: aur-pulse-fab .9s infinite;
}
.ai-fab.loading{ opacity: 0.75; cursor: wait; }
@keyframes aur-pulse-fab{
  0%, 100%{ box-shadow: 0 12px 40px rgba(220,38,38,.5); }
  50%{ box-shadow: 0 12px 56px rgba(220,38,38,.8); transform: translateY(-2px) scale(1.05); }
}

.ai-panel{
  position: fixed;
  inset-inline-end: 22px;
  bottom: 88px;
  width: min(440px, calc(100vw - 28px));
  border: 1px solid rgba(var(--au-glow-v), 0.3);
  background: var(--au-surface-strong);
  color: var(--au-text-1);
  border-radius: var(--au-r-lg);
  z-index: 1200;
  box-shadow: 0 32px 80px rgba(0,0,0,.5), 0 0 0 1px rgba(var(--au-glow-c), 0.08) inset;
  display: none;
  overflow: hidden;
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
}
.ai-panel[aria-hidden="false"]{ display: flex; flex-direction: column; animation: aur-card-in .25s; }

.ai-panel-head{
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 16px;
  border-bottom: 1px solid var(--au-border);
  background: linear-gradient(135deg, rgba(var(--au-glow-v), 0.10), rgba(var(--au-glow-c), 0.06));
}
.ai-panel-title{
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 800;
  font-size: 15px;
}
.ai-panel-dot{
  width: 9px; height: 9px;
  border-radius: 50%;
  background: var(--au-accent-2);
  box-shadow: 0 0 0 3px rgba(var(--au-glow-v), 0.25);
}
.ai-panel-dot.active{
  background: var(--au-ok);
  box-shadow: 0 0 0 3px rgba(16,185,129,.25);
  animation: dotPulse 1.5s infinite;
}
@keyframes dotPulse{ 50%{ box-shadow: 0 0 0 6px rgba(16,185,129,.12); } }
.ai-close{
  border: 0;
  background: var(--au-surface-2);
  color: inherit;
  width: 30px; height: 30px;
  border-radius: 8px;
  font-size: 14px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .15s, color .15s;
}
.ai-close:hover{ background: var(--au-bad); color: #fff; }

.ai-status{
  padding: 10px 16px;
  font-size: 12px;
  line-height: 1.5;
  color: var(--au-text-3);
  border-bottom: 1px solid var(--au-border);
  min-height: 36px;
}
.ai-input-row{
  display: flex;
  gap: 6px;
  align-items: center;
  padding: 10px;
  border-bottom: 1px solid var(--au-border);
}
.ai-text-input{
  flex: 1;
  min-width: 0;
  height: 40px;
  border-radius: 10px;
  border: 1px solid var(--au-border);
  background: var(--au-surface);
  color: inherit;
  padding: 0 12px;
  font-size: 13px;
  outline: none;
  direction: auto;
  font-family: inherit;
}
.ai-text-input:focus{
  border-color: var(--au-accent-2);
  background: var(--au-surface-2);
  box-shadow: 0 0 0 3px rgba(var(--au-glow-v), 0.15);
}
.ai-text-input::placeholder{ color: var(--au-text-3); }
.ai-send-btn, .ai-mic-btn{
  width: 40px; height: 40px;
  flex-shrink: 0;
  border-radius: 10px;
  border: 1px solid var(--au-border);
  background: var(--au-surface);
  color: inherit;
  font-size: 16px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .15s, border-color .15s;
}
.ai-send-btn:hover, .ai-mic-btn:hover{
  background: linear-gradient(135deg, rgba(var(--au-glow-v), 0.25), rgba(var(--au-glow-c), 0.15));
  border-color: rgba(var(--au-glow-v), 0.5);
}
.ai-mic-btn.recording{
  background: rgba(220,38,38,0.2);
  border-color: rgba(220,38,38,0.5);
  animation: aur-pulse-fab .9s infinite;
}
.ai-transcript{
  padding: 10px 16px;
  font-size: 12px;
  color: var(--au-text-3);
  border-bottom: 1px solid var(--au-border);
  display: none;
  font-style: italic;
}
.ai-answer{
  padding: 14px 16px;
  font-size: 14px;
  line-height: 1.75;
  font-weight: 600;
  display: none;
  border-bottom: 1px solid var(--au-border);
  color: var(--au-text-1);
}
.ai-alts{
  padding: 12px 14px;
  border-bottom: 1px solid var(--au-border);
}
.ai-alts-title{
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--au-warn);
  margin-bottom: 10px;
}
.ai-alts-list{ display: flex; flex-direction: column; gap: 6px; }
.ai-alt-card{
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(245, 158, 11, 0.22);
  background: rgba(245, 158, 11, 0.06);
  font-size: 12px;
}
.ai-alt-card .alt-name{ font-weight: 800; color: var(--au-text-1); }
.ai-alt-card .alt-qty{ color: var(--au-ok); font-size: 11px; margin-top: 4px; font-weight: 700; }

.ai-items{
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  max-height: 200px;
  overflow-y: auto;
}
.ai-item-card{
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--au-border);
  background: var(--au-surface);
  font-size: 12px;
}
.ai-item-card .ic-name{ font-weight: 800; color: var(--au-text-1); }
.ai-item-card .ic-total{
  display: inline-block;
  margin-top: 6px;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
  background: rgba(var(--au-glow-c), 0.18);
  color: var(--au-accent);
}
.ai-item-card .ic-total.zero{ background: rgba(239, 68, 68, 0.18); color: var(--au-bad); }

/* ====== Global <select> & <option> readability fix ====== */
/* Native dropdown options ينحلوا من المتصفح، فلازم نضبط الـ background/color صراحةً
   عشان تكون النصوص ظاهرة بالـ dark mode. */
body.aur-body select option,
body.aur-body select optgroup{
  background: #15182a !important;
  color: #f0f4ff !important;
  font-family: inherit;
  font-weight: 500;
}
:root[data-theme="light"] body.aur-body select option,
:root[data-theme="light"] body.aur-body select optgroup{
  background: #ffffff !important;
  color: #0b0d23 !important;
}
body.aur-body select option:hover,
body.aur-body select option:focus,
body.aur-body select option:checked{
  background: linear-gradient(0deg, rgba(6,182,212,0.35), rgba(6,182,212,0.35)) !important;
  color: #ffffff !important;
}
:root[data-theme="light"] body.aur-body select option:checked{
  background: linear-gradient(0deg, rgba(8,145,178,0.20), rgba(8,145,178,0.20)) !important;
  color: #0b0d23 !important;
}

/* الـ chip اللي بيغلف select (في stock + audit) — يخفي select بشكل صحيح بدون استخدام opacity:0 على option */
body.aur-body .aur-chip select{
  color-scheme: dark;
}
:root[data-theme="light"] body.aur-body .aur-chip select{
  color-scheme: light;
}

/* ====== Audit Timeline ====== */
.aur-timeline{ display: flex; flex-direction: column; gap: 4px; }
.aur-tl-day{
  font-size: 11px; font-weight: 800;
  color: var(--au-accent);
  letter-spacing: 0.06em; text-transform: uppercase;
  padding: 14px 4px 6px;
  border-bottom: 1px dashed var(--au-border);
  margin-bottom: 6px;
}
.aur-tl-day span{ color: var(--au-text-3); font-weight: 600; }
.aur-tl-row{
  display: grid;
  grid-template-columns: 70px 36px 1fr;
  gap: 12px;
  align-items: center;
  padding: 10px 12px;
  border-radius: 10px;
  background: var(--au-surface);
  border: 1px solid transparent;
  transition: border-color .15s, background .15s, transform .12s;
}
.aur-tl-row:hover{
  border-color: var(--au-border-2);
  background: var(--au-surface-2);
  transform: translateX(-3px);
}
[dir="rtl"] .aur-tl-row:hover{ transform: translateX(3px); }
.aur-tl-row--undo{ opacity: .65; background: rgba(245,158,11,0.05); }
.aur-tl-time{
  font-family: ui-monospace, Menlo, monospace;
  font-size: 11px; color: var(--au-text-3); text-align: center;
}
.aur-tl-badge{
  width: 36px; height: 36px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; font-weight: 800;
}
.aur-tl-badge.in{ background: rgba(16,185,129,0.18); color: var(--au-ok); }
.aur-tl-badge.out{ background: rgba(239,68,68,0.18); color: var(--au-bad); }
.aur-tl-badge.transfer{ background: rgba(6,182,212,0.18); color: var(--au-accent); }
.aur-tl-badge.other{ background: var(--au-surface-2); color: var(--au-text-3); }
.aur-tl-main{ min-width: 0; }
.aur-tl-title{
  display: flex; align-items: center; gap: 8px;
  flex-wrap: wrap;
}
.aur-tl-type{
  font-size: 10px; font-weight: 800;
  letter-spacing: 0.05em;
  padding: 2px 8px; border-radius: 4px;
  background: var(--au-surface-2);
  color: var(--au-text-2);
}
.aur-tl-item{
  font-weight: 700; font-size: 13.5px; color: var(--au-text-1);
}
.aur-tl-tag{
  font-size: 9.5px; font-weight: 800;
  padding: 2px 7px; border-radius: 999px;
  background: rgba(245,158,11,0.2);
  color: var(--au-warn);
  letter-spacing: 0.08em;
}
.aur-tl-meta{
  font-size: 11.5px; color: var(--au-text-3);
  margin-top: 4px;
  display: flex; gap: 12px; flex-wrap: wrap;
}
.aur-tl-meta b{ color: var(--au-text-1); }

/* ====== Activity Heatmap ====== */
.aur-heatmap{
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 8px;
  align-items: start;
  padding-top: 8px;
}
.aur-heatmap__months{
  grid-column: 2;
  display: grid;
  grid-template-columns: repeat(53, 1fr);
  font-size: 10px;
  color: var(--au-text-3);
  margin-bottom: 4px;
  pointer-events: none;
}
.aur-heatmap__dayslbl{
  display: flex; flex-direction: column;
  gap: 2px;
  font-size: 9px;
  color: var(--au-text-3);
}
.aur-heatmap__dayslbl span{ height: 10px; line-height: 10px; }
.aur-heatmap__grid{
  display: grid;
  grid-template-columns: repeat(53, 1fr);
  grid-template-rows: repeat(7, 10px);
  grid-auto-flow: column;
  gap: 2px;
}
.aur-heatmap__cell{
  width: 100%;
  background: var(--au-surface-2);
  border-radius: 2px;
  cursor: help;
  transition: transform .12s;
}
.aur-heatmap__cell:hover{ transform: scale(1.4); outline: 1px solid var(--au-text-1); }
.aur-heatmap__cell.l1{ background: rgba(6,182,212,0.25); }
.aur-heatmap__cell.l2{ background: rgba(6,182,212,0.45); }
.aur-heatmap__cell.l3{ background: rgba(6,182,212,0.70); }
.aur-heatmap__cell.l4{ background: rgba(6,182,212,1); box-shadow: 0 0 6px rgba(6,182,212,0.5); }
.aur-heatmap__legend{
  margin-top: 10px;
  display: flex; gap: 10px; align-items: center; justify-content: flex-end;
  font-size: 10px; color: var(--au-text-3);
}
.aur-heatmap__legend span{ display: flex; gap: 2px; }
.aur-heatmap__legend i{
  display: inline-block; width: 10px; height: 10px; border-radius: 2px;
}

/* ====== Favorites star button ====== */
.aur-card__actions{
  position: absolute;
  top: 12px; inset-inline-end: 12px;
  z-index: 2;
  display: flex;
  gap: 6px;
}
.aur-star, .aur-qrbtn{
  z-index: 2;
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--au-surface-2);
  border: 1px solid var(--au-border);
  color: var(--au-text-3);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all .15s;
  opacity: 0;
}
.aur-card:hover .aur-star{ opacity: 1; }
.aur-star:hover{
  background: rgba(251,191,36,0.18);
  border-color: var(--au-warn);
  color: var(--au-warn);
  transform: scale(1.12);
}
.aur-star.is-fav{
  opacity: 1;
  background: rgba(251,191,36,0.20);
  border-color: var(--au-warn);
  color: var(--au-warn);
  box-shadow: 0 0 12px rgba(251,191,36,0.4);
}
.aur-star svg{ width: 14px; height: 14px; fill: currentColor; }

.aur-qrbtn{
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--au-surface-2);
  border: 1px solid var(--au-border);
  color: var(--au-text-3);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all .15s;
  opacity: 0;
}
.aur-card:hover .aur-qrbtn{ opacity: 1; }
.aur-qrbtn:hover{
  background: rgba(6,182,212,0.18);
  border-color: var(--au-accent);
  color: var(--au-accent);
  transform: scale(1.12);
}
.aur-qrbtn svg{ width: 13px; height: 13px; }

/* Favorites section on dashboard */
.aur-favorites{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 10px;
}
.aur-fav{
  position: relative;
  display: block;
  padding: 12px 14px;
  border-radius: 12px;
  background: var(--au-surface);
  border: 1px solid var(--au-border);
  text-decoration: none;
  cursor: pointer;
  transition: all .15s;
}
.aur-fav:hover{
  border-color: var(--au-warn);
  background: var(--au-surface-2);
  box-shadow: 0 8px 24px rgba(251,191,36,0.15);
  transform: translateY(-1px);
}
.aur-fav__title{ font-weight: 800; font-size: 13px; color: var(--au-text-1); }
.aur-fav__sub{ font-size: 11px; color: var(--au-text-3); margin-top: 3px; }
.aur-fav__total{
  position: absolute; top: 10px; inset-inline-end: 10px;
  padding: 2px 8px; border-radius: 999px;
  background: linear-gradient(135deg, var(--au-accent), var(--au-accent-2));
  color: #fff; font-size: 11px; font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.aur-fav__total--zero{ background: var(--au-bad); }
.aur-fav__rm{
  position: absolute; bottom: 8px; inset-inline-end: 8px;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: transparent; border: none;
  color: var(--au-text-4);
  cursor: pointer; font-size: 13px;
  opacity: 0; transition: opacity .15s, color .15s;
}
.aur-fav:hover .aur-fav__rm{ opacity: 1; }
.aur-fav__rm:hover{ color: var(--au-bad); }

/* ====== Quick Add FAB ====== */
.aur-fab{
  position: fixed;
  inset-inline-end: 22px;
  bottom: 80px;
  z-index: 1150;
  width: 56px; height: 56px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--au-accent), var(--au-accent-2));
  border: none; color: #fff;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 12px 36px rgba(6,182,212,0.5);
  transition: transform .2s, box-shadow .2s;
}
.aur-fab:hover{
  transform: scale(1.08) rotate(90deg);
  box-shadow: 0 16px 44px rgba(6,182,212,0.65);
}
.aur-fab svg{ width: 24px; height: 24px; }

/* QR Modal */
.aur-qr-modal{ position: fixed; inset: 0; z-index: 2200; display: none; }
.aur-qr-modal.is-open{ display: block; }
.aur-qr-bd{
  position: absolute; inset: 0;
  background: rgba(5,6,20,0.65);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.aur-qr-panel{
  position: relative;
  width: min(420px, calc(100vw - 24px));
  margin: 8vh auto;
  background: var(--au-surface-strong);
  border: 1px solid var(--au-border-2);
  border-radius: 18px;
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  box-shadow: 0 28px 70px rgba(0,0,0,0.5);
  overflow: hidden;
  animation: aur-qr-in .2s cubic-bezier(.2,.8,.2,1);
}
@keyframes aur-qr-in{ from{ opacity:0; transform: scale(.95); } }
.aur-qr-head{
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px 18px;
  border-bottom: 1px solid var(--au-border);
}
.aur-qr-title{ font-weight: 800; font-size: 15px; color: var(--au-text-1); }
.aur-qr-body{ padding: 24px; text-align: center; }
.aur-qr-canvas{
  display: inline-block;
  padding: 14px;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 12px 36px rgba(6,182,212,0.2);
}
.aur-qr-info{
  margin-top: 16px;
  font-size: 13px; color: var(--au-text-2);
  line-height: 1.6;
}
.aur-qr-info b{ color: var(--au-text-1); }
.aur-qr-id{
  display: inline-block;
  margin-top: 8px;
  font-family: ui-monospace, Menlo, monospace;
  font-size: 11px;
  padding: 3px 8px;
  border-radius: 4px;
  background: var(--au-surface-2);
  color: var(--au-text-3);
}
.aur-qr-actions{
  display: flex; gap: 8px; flex-wrap: wrap;
  justify-content: center;
  padding: 0 18px 18px;
}

/* Print labels — hide everything except the label sheet */
@media print{
  body.aur-printing > *:not(.aur-print-sheet){ display: none !important; }
  .aur-aurora, .aur-theme-toggle, .notif-bell, .aur-fab, #pwaInstallBtn,
  .wm-topbar, .undo-toast{ display: none !important; }
  .aur-print-sheet{
    position: static !important;
    display: block !important;
    padding: 8mm;
    background: white !important;
    color: black !important;
  }
  .aur-print-label{
    page-break-inside: avoid;
    border: 1px solid #ddd;
    padding: 10mm;
    margin-bottom: 6mm;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 8mm;
    align-items: center;
    background: white !important;
    color: black !important;
  }
  .aur-print-label .name{ font-weight: 800; font-size: 16pt; }
  .aur-print-label .meta{ font-size: 10pt; color: #555; margin-top: 4pt; }
  .aur-print-label .id{ font-family: monospace; font-size: 10pt; color: #888; margin-top: 6pt; }
}
.aur-print-sheet{ display: none; }

/* ====== Predict (stockout) badge ====== */
.aur-predict{
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 8px;
  font-size: 10.5px; font-weight: 800;
  border-radius: 6px;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
}
.aur-predict--ok{ background: rgba(16,185,129,0.15); color: var(--au-ok); }
.aur-predict--warn{ background: rgba(245,158,11,0.18); color: var(--au-warn); }
.aur-predict--critical{
  background: rgba(239,68,68,0.18); color: var(--au-bad);
  animation: aur-blink 2s ease-in-out infinite;
}
.aur-predict--empty{ background: rgba(239,68,68,0.30); color: #fff; }
@keyframes aur-blink{ 50%{ opacity: 0.5; } }

/* ====== Density: compact mode for stock grid ====== */
body.aur-dense .aur-bento{
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 10px;
}
body.aur-dense .aur-card{
  padding: 12px;
  border-radius: 14px;
}
body.aur-dense .aur-card__head{ margin-bottom: 8px; gap: 10px; }
body.aur-dense .aur-card__model{ font-size: 14px; }
body.aur-dense .aur-card__brand{ font-size: 10px; margin-bottom: 2px; }
body.aur-dense .aur-card__desc{ -webkit-line-clamp: 1; font-size: 11px; }
body.aur-dense .aur-card__id{ display: none; }
body.aur-dense .aur-card__total{ min-width: 56px; }
body.aur-dense .aur-card__total-n{ font-size: 26px; }
body.aur-dense .aur-card__total-lbl{ font-size: 8px; margin-top: 2px; }
body.aur-dense .aur-spark{ height: 18px; margin-bottom: 8px; }
body.aur-dense .aur-card__whs{ gap: 4px; }
body.aur-dense .aur-wh{ padding: 7px 3px; gap: 3px; }
body.aur-dense .aur-wh__lbl{ font-size: 10px; }
body.aur-dense .aur-wh__qty{ font-size: 15px; }

/* ====== Dashboard charts ====== */
.aur-dash-charts{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 14px;
}
.aur-chart-card{
  background: var(--au-surface);
  border: 1px solid var(--au-border);
  border-radius: var(--au-r);
  padding: 14px;
  transition: border-color .2s;
}
.aur-chart-card:hover{ border-color: var(--au-border-2); }
.aur-chart-card__head{
  font-size: 12px;
  font-weight: 700;
  color: var(--au-text-3);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 12px;
}
.aur-chart-card__body{ min-height: 120px; }

/* ====== Responsive ====== */
@media (max-width: 900px){
  .aur-hero{ grid-template-columns: 1fr; gap: 16px; }
  .aur-quickstats{ justify-content: flex-start; }
  .aur-stock{ padding: 90px 16px 40px; }
  .aur-card__whs{ grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .aur-dash{ padding: 90px 16px 40px; }
  .aur-dash-grid2{ grid-template-columns: 1fr; }
}
@media (max-width: 560px){
  .aur-stock{ padding: 85px 12px 30px; }
  .aur-bento{ grid-template-columns: 1fr; }
  .aur-search{ height: 50px; font-size: 15px; }
  .aur-search-hint{ display: none; }
  .aur-card__whs{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .aur-aurora__blob{ filter: blur(60px); }
}

@media (prefers-reduced-motion: reduce){
  .aur-aurora__blob{ animation: none !important; }
  .aur-card{ animation: none !important; }
  *{ transition: none !important; }
}

/* ====================================================
   ✅ MOBILE PERFORMANCE OPTIMIZATIONS
   تطفّي الأشياء الـ GPU-heavy على التلفون لمنع الـ crash:
   - backdrop-filter: blur() (مكلف جداً على الموبايل)
   - filter: blur(80px) على blobs
   - 3D tilt + perspective
   - stagger animations
   ==================================================== */
@media (hover: none) and (max-width: 900px){
  /* Aurora blobs — قللها لـ blob واحد فقط، بدون blur ثقيل */
  .aur-aurora__blob--2,
  .aur-aurora__blob--3{ display: none !important; }
  .aur-aurora__blob--1{
    width: 400px !important; height: 400px !important;
    filter: blur(40px) !important;
    opacity: 0.3 !important;
    animation: none !important;
  }
  .aur-aurora::after{ display: none !important; }  /* noise grain */

  /* اقتل كل backdrop-filter — يستبدلوا بـ solid */
  *,
  *::before,
  *::after{
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  /* استبدل الـ surfaces الشفافة بـ solid background */
  body.aur-body .aur-card,
  body.aur-body .aur-dash-section,
  body.aur-body .stk-bar,
  body.aur-body .aur-bento .aur-card,
  body.aur-body .users-card,
  body.aur-body .u-card,
  body.aur-body .al-card,
  body.aur-body .aur-sheet,
  body.aur-body .aur-modal__panel,
  body.aur-body .stk-modal__panel,
  body.aur-body .u-modal__panel,
  body.aur-body .al-modal__panel,
  body.aur-body .ai-panel,
  body.aur-body .tc-cluster,
  body.aur-body .notif-panel,
  body.aur-body .stk-card,
  body.aur-body .lg-card{
    background: #15182a !important;
    border-color: #262b40 !important;
  }
  :root[data-theme="light"] body.aur-body .aur-card,
  :root[data-theme="light"] body.aur-body .aur-dash-section,
  :root[data-theme="light"] body.aur-body .stk-bar,
  :root[data-theme="light"] body.aur-body .aur-bento .aur-card,
  :root[data-theme="light"] body.aur-body .users-card,
  :root[data-theme="light"] body.aur-body .u-card,
  :root[data-theme="light"] body.aur-body .al-card,
  :root[data-theme="light"] body.aur-body .aur-sheet,
  :root[data-theme="light"] body.aur-body .stk-card,
  :root[data-theme="light"] body.aur-body .lg-card{
    background: #ffffff !important;
    border-color: #e6e8f0 !important;
  }

  /* اقتل 3D tilt + perspective على كل الكروت */
  .aur-bento{ perspective: none !important; }
  .aur-card{
    transform: none !important;
    transform-style: flat !important;
    will-change: auto !important;
  }
  .aur-card::before{ display: none !important; }  /* radial glow على hover */
  .db-quick{ perspective: none !important; }
  .db-q{
    transform: none !important;
    transform-style: flat !important;
    will-change: auto !important;
  }
  .db-q::before{ display: none !important; }

  /* اقتل stagger animations الثقيلة */
  .aur-card,
  .db-q{
    animation: none !important;
  }

  /* قللي تكاليف box-shadow */
  body.aur-body .aur-card:hover,
  body.aur-body .stk-card:hover,
  body.aur-body .db-q:hover,
  body.aur-body .u-card:hover{
    box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
    transform: none !important;
  }

  /* غير cursor glow — اقتله نهائياً لو موجود */
  .aur-cursor-glow{ display: none !important; }
}

/* للموبايل العادي (touch) برضو طبّق بعض الأشياء حتى لو > 900px */
@media (hover: none){
  .aur-cursor-glow{ display: none !important; }
  .aur-aurora__blob{ animation: none !important; }
}
