/* ═══════════════════════════════════════════
   VARIABLES & RESET
   ═══════════════════════════════════════════ */
:root {
  --bg: #0d1117; --bg-surface: #161b22; --bg-card: #1c2128;
  --bg-hover: #252c35; --border: #30363d; --border-active: #58a6ff;
  --text: #e6edf3; --text-muted: #8b949e; --text-faint: #6e7681;
  --accent: #58a6ff; --accent-glow: rgba(88,166,255,0.15);
  --green: #3fb950; --green-bg: rgba(63,185,80,0.1);
  --orange: #d29922; --orange-bg: rgba(210,153,34,0.1);
  --red: #f85149; --red-bg: rgba(248,81,73,0.1);
  --purple: #bc8cff; --purple-bg: rgba(188,140,255,0.1);
  --yellow: #e3b341; --cyan: #39d2c0; --cyan-bg: rgba(57,210,192,0.1);
  --pink: #f778ba; --pink-bg: rgba(247,120,186,0.1);
}
.light-mode {
  --bg: #f0f2f5; --bg-surface: #ffffff; --bg-card: #ffffff;
  --bg-hover: #f6f8fa; --border: #d8dee4; --border-active: #0969da;
  --text: #1f2328; --text-muted: #656d76; --text-faint: #8b949e;
  --accent: #0969da; --accent-glow: rgba(9,105,218,0.1);
  --green: #1a7f37; --green-bg: rgba(26,127,55,0.08);
  --orange: #9a6700; --orange-bg: rgba(154,103,0,0.08);
  --red: #cf222e; --red-bg: rgba(207,34,46,0.08);
  --purple: #8250df; --purple-bg: rgba(130,80,223,0.08);
  --yellow: #9a6700; --cyan: #0e8a7e; --cyan-bg: rgba(14,138,126,0.08);
  --pink: #bf3989; --pink-bg: rgba(191,57,137,0.08);
}
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;transition:background .3s,color .3s;}
.mono{font-family:'JetBrains Mono',monospace;}

/* ═══════════ HEADER ═══════════ */
header{background:var(--bg-surface);border-bottom:1px solid var(--border);padding:12px 24px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;backdrop-filter:blur(12px);flex-wrap:wrap;gap:8px;}
.logo{display:flex;align-items:center;gap:12px;font-weight:700;font-size:18px;letter-spacing:-.5px;}
.logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--accent),var(--purple));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;color:white;}
.header-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.search-box{display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:7px 14px;min-width:200px;transition:border-color .2s;}
.search-box:focus-within{border-color:var(--accent);}
.search-box input{background:none;border:none;color:var(--text);font-family:inherit;font-size:14px;outline:none;width:100%;}
.search-box input::placeholder{color:var(--text-faint);}

.btn{padding:8px 16px;border-radius:8px;border:1px solid var(--border);background:var(--bg-surface);color:var(--text);font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .2s;white-space:nowrap;}
.btn:hover{background:var(--bg-hover);border-color:var(--text-faint);}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent);}
.btn-primary:hover{opacity:.9;}
.btn-sm{padding:5px 10px;font-size:11px;border-radius:6px;}
.theme-toggle{width:36px;height:36px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .2s;}
.theme-toggle:hover{color:var(--text);border-color:var(--text-faint);}

/* ═══════════ TABS ═══════════ */
.tab-nav{display:flex;gap:2px;padding:8px 24px;background:var(--bg-surface);border-bottom:1px solid var(--border);}
.tab-btn{padding:8px 20px;border-radius:8px 8px 0 0;border:1px solid transparent;border-bottom:none;background:transparent;color:var(--text-muted);font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px;}
.tab-btn:hover{color:var(--text);background:var(--bg-hover);}
.tab-btn.active{color:var(--accent);background:var(--bg);border-color:var(--border);border-bottom:2px solid var(--accent);margin-bottom:-1px;}

.view-container{display:none;}.view-container.active{display:block;}

/* ═══════════ STATS BAR ═══════════ */
.stats-bar{display:flex;gap:8px;padding:10px 24px;background:var(--bg-surface);border-bottom:1px solid var(--border);overflow-x:auto;flex-wrap:wrap;}
.stat-chip{display:flex;align-items:center;gap:6px;padding:5px 12px;border-radius:20px;font-size:12px;font-weight:500;white-space:nowrap;border:1px solid var(--border);background:var(--bg);}
.stat-chip .count{font-family:'JetBrains Mono',monospace;font-weight:600;font-size:13px;}
.stat-new{color:var(--accent);border-color:var(--accent);background:var(--accent-glow);}
.stat-prep{color:var(--orange);border-color:var(--orange);background:var(--orange-bg);}
.stat-ready{color:var(--green);border-color:var(--green);background:var(--green-bg);}
.stat-done{color:var(--purple);border-color:var(--purple);background:var(--purple-bg);}
.stat-total{color:var(--text-muted);}

/* ═══════════ WEEK NAV ═══════════ */
.week-nav{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:var(--bg-surface);border-bottom:1px solid var(--border);flex-wrap:wrap;gap:8px;}
.week-nav-center{display:flex;align-items:center;gap:10px;}
.week-nav h2{font-size:17px;font-weight:700;letter-spacing:-.4px;min-width:280px;text-align:center;}
.calendar-views{display:flex;gap:4px;align-items:center;}
.week-filters{display:flex;gap:8px;flex-wrap:wrap;align-items:center;}
.filter-select{padding:6px 12px;border-radius:6px;border:1px solid var(--border);background:var(--bg-surface);color:var(--text);font-family:inherit;font-size:12px;cursor:pointer;outline:none;}
.filter-select:focus{border-color:var(--accent);}

/* ═══════════ WEEKLY BOARD ═══════════ */
.week-board{display:grid;grid-template-columns:repeat(7,1fr);gap:0;min-height:calc(100vh - 280px);border-top:1px solid var(--border);}
.day-column{border-right:1px solid var(--border);display:flex;flex-direction:column;min-width:0;transition:background .3s,box-shadow .3s;}
.day-column:last-child{border-right:none;}
.day-column:hover:not(.is-today):not(.is-weekend){background:rgba(255,200,50,0.03);box-shadow:inset 0 0 15px rgba(255,200,50,0.04);}
.day-column:hover:not(.is-today):not(.is-weekend) .day-header{background:rgba(255,200,50,0.07);transition:background .3s;}
.day-column:hover:not(.is-today):not(.is-weekend) .day-header-name{color:rgb(255,200,50);transition:color .2s;}
.day-column:hover:not(.is-today):not(.is-weekend) .day-header-date{color:var(--text);text-shadow:0 0 8px rgba(255,200,50,0.4);transition:text-shadow .3s;}
.day-column.is-today{background:rgba(88,166,255,0.03);border-left:2px solid var(--accent);border-right:2px solid var(--accent);box-shadow:inset 0 0 20px rgba(88,166,255,0.04);}
.day-column.is-today:hover{background:rgba(88,166,255,0.05);box-shadow:inset 0 0 25px rgba(88,166,255,0.07);}
.day-column.is-today .day-header{background:var(--accent-glow);border-bottom:2px solid var(--accent);}
.day-column.is-today .day-header-name{color:var(--accent);}
.day-column.is-today .day-header-date{color:var(--accent);}
.day-column.is-today .day-body{background:rgba(88,166,255,0.02);}
.day-column.is-weekend{opacity:.6;}
.day-column.is-weekend:hover{opacity:.85;transition:opacity .3s;}
.day-column.is-weekend .day-header{background:var(--bg-hover);}

/* Weekend collapse when empty */
.day-column.weekend-empty{max-width:42px;min-width:42px;cursor:pointer;transition:max-width .35s ease,min-width .35s ease,opacity .3s;}
.day-column.weekend-empty .day-header{padding:10px 4px;}
.day-column.weekend-empty .day-header-name{font-size:9px;letter-spacing:0;}
.day-column.weekend-empty .day-header-date{font-size:12px;}
.day-column.weekend-empty .day-header-routes,.day-column.weekend-empty .day-header-summary{display:none;}
.day-column.weekend-empty .day-header button{display:none;}
.day-column.weekend-empty .day-body{padding:2px;min-height:40px;}
.day-column.weekend-empty .day-body button{display:none;}
.day-column.weekend-empty::after{content:'⟩';position:absolute;bottom:8px;left:50%;transform:translateX(-50%);color:var(--text-faint);font-size:14px;opacity:.5;}
.day-column.weekend-empty{position:relative;}
.day-column.weekend-empty:hover{opacity:.8;}
.day-column.weekend-empty:hover::after{color:var(--accent);opacity:1;}
/* Expanded state */
.day-column.weekend-empty.weekend-expanded{max-width:none;min-width:0;}
.day-column.weekend-empty.weekend-expanded .day-header{padding:10px 10px;}
.day-column.weekend-empty.weekend-expanded .day-header-name{font-size:11px;letter-spacing:.8px;}
.day-column.weekend-empty.weekend-expanded .day-header-date{font-size:16px;}
.day-column.weekend-empty.weekend-expanded .day-header-routes,.day-column.weekend-empty.weekend-expanded .day-header-summary{display:flex;}
.day-column.weekend-empty.weekend-expanded .day-header button{display:flex;}
.day-column.weekend-empty.weekend-expanded .day-body{padding:6px;min-height:100px;}
.day-column.weekend-empty.weekend-expanded .day-body button{display:flex;}
.day-column.weekend-empty.weekend-expanded::after{display:none;}

.day-header{padding:10px 10px;border-bottom:2px solid var(--border);text-align:center;background:var(--bg-surface);position:sticky;top:0;z-index:10;}
.day-header-name{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);}
.day-header-date{font-family:'JetBrains Mono',monospace;font-size:16px;font-weight:700;margin:2px 0;}
.day-header-badge{font-size:9px;background:var(--accent);color:white;padding:1px 8px;border-radius:8px;font-weight:600;display:inline-block;}
.day-header-routes{display:flex;flex-wrap:wrap;gap:3px;justify-content:center;margin-top:4px;}
.day-route-pill{font-size:9px;padding:2px 6px;border-radius:4px;font-weight:600;}
.day-header-summary{font-size:10px;color:var(--text-faint);margin-top:4px;font-family:'JetBrains Mono',monospace;}

.day-body{flex:1;padding:6px;display:flex;flex-direction:column;gap:6px;overflow-y:auto;min-height:100px;transition:background .2s;cursor:pointer;}
.day-body:hover{background:rgba(88,166,255,0.03);}
.day-body.drag-over{background:var(--accent-glow);outline:2px dashed var(--accent);outline-offset:-4px;border-radius:4px;}

/* ═══════════ ORDER CARD ═══════════ */
.order-card{
  background:var(--bg-card);border:1px solid var(--border);border-radius:8px;
  padding:10px;cursor:grab;position:relative;font-size:12px;
  transition:all .35s cubic-bezier(.4,0,.2,1);
  overflow:hidden;
  transform-origin:center center;
}
.order-card:hover{
  border-color:var(--accent);
  box-shadow:0 0 0 1px var(--accent),0 20px 40px rgba(0,0,0,.35),0 8px 16px rgba(88,166,255,.15);
  z-index:20;
  transform:translateY(-6px) scale(1.03);
}
.light-mode .order-card:hover{
  box-shadow:0 0 0 1px var(--accent),0 20px 40px rgba(0,0,0,.12),0 8px 16px rgba(9,105,218,.1);
}
.order-card.dragging{opacity:.4;transform:rotate(2deg) scale(.95);}
.order-card.urgent{border-left:3px solid var(--red);}

/* ═══════════ URGENT EFFECT STYLES ═══════════ */
/* 1. Pulse Border */
.order-card.ue-active.ue-pulse-border{border:2px solid var(--red);animation:uePulseBorder 2s ease-in-out infinite;}
@keyframes uePulseBorder{
  0%,100%{border-color:var(--red);box-shadow:0 0 0 0 rgba(248,81,73,0.15);}
  50%{border-color:#f87171;box-shadow:0 0 16px 2px rgba(248,81,73,0.2);}
}
/* 2. Glow + Alert icon */
.order-card.ue-active.ue-glow{border:2px solid var(--red);animation:ueGlow 2s ease-in-out infinite;}
.order-card.ue-active.ue-glow .ue-icon{display:inline-flex;}
@keyframes ueGlow{
  0%,100%{box-shadow:0 0 12px rgba(248,81,73,0.35),0 0 24px rgba(248,81,73,0.15);}
  50%{box-shadow:0 0 20px rgba(248,81,73,0.5),0 0 40px rgba(248,81,73,0.25);}
}
/* 3. Bell shake */
.order-card.ue-active.ue-bell .ue-icon{display:inline-flex;}
.order-card.ue-active.ue-bell{border-left:4px solid var(--red);}
.ue-bell-svg{animation:ueBellShake .8s ease-in-out infinite;transform-origin:top center;}
@keyframes ueBellShake{
  0%{transform:rotate(0)}10%{transform:rotate(14deg)}20%{transform:rotate(-12deg)}
  30%{transform:rotate(10deg)}40%{transform:rotate(-8deg)}50%{transform:rotate(4deg)}60%,100%{transform:rotate(0)}
}
/* 4. Flame */
.order-card.ue-active.ue-flame .ue-icon{display:inline-flex;}
.order-card.ue-active.ue-flame{border-left:4px solid #ef4444;}
/* 5. Police strobe */
.order-card.ue-active.ue-police-strobe{animation:uePoliceStrobe .8s linear infinite;border:2px solid transparent;}
.order-card.ue-active.ue-police-strobe .ue-icon{display:inline-flex;}
.order-card.ue-active.ue-police-strobe::before,.order-card.ue-active.ue-police-strobe::after{
  content:'';position:absolute;top:0;width:4px;height:100%;z-index:2;transition:all .1s;pointer-events:none;
}
.order-card.ue-active.ue-police-strobe::before{left:0;}
.order-card.ue-active.ue-police-strobe::after{right:0;}
@keyframes uePoliceStrobe{
  0%,100%{box-shadow:-4px 0 16px rgba(37,99,235,0.4),4px 0 16px rgba(248,81,73,0.1);}
  50%{box-shadow:-4px 0 16px rgba(37,99,235,0.1),4px 0 16px rgba(248,81,73,0.4);}
}
/* 6. Police bar */
.order-card.ue-active.ue-police-bar{border:2px solid #334155;padding-top:28px !important;padding-bottom:28px !important;}
.order-card.ue-active.ue-police-bar .ue-police-lightbar{display:flex !important;}
.ue-police-lightbar{
  display:none !important;position:absolute;left:0;right:0;height:22px;
  background:#0f172a;align-items:center;justify-content:center;gap:3px;padding:0 8px;
  z-index:3;
}
.ue-police-lightbar.ue-bar-top{top:0;border-bottom:1px solid #334155;border-radius:6px 6px 0 0;}
.ue-police-lightbar.ue-bar-bottom{bottom:0;border-top:1px solid #334155;border-radius:0 0 6px 6px;}
.ue-led{width:14px;height:6px;border-radius:3px;transition:all .15s;}
.ue-led-blue{background:rgba(59,130,246,0.15);}
.ue-led-blue.on{background:#3b82f6;box-shadow:0 0 8px #3b82f6;}
.ue-led-red{background:rgba(248,81,73,0.15);}
.ue-led-red.on{background:#f85149;box-shadow:0 0 8px #f85149;}
.ue-led-center{width:10px;height:10px;border-radius:50%;background:#f8fafc;animation:ueCenterFlash .3s linear infinite;}
@keyframes ueCenterFlash{0%,100%{opacity:.4}50%{opacity:1}}
/* 7. Fire gradient */
.order-card.ue-active.ue-fire-gradient{
  border:3px solid transparent !important;
  background-image:linear-gradient(var(--bg-card),var(--bg-card)),linear-gradient(90deg,#dc2626,#f97316,#fbbf24,#f97316,#dc2626) !important;
  background-origin:border-box !important;background-clip:padding-box,border-box !important;
  background-size:100% 100%,200% 100% !important;animation:ueFireShift 2s linear infinite !important;
}
.order-card.ue-active.ue-fire-gradient .ue-icon{display:inline-flex;}
@keyframes ueFireShift{0%{background-position:0 0,0% center}100%{background-position:0 0,200% center}}
/* 8. Fire engine */
.order-card.ue-active.ue-fire-engine{border:2px solid var(--red);animation:ueFireFlash 1.5s ease-in-out infinite;}
.order-card.ue-active.ue-fire-engine .ue-icon{display:inline-flex;}
.order-card.ue-active.ue-fire-engine .ue-stripe-top,.order-card.ue-active.ue-fire-engine .ue-stripe-bottom{display:block !important;}
.ue-stripe-top,.ue-stripe-bottom{
  display:none !important;position:absolute;left:0;right:0;height:4px;z-index:2;pointer-events:none;
  background:linear-gradient(90deg,#fbbf24,#fde68a,#fbbf24);background-size:200% 100%;
  animation:ueReflective 2s linear infinite;
}
.ue-stripe-top{top:0;border-radius:6px 6px 0 0;}
.ue-stripe-bottom{bottom:0;border-radius:0 0 6px 6px;}
@keyframes ueFireFlash{
  0%,100%{box-shadow:0 0 0 0 rgba(248,81,73,0);border-color:var(--red);}
  15%{box-shadow:0 0 20px 4px rgba(248,81,73,0.3);border-color:#ef4444;}
  30%{box-shadow:0 0 0 0 rgba(248,81,73,0);border-color:var(--red);}
  45%{box-shadow:0 0 20px 4px rgba(248,81,73,0.3);border-color:#ef4444;}
  60%,100%{box-shadow:0 0 0 0 rgba(248,81,73,0);border-color:var(--red);}
}
@keyframes ueReflective{0%{background-position:-200% center}100%{background-position:200% center}}
/* 9. Construction barricade - yellow/black stripes */
.order-card.ue-active.ue-barricade{
  border:none !important;padding:10px !important;position:relative;z-index:1;
  background:var(--bg-card) !important;
}
.order-card.ue-active.ue-barricade::before{
  content:'';position:absolute;inset:-5px;z-index:-1;border-radius:12px;
  background:repeating-linear-gradient(
    -45deg,
    #f59e0b 0px,#f59e0b 12px,
    #111 12px,#111 24px
  );
  background-size:200% 200%;
  animation:ueBarricadeMove 0.8s linear infinite;
}
.order-card.ue-active.ue-barricade::after{
  content:'';position:absolute;inset:0;border-radius:8px;
  background:var(--bg-card);z-index:-1;
}
.order-card.ue-active.ue-barricade:hover{
  border:none !important;
  box-shadow:0 0 24px rgba(245,158,11,0.4),0 0 48px rgba(245,158,11,0.15) !important;
  transform:translateY(-6px) scale(1.03);
}
.order-card.ue-active.ue-barricade:hover::before{
  inset:-6px;
  filter:brightness(1.2);
}
.order-card.ue-active.ue-barricade .ue-icon{display:inline-flex !important;}

/* Matrix effect */
.order-card.ue-active.ue-matrix{
  border:1.5px solid rgba(0,255,65,0.25) !important;
  background:transparent !important;
  animation:ueMatrixGlow 2s ease-in-out infinite;
  overflow:hidden;
}
@keyframes ueMatrixGlow{
  0%,100%{box-shadow:0 0 6px rgba(0,255,65,0.15),inset 0 0 8px rgba(0,255,65,0.03);}
  50%{box-shadow:0 0 14px rgba(0,255,65,0.25),inset 0 0 12px rgba(0,255,65,0.06);}
}
.order-card.ue-active.ue-matrix .ue-matrix-canvas{display:block !important;}
.ue-matrix-canvas{display:none !important;position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;border-radius:6px;pointer-events:none;}
.order-card.ue-active.ue-matrix .card-row,
.order-card.ue-active.ue-matrix .card-client,
.order-card.ue-active.ue-matrix .status-select,
.order-card.ue-active.ue-matrix .card-total,
.order-card.ue-active.ue-matrix .mini-card-corner,
.order-card.ue-active.ue-matrix>div:not(.ue-matrix-canvas){
  position:relative;z-index:1;
}
.order-card.ue-active.ue-matrix .card-row{background:rgba(13,17,23,0.55);border-radius:3px;padding:1px 4px;margin:-1px -3px 3px;}
.order-card.ue-active.ue-matrix>div:nth-child(3){background:rgba(13,17,23,0.5);border-radius:3px;padding:1px 4px;margin:0 -3px 3px;}
.order-card.ue-active.ue-matrix>div:nth-child(4){background:rgba(13,17,23,0.5);border-radius:3px;padding:2px 4px;margin:0 -3px 0;}
.order-card.ue-active.ue-matrix .ue-icon{display:inline-flex !important;}

/* Glassmorphism shared */
.ue-glass-blobs{display:none !important;position:absolute;inset:0;overflow:hidden;border-radius:6px;z-index:0;pointer-events:none;}
.ue-glass-surface{display:none !important;position:absolute;inset:0;border-radius:6px;z-index:1;pointer-events:none;backdrop-filter:blur(14px) saturate(1.4);-webkit-backdrop-filter:blur(14px) saturate(1.4);}
.ue-glass-streak{display:none !important;position:absolute;inset:0;overflow:hidden;border-radius:6px;z-index:2;pointer-events:none;}
.ue-glass-streak>div{position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,0.06) 45%,rgba(255,255,255,0.13) 50%,rgba(255,255,255,0.06) 55%,transparent 60%);animation:ueGlassSweep 4s ease-in-out infinite;}
.ue-glass-highlight{display:none !important;position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.25),transparent);z-index:3;pointer-events:none;}
.ue-glass-blob{position:absolute;border-radius:50%;pointer-events:none;}
.ue-glass-blob.b1{width:110px;height:110px;top:-20px;left:-20px;background:radial-gradient(circle,rgba(139,92,246,0.5) 0%,transparent 70%);animation:ueBlobF1 6s ease-in-out infinite;}
.ue-glass-blob.b2{width:90px;height:90px;bottom:-15px;right:-15px;background:radial-gradient(circle,rgba(59,130,246,0.4) 0%,transparent 70%);animation:ueBlobF2 7s ease-in-out infinite;}
.ue-glass-blob.b3{width:70px;height:70px;top:40%;left:50%;background:radial-gradient(circle,rgba(236,72,153,0.35) 0%,transparent 70%);animation:ueBlobF3 5s ease-in-out infinite;}
@keyframes ueBlobF1{0%,100%{transform:translate(0,0) scale(1);}33%{transform:translate(30px,20px) scale(1.1);}66%{transform:translate(-10px,30px) scale(.95);}}
@keyframes ueBlobF2{0%,100%{transform:translate(0,0) scale(1);}33%{transform:translate(-25px,-15px) scale(1.15);}66%{transform:translate(15px,-25px) scale(.9);}}
@keyframes ueBlobF3{0%,100%{transform:translate(-50%,-50%) scale(1);}50%{transform:translate(-30%,-60%) scale(1.2);}}
@keyframes ueGlassSweep{0%{left:-100%;}40%,100%{left:200%;}}
@keyframes ueGlassGlow{0%,100%{box-shadow:0 6px 24px rgba(0,0,0,0.25),inset 0 1px 0 rgba(255,255,255,0.1),0 0 0 0 rgba(139,92,246,0);}50%{box-shadow:0 6px 24px rgba(0,0,0,0.25),inset 0 1px 0 rgba(255,255,255,0.1),0 0 18px rgba(139,92,246,0.08);}}

/* Glass Light */
.order-card.ue-active.ue-glass-light{
  background:rgba(255,255,255,0.07) !important;
  border:1px solid rgba(255,255,255,0.12) !important;
  overflow:hidden;animation:ueGlassGlow 3s ease-in-out infinite;
}
.order-card.ue-active.ue-glass-light .ue-glass-blobs,
.order-card.ue-active.ue-glass-light .ue-glass-surface,
.order-card.ue-active.ue-glass-light .ue-glass-streak,
.order-card.ue-active.ue-glass-light .ue-glass-highlight{display:block !important;}
.order-card.ue-active.ue-glass-light .ue-glass-surface{background:rgba(255,255,255,0.04);}
.order-card.ue-active.ue-glass-light>div:not(.ue-glass-blobs):not(.ue-glass-surface):not(.ue-glass-streak):not(.ue-glass-highlight),
.order-card.ue-active.ue-glass-light>.card-row,
.order-card.ue-active.ue-glass-light>.mini-card-corner,
.order-card.ue-active.ue-glass-light>select{position:relative;z-index:3;}
.order-card.ue-active.ue-glass-light .card-client{text-shadow:0 1px 3px rgba(0,0,0,0.3);}
.order-card.ue-active.ue-glass-light .ue-icon{display:inline-flex !important;}

/* Glass Dark */
.order-card.ue-active.ue-glass-dark{
  background:rgba(15,20,30,0.45) !important;
  border:1px solid rgba(255,255,255,0.1) !important;
  overflow:hidden;animation:ueGlassGlow 3s ease-in-out infinite;
}
.order-card.ue-active.ue-glass-dark .ue-glass-blobs,
.order-card.ue-active.ue-glass-dark .ue-glass-surface,
.order-card.ue-active.ue-glass-dark .ue-glass-streak,
.order-card.ue-active.ue-glass-dark .ue-glass-highlight{display:block !important;}
.order-card.ue-active.ue-glass-dark .ue-glass-surface{background:rgba(15,20,30,0.35);}
.order-card.ue-active.ue-glass-dark>div:not(.ue-glass-blobs):not(.ue-glass-surface):not(.ue-glass-streak):not(.ue-glass-highlight),
.order-card.ue-active.ue-glass-dark>.card-row,
.order-card.ue-active.ue-glass-dark>.mini-card-corner,
.order-card.ue-active.ue-glass-dark>select{position:relative;z-index:3;}
.order-card.ue-active.ue-glass-dark .card-client{text-shadow:0 1px 3px rgba(0,0,0,0.4);}
.order-card.ue-active.ue-glass-dark .ue-icon{display:inline-flex !important;}
@keyframes ueBarricadeMove{
  0%{background-position:0 0;}
  100%{background-position:33.94px 33.94px;}
}

/* Common: ue-icon base style */
.ue-icon{display:inline-flex;align-items:center;margin-right:4px;}
.ue-pick-opt{cursor:pointer;padding:6px 10px;border-radius:6px;border:1px solid var(--border);font-size:11px;transition:all .15s;background:var(--bg);color:var(--text-muted);display:flex;align-items:center;gap:6px;}
.ue-pick-opt:hover{background:var(--bg-hover);border-color:var(--text-faint);}
.ue-pick-opt.active{background:var(--accent);color:white;border-color:var(--accent);}
.ue-picker-btn{width:32px;height:32px;border-radius:6px;border:1px solid var(--border);background:var(--bg-surface);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .2s;position:relative;}
.ue-picker-btn:hover,.ue-picker-btn.has-effect{border-color:var(--accent);background:var(--accent-bg);transform:scale(1.1);}
.ue-picker-btn.has-effect::after{content:'';position:absolute;top:-2px;right:-2px;width:8px;height:8px;border-radius:50%;background:var(--accent);border:2px solid var(--bg-surface);}
.ue-picker-dropdown{display:none;position:absolute;bottom:calc(100% + 6px);right:0;background:var(--bg-surface);border:1px solid var(--border);border-radius:10px;padding:8px;z-index:300;min-width:240px;max-height:320px;overflow-y:auto;box-shadow:0 12px 32px rgba(0,0,0,.5);flex-direction:column;gap:4px;}
.ue-picker-dropdown.open{display:flex;}
.ue-picker-header{font-size:10px;font-weight:700;color:var(--text-faint);text-transform:uppercase;letter-spacing:.6px;padding:2px 6px 4px;}
/* Urgent effect badge pulse for pulse-border */
.order-card.ue-active.ue-pulse-border .tag-priority-urgente{animation:ueBadgePulse 2s ease-in-out infinite;}
@keyframes ueBadgePulse{0%,100%{opacity:1}50%{opacity:.6}}

/* Corner indicator (visual only, hover drives expand) */
.card-expand-corner{
  position:absolute;top:0;right:0;width:24px;height:24px;z-index:5;pointer-events:none;
}
.card-expand-corner::before{
  content:'';position:absolute;top:0;right:0;
  width:0;height:0;
  border-style:solid;border-width:0 24px 24px 0;
  border-color:transparent var(--accent) transparent transparent;
  opacity:0;transition:opacity .3s,border-width .3s;border-radius:0 7px 0 0;
}
.order-card:hover .card-expand-corner::before{opacity:.7;border-width:0 28px 28px 0;}
.card-expand-corner .expand-icon{
  position:relative;z-index:1;font-size:9px;color:white;
  margin-top:-5px;margin-right:-3px;transition:transform .35s;font-weight:700;
  opacity:0;transition:opacity .3s,transform .35s;
  display:flex;align-items:center;justify-content:center;width:100%;height:100%;
}
.order-card:hover .card-expand-corner .expand-icon{opacity:1;transform:rotate(180deg);}

/* Collapsed state - content clipping (hover to reveal) */
.card-collapsible{
  max-height:0;overflow:hidden;opacity:0;
  transition:max-height .4s cubic-bezier(.4,0,.2,1),opacity .35s ease,margin .3s ease;
  margin-top:0;
}
.order-card:hover .card-collapsible{
  max-height:600px;opacity:1;margin-top:4px;
}

/* Shimmer pulse on status change */
@keyframes statusPulse{
  0%{box-shadow:0 0 0 0 var(--accent);}
  50%{box-shadow:0 0 0 6px transparent;}
  100%{box-shadow:0 0 0 0 transparent;}
}
.order-card.pulse{animation:statusPulse .6s ease;}

/* Card inner elements */
.card-row{display:flex;justify-content:space-between;align-items:center;gap:4px;}
.card-client{font-weight:700;font-size:13px;letter-spacing:-.2px;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.card-id{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text-faint);}
.card-tags{display:flex;gap:4px;flex-wrap:wrap;margin:4px 0;}
.tag{font-size:9px;padding:2px 6px;border-radius:4px;font-weight:600;white-space:nowrap;}
.tag-type{background:var(--bg);color:var(--text-muted);}
.tag-route{font-weight:600;}
.tag-channel{background:var(--bg);color:var(--text-faint);}
.tag-priority-urgente{background:var(--red-bg);color:var(--red);}
.tag-priority-normal{background:var(--accent-glow);color:var(--accent);}

.card-products{font-size:11px;color:var(--text-muted);line-height:1.4;max-height:36px;overflow:hidden;margin:4px 0;transition:max-height .4s;}
.order-card:hover .card-products{max-height:none;}
.card-obs{font-size:10px;color:var(--orange);font-style:italic;padding:3px 6px;background:var(--orange-bg);border-radius:4px;margin:4px 0;}
.card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:6px;border-top:1px solid var(--border);margin-top:4px;}
.card-total{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:700;color:var(--green);}
.card-address{font-size:10px;color:var(--text-faint);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:120px;}
.order-card:hover .card-address{white-space:normal;max-width:none;}

/* Status selector on card */
.status-select{font-size:10px;padding:3px 6px;border-radius:5px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-family:inherit;cursor:pointer;outline:none;font-weight:600;max-width:110px;transition:all .2s;}
.status-select:focus{border-color:var(--accent);}
.status-nuevo{border-color:var(--accent);color:var(--accent);}
.status-preparacion{border-color:var(--orange);color:var(--orange);}
.status-listo{border-color:var(--green);color:var(--green);}
.status-entregado{border-color:var(--purple);color:var(--purple);}

/* Card action buttons */
.card-actions{display:flex;gap:3px;margin-top:6px;}
.card-act{width:26px;height:24px;border-radius:5px;border:1px solid var(--border);background:var(--bg);color:var(--text-faint);font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;padding:0;}
.card-act:hover{border-color:var(--text-muted);color:var(--text);background:var(--bg-hover);transform:scale(1.1);}
.card-act.del:hover{border-color:var(--red);color:var(--red);background:var(--red-bg);}

/* Role restrictions */
.role-viewer .btn-primary,.role-viewer .card-act,.role-viewer .card-act.del{display:none !important;}
.role-viewer .status-select{pointer-events:none;opacity:.7;}
.role-driver .card-act.del{display:none !important;}

/* Dropdown menu */
.dropdown-wrap{position:relative;}
.dropdown-wrap .dropdown-menu{display:none;position:absolute;top:100%;right:0;margin-top:6px;background:var(--bg-surface);border:1px solid var(--border);border-radius:10px;padding:6px;min-width:240px;z-index:500;box-shadow:0 8px 24px rgba(0,0,0,.25);}
.dropdown-wrap:hover .dropdown-menu{display:block;}
.dropdown-item{padding:8px 12px;border-radius:6px;font-size:12px;cursor:pointer;transition:background .15s;color:var(--text);white-space:nowrap;}
.dropdown-item:hover{background:var(--bg-hover);}
.dropdown-danger{color:var(--red);}
.dropdown-danger:hover{background:rgba(248,81,73,.1);}
.dropdown-sep{height:1px;background:var(--border);margin:4px 8px;}

/* Mini card expand for compact views */
.mini-card-corner{
  position:absolute;top:0;right:0;width:18px;height:18px;z-index:5;pointer-events:none;
}
.mini-card-corner::before{
  content:'';position:absolute;top:0;right:0;width:0;height:0;
  border-style:solid;border-width:0 18px 18px 0;
  border-color:transparent var(--accent) transparent transparent;
  opacity:0;transition:opacity .25s;border-radius:0 7px 0 0;
}
.order-card:hover .mini-card-corner::before{opacity:.6;}

/* ═══════════ MODALS ═══════════ */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:none;align-items:center;justify-content:center;z-index:1000;backdrop-filter:blur(4px);}
.modal-overlay.active{display:flex;}
.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:16px;width:580px;max-width:95vw;max-height:90vh;overflow-y:auto;padding:24px;box-shadow:0 24px 64px rgba(0,0,0,.4);animation:modalIn .2s ease;}
@keyframes modalIn{from{opacity:0;transform:translateY(20px) scale(.97);}to{opacity:1;transform:translateY(0) scale(1);}}
.modal h2{font-size:18px;font-weight:700;margin-bottom:16px;letter-spacing:-.4px;display:flex;align-items:center;gap:10px;}
.form-row{margin-bottom:12px;}
.form-row label{display:block;font-size:11px;font-weight:600;color:var(--text-muted);margin-bottom:3px;text-transform:uppercase;letter-spacing:.5px;}
.form-row input,.form-row select,.form-row textarea{width:100%;padding:9px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-family:inherit;font-size:13px;outline:none;transition:border-color .2s;}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--accent);}
.form-row textarea{resize:vertical;min-height:50px;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;}
.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px;padding-top:14px;border-top:1px solid var(--border);}

/* ═══════════ ROUTE CONFIG ═══════════ */
.route-config-list{max-height:380px;overflow-y:auto;}
.route-config-item{display:flex;align-items:center;gap:12px;padding:10px;border:1px solid var(--border);border-radius:8px;margin-bottom:6px;background:var(--bg);}
.route-color-dot{width:14px;height:14px;border-radius:4px;flex-shrink:0;}
.route-name-text{font-weight:600;font-size:13px;flex:1;}
.route-day-pills{display:flex;gap:3px;}
.route-day-pill{width:28px;height:26px;border-radius:5px;border:1px solid var(--border);background:var(--bg-surface);color:var(--text-muted);font-size:10px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;font-family:inherit;padding:0;}
.route-day-pill.active{background:var(--accent);color:white;border-color:var(--accent);}
.route-day-pill:hover:not(.active){border-color:var(--text-faint);color:var(--text);}

/* ═══════════ CALENDAR VIEW ═══════════ */
.calendar-wrapper{padding:16px 24px;}
.calendar-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:12px;}
.calendar-nav{display:flex;align-items:center;gap:8px;}
.calendar-nav h2{font-size:20px;font-weight:700;letter-spacing:-.5px;min-width:240px;text-align:center;}
.calendar-views{display:flex;gap:4px;}
.cal-view-btn{padding:6px 14px;border-radius:6px;border:1px solid var(--border);background:var(--bg-surface);color:var(--text-muted);font-family:inherit;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;}
.cal-view-btn:hover{color:var(--text);}
.cal-view-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);}
.calendar-grid{display:grid;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--bg-surface);}
.calendar-grid.view-day{grid-template-columns:1fr;}
.calendar-grid.view-week{grid-template-columns:repeat(5,1fr);}
.calendar-grid.view-biweek{grid-template-columns:repeat(5,1fr);}
.calendar-grid.view-month{grid-template-columns:repeat(7,1fr);}
.cal-header-cell{padding:10px 12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);background:var(--bg-hover);border-bottom:1px solid var(--border);text-align:center;}
.cal-cell{min-height:130px;padding:8px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);transition:background .2s;position:relative;display:flex;flex-direction:column;}
.cal-cell:hover{background:var(--bg-hover);}
.cal-cell.today{background:var(--accent-glow);}
.cal-cell.outside{opacity:.35;}
.cal-cell.weekend{background:var(--bg);opacity:.5;}
.cal-day-number{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:600;margin-bottom:6px;display:flex;align-items:center;justify-content:space-between;}
.cal-today-badge{font-size:9px;background:var(--accent);color:white;padding:1px 6px;border-radius:8px;font-weight:600;}
.cal-route-tag{padding:4px 8px;border-radius:6px;font-size:11px;font-weight:600;margin-bottom:3px;display:flex;align-items:center;gap:4px;cursor:pointer;transition:all .15s;border:1px solid transparent;}
.cal-route-tag:hover{transform:scale(1.02);filter:brightness(1.1);}
.cal-order-mini{padding:3px 6px;border-radius:4px;font-size:10px;background:var(--bg);border:1px solid var(--border);margin-bottom:2px;display:flex;justify-content:space-between;align-items:center;}
.cal-order-mini .client-name{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:110px;}
.cal-order-mini .order-total{font-family:'JetBrains Mono',monospace;color:var(--green);font-weight:600;font-size:9px;}
.cal-cell-summary{margin-top:auto;padding-top:4px;border-top:1px solid var(--border);font-size:10px;color:var(--text-faint);display:flex;justify-content:space-between;align-items:center;}
.cal-cell-summary .total{font-family:'JetBrains Mono',monospace;color:var(--green);font-weight:600;}
.route-legend{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;padding:12px 16px;background:var(--bg-surface);border:1px solid var(--border);border-radius:10px;}
.legend-item{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;padding:4px 10px;border-radius:6px;cursor:pointer;transition:all .2s;border:1px solid transparent;}
.legend-item:hover{border-color:var(--text-faint);}
.legend-item.dimmed{opacity:.3;}
.legend-dot{width:10px;height:10px;border-radius:3px;}

/* ═══════════ ATTACHMENTS ═══════════ */
.card-attachments{display:flex;gap:4px;flex-wrap:wrap;margin:5px 0;}
.attach-thumb{width:40px;height:40px;border-radius:6px;border:1px solid var(--border);overflow:hidden;cursor:pointer;transition:all .15s;position:relative;background:var(--bg);display:flex;align-items:center;justify-content:center;}
.attach-thumb:hover{border-color:var(--accent);transform:scale(1.08);box-shadow:0 2px 8px rgba(0,0,0,.3);}
.attach-thumb img{width:100%;height:100%;object-fit:cover;}
.attach-thumb .attach-icon{font-size:18px;}
.attach-thumb .attach-remove{position:absolute;top:-4px;right:-4px;width:14px;height:14px;border-radius:50%;background:var(--red);color:white;font-size:8px;display:none;align-items:center;justify-content:center;cursor:pointer;border:1px solid var(--bg-card);font-weight:700;line-height:1;}
.attach-thumb:hover .attach-remove{display:flex;}
.attach-badge{font-size:9px;padding:2px 6px;border-radius:4px;background:var(--bg);border:1px solid var(--border);color:var(--text-faint);display:flex;align-items:center;gap:3px;cursor:pointer;transition:all .15s;}
.attach-badge:hover{border-color:var(--accent);color:var(--accent);}

/* ── Inline preview strip (always visible) ── */
.card-preview-strip{display:flex;gap:5px;flex-wrap:wrap;margin:6px 0 2px;overflow:hidden;max-height:0;opacity:0;transition:max-height .4s cubic-bezier(.4,0,.2,1),opacity .3s;width:100%;}
.order-card:hover .card-preview-strip,.order-card .card-preview-strip.has-items{max-height:300px;opacity:1;}

/* Image preview */
.preview-img-wrap{position:relative;border-radius:8px;overflow:hidden;border:1px solid var(--border);cursor:pointer;transition:all .2s;max-width:100%;min-width:0;}
.preview-img-wrap:hover{border-color:var(--accent);box-shadow:0 4px 12px rgba(0,0,0,.3);transform:scale(1.02);}
.preview-img-wrap img{display:block;height:auto;max-height:72px;width:100%;max-width:100%;object-fit:cover;border-radius:7px;}
.preview-img-wrap .preview-del{position:absolute;top:3px;right:3px;width:18px;height:18px;border-radius:50%;background:rgba(0,0,0,.65);color:white;font-size:10px;display:none;align-items:center;justify-content:center;cursor:pointer;border:none;backdrop-filter:blur(4px);}
.preview-img-wrap:hover .preview-del{display:flex;}

/* Multiple images → grid layout */
.card-preview-strip.multi-img{display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:4px;}
.card-preview-strip.multi-img .preview-img-wrap img{height:56px;width:100%;object-fit:cover;}
.card-preview-strip.multi-img .preview-audio-wrap,
.card-preview-strip.multi-img .preview-file-wrap{grid-column:1/-1;}

/* Audio inline player */
.preview-audio-wrap{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:8px;border:1px solid var(--border);background:var(--bg);cursor:default;transition:all .2s;position:relative;width:100%;min-width:0;box-sizing:border-box;}
.preview-audio-wrap:hover{border-color:var(--accent);}
.preview-audio-btn{width:28px;height:28px;border-radius:50%;background:var(--accent);color:white;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;transition:all .2s;}
.preview-audio-btn:hover{transform:scale(1.1);box-shadow:0 2px 8px rgba(88,166,255,.4);}
.preview-audio-btn.playing{background:var(--green);}
.preview-audio-info{flex:1;min-width:0;overflow:hidden;}
.preview-audio-name{font-size:10px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.preview-audio-wave{height:20px;display:flex;align-items:flex-end;gap:1px;margin-top:2px;}
.preview-audio-wave .bar{width:3px;border-radius:1px;background:var(--accent);opacity:.4;transition:all .15s;animation:none;}
.preview-audio-wrap.playing .preview-audio-wave .bar{animation:audioWave .6s ease-in-out infinite alternate;}
@keyframes audioWave{0%{opacity:.3;}100%{opacity:1;}}
.preview-audio-time{font-size:9px;color:var(--text-faint);font-family:'JetBrains Mono',monospace;flex-shrink:0;}
.preview-audio-wrap .preview-del{position:absolute;top:-4px;right:-4px;width:16px;height:16px;border-radius:50%;background:var(--red);color:white;font-size:8px;display:none;align-items:center;justify-content:center;cursor:pointer;border:1px solid var(--bg-card);font-weight:700;}
.preview-audio-wrap:hover .preview-del{display:flex;}

/* PDF/Document preview */
.preview-file-wrap{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:8px;border:1px solid var(--border);background:var(--bg);cursor:pointer;transition:all .2s;position:relative;width:100%;min-width:0;box-sizing:border-box;}
.preview-file-wrap:hover{border-color:var(--accent);box-shadow:0 2px 8px rgba(0,0,0,.15);}
.preview-file-icon{font-size:22px;flex-shrink:0;}
.preview-file-info{flex:1;min-width:0;overflow:hidden;}
.preview-file-name{font-size:10px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.preview-file-type{font-size:9px;color:var(--text-faint);text-transform:uppercase;font-family:'JetBrains Mono',monospace;}
.preview-file-wrap .preview-del{position:absolute;top:-4px;right:-4px;width:16px;height:16px;border-radius:50%;background:var(--red);color:white;font-size:8px;display:none;align-items:center;justify-content:center;cursor:pointer;border:1px solid var(--bg-card);font-weight:700;}
.preview-file-wrap:hover .preview-del{display:flex;}

/* Upload zone in modal */
.upload-zone{border:2px dashed var(--border);border-radius:10px;padding:16px;text-align:center;cursor:pointer;transition:all .2s;background:var(--bg);position:relative;}
.upload-zone:hover,.upload-zone.dragover{border-color:var(--accent);background:var(--accent-glow);}
.upload-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;}
.upload-zone-text{font-size:13px;color:var(--text-muted);}
.upload-zone-text span{color:var(--accent);font-weight:600;}
.upload-preview-list{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px;}
.upload-preview{position:relative;width:64px;height:64px;border-radius:8px;border:1px solid var(--border);overflow:hidden;background:var(--bg);display:flex;align-items:center;justify-content:center;}
.upload-preview img{width:100%;height:100%;object-fit:cover;}
.upload-preview .preview-icon{font-size:24px;}
.upload-preview .preview-name{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.7);color:white;font-size:8px;padding:2px;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.upload-preview .preview-remove{position:absolute;top:-2px;right:-2px;width:18px;height:18px;border-radius:50%;background:var(--red);color:white;font-size:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;border:2px solid var(--bg-surface);font-weight:700;line-height:1;}

/* Delivery section collapsible */
.prod-menu-item{padding:8px 14px;font-size:12px;cursor:pointer;transition:background .15s;color:var(--text);}
.prod-menu-item:hover{background:var(--bg-hover);}
#prodTable tbody tr{border-bottom:1px solid var(--border);transition:background .15s;}
#prodTable tbody tr:hover{background:var(--bg-hover);}
#prodTable tbody input{background:transparent;border:none;color:var(--text);font-size:11px;font-family:inherit;width:100%;padding:6px 8px;outline:none;}
#prodTable tbody input:focus{background:rgba(88,166,255,0.05);}
#prodTable tbody input[type=number]{font-family:'JetBrains Mono',monospace;text-align:right;}
#prodTable tbody .prod-del-btn{background:none;border:none;color:var(--text-faint);cursor:pointer;font-size:12px;padding:4px 8px;border-radius:4px;transition:all .15s;}
#prodTable tbody .prod-del-btn:hover{background:var(--red);color:#fff;}
.order-delivery-section,.client-addr-section{margin-top:8px;border:1px solid var(--border);border-radius:8px;overflow:hidden;transition:border-color .3s;}
.order-delivery-section:hover,.client-addr-section:hover{border-color:var(--accent);}
.order-delivery-section.open,.client-addr-section.open{border-color:var(--accent);}
.delivery-toggle{display:flex;align-items:center;gap:8px;padding:10px 14px;cursor:pointer;background:var(--bg-surface);user-select:none;transition:background .2s;}
.delivery-toggle:hover{background:var(--bg-hover);}
.delivery-toggle span:first-child{font-size:10px;transition:transform .3s;color:var(--accent);}
.delivery-toggle span:nth-child(2){font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;}
.delivery-toggle-hint{margin-left:auto;font-size:10px;color:var(--text-faint);font-weight:400!important;text-transform:none!important;letter-spacing:0!important;transition:opacity .2s;}
.order-delivery-section.open .delivery-toggle-hint,.client-addr-section.open .delivery-toggle-hint{opacity:0;}
.order-delivery-section.open .delivery-toggle span:first-child,.client-addr-section.open .delivery-toggle span:first-child{transform:rotate(90deg);}
.delivery-collapsible{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s ease,opacity .3s ease;opacity:0;padding:0 14px;}
.order-delivery-section.open .delivery-collapsible,.client-addr-section.open .delivery-collapsible{max-height:800px;opacity:1;padding:8px 14px 14px;}
.order-delivery-section.hover-preview .delivery-collapsible,.client-addr-section.hover-preview .delivery-collapsible{max-height:800px;opacity:0.85;padding:8px 14px 14px;}
.order-delivery-section.hover-preview,.client-addr-section.hover-preview{border-color:rgba(88,166,255,0.3);}

/* Card file drop zone */
.order-card.file-drag-over{outline:2px dashed var(--accent);outline-offset:-2px;background:rgba(88,166,255,0.08)!important;position:relative;}
.order-card.file-drag-over::after{content:'📎 Soltar archivo';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(15,17,21,0.85);color:var(--accent);font-size:13px;font-weight:700;border-radius:inherit;z-index:5;pointer-events:none;letter-spacing:.5px;}

/* Lightbox */
.lightbox-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);display:none;align-items:center;justify-content:center;z-index:2000;backdrop-filter:blur(8px);flex-direction:column;gap:16px;cursor:pointer;}
.lightbox-overlay.active{display:flex;}
.lightbox-overlay img{max-width:90vw;max-height:75vh;border-radius:12px;box-shadow:0 8px 40px rgba(0,0,0,.5);}
.lightbox-overlay audio{width:min(400px,90vw);}
.lightbox-close{position:absolute;top:20px;right:20px;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.15);color:white;font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;transition:background .2s;}
.lightbox-close:hover{background:rgba(255,255,255,.3);}
.lightbox-info{color:rgba(255,255,255,.7);font-size:13px;text-align:center;}

/* ═══════════ ROUTE PLANNER STOPS ═══════════ */
.rp-stop{display:flex;gap:10px;padding:10px;border:1px solid var(--border);border-radius:8px;margin-bottom:6px;background:var(--bg-card);cursor:grab;transition:all .2s;align-items:flex-start;}
.rp-stop:hover{border-color:var(--text-faint);box-shadow:0 2px 8px rgba(0,0,0,.15);}
.rp-stop.dragging{opacity:.4;transform:scale(.97);}
.rp-stop.drag-over-stop{border-color:var(--accent);background:var(--accent-glow);}
.rp-stop-num{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex-shrink:0;color:white;font-family:'JetBrains Mono',monospace;}
.rp-stop-info{flex:1;min-width:0;}
.rp-stop-client{font-weight:700;font-size:13px;margin-bottom:2px;}
.rp-stop-addr{font-size:11px;color:var(--text-muted);margin-bottom:3px;}
.rp-stop-meta{display:flex;gap:8px;font-size:10px;color:var(--text-faint);align-items:center;}
.rp-stop-total{font-family:'JetBrains Mono',monospace;color:var(--green);font-weight:600;font-size:12px;}
.rp-stop-distance{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--cyan);background:var(--cyan-bg);padding:2px 6px;border-radius:4px;margin-top:4px;}
.rp-stop-handle{color:var(--text-faint);cursor:grab;font-size:14px;padding:0 4px;user-select:none;}

/* ═══════════ NOTIFICATION ═══════════ */
.notification{position:fixed;top:20px;right:20px;background:var(--accent);color:white;padding:14px 20px;border-radius:12px;font-weight:600;font-size:14px;box-shadow:0 8px 32px rgba(88,166,255,.3);transform:translateX(120%);transition:transform .4s cubic-bezier(.4,0,.2,1);z-index:500;display:flex;align-items:center;gap:10px;}
.notification.show{transform:translateX(0);}

/* ═══════════ SCROLLBAR ═══════════ */
::-webkit-scrollbar{width:5px;height:5px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px;}
::-webkit-scrollbar-thumb:hover{background:var(--text-faint);}

/* ═══════════ RESPONSIVE ═══════════ */
@media(max-width:1100px){
  .week-board{grid-template-columns:repeat(7,minmax(160px,1fr));overflow-x:auto;}
}
@media(max-width:768px){
  header{padding:10px 12px;flex-wrap:wrap;gap:6px;}
  .week-nav{padding:10px 12px !important;display:flex !important;flex-direction:column !important;align-items:center !important;gap:8px !important;}
  .week-nav-center{display:flex !important;justify-content:center !important;gap:8px !important;width:100% !important;}
  .week-nav h2{min-width:auto !important;font-size:15px !important;}
  .week-nav-center .btn-sm{font-size:15px !important;}
  .calendar-views{display:flex !important;width:100% !important;justify-content:center !important;gap:5px !important;}
  .calendar-views .btn-sm{padding:6px 12px !important;font-size:13px !important;}
  .cal-view-btn{padding:7px 14px !important;font-size:13px !important;white-space:nowrap !important;}
  .week-filters{width:100% !important;justify-content:center !important;flex-wrap:wrap !important;gap:4px !important;}
  .week-filters .filter-select{font-size:12px !important;padding:6px 8px !important;min-width:0 !important;flex:1 !important;max-width:45% !important;}
  .week-board{grid-template-columns:repeat(7,minmax(120px,1fr)) !important;overflow-x:auto !important;}
  .map-panel{width:100% !important;right:-100% !important;}
}
@media(max-width:480px){
  .week-nav h2{font-size:14px !important;}
  .cal-view-btn{padding:6px 11px !important;font-size:12px !important;}
  .calendar-views .btn-sm{padding:6px 10px !important;font-size:12px !important;}
  .week-filters .filter-select{font-size:11px !important;max-width:48% !important;}
}
