/* dealers.css - namespaced under .dfm to avoid Bootstrap conflicts */

/* Color scheme (can be overridden)
   Centralize all colors and gradients here so themes can be swapped easily.
*/
:root{
  /* Base text / backgrounds */
  --bg: #f8f9fa; /* light background to align with Bootstrap */
  --bg-gradient-start: #ffffff;
  --bg-gradient-end:   #f1f3f5;
  --text: #212529;

  /* Cards & panels */
  --card: #ffffff;
  --panel-overlay: rgba(0,0,0,0.03);
  --card-border: rgba(0,0,0,0.08);
  --input-border: rgba(0,0,0,0.12);
  --room-select-border: rgba(0,0,0,0.12);
  --dealer-card-bg: rgba(0,0,0,0.02);
  --muted: #6c757d;

  /* Accent (primary action) - Bootstrap primary */
  --accent: #0d6efd;
  --accent-text: #ffffff;
  --accent-gradient-start: #0d6efd;
  --accent-gradient-end:   #0b5ed7;

  /* Danger / destructive */
  --danger: #dc3545;

  /* Table closed state */
  --closed-gradient-start: #6c757d;
  --closed-gradient-end:   #495057;
  --closed-text: #f8f9fa;

  /* Avatar gradient */
  --avatar-gradient-start: #0d6efd;
  --avatar-gradient-end:   #6f42c1;
}

/* Scope all custom styles to body.dfm to avoid overriding Bootstrap defaults */
body.dfm, .dfm .app-root{height:100%;margin:0;font-family:Inter,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:linear-gradient(180deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%);color:var(--text)}
.dfm .app{display:flex;flex-direction:column;min-height:100vh}

/* Header */
.dfm .dfm-navbar .navbar{background:linear-gradient(180deg,var(--panel-overlay), transparent);backdrop-filter:blur(6px)}
.dfm .brand{font-weight:700;font-size:18px}
.dfm .dfm-logo{height:50px;width:auto;display:inline-block}
.dfm .spacer{flex:1}
.dfm .nav-items{display:flex;gap:12px;align-items:center}
.dfm .header-link{color:inherit;text-decoration:none}
.dfm .countdown{display:flex;flex-direction:column;align-items:flex-end;min-width:160px}
.dfm .countdown .label{font-size:12px;color:var(--muted)}
.dfm .countdown .time{font-weight:700;font-size:16px}

/* Room select */
.dfm .room-select select{padding:8px;border-radius:8px;background:transparent;color:inherit;border:1px solid var(--room-select-border)}
.dfm .room-info{display:flex;align-items:center;gap:8px}
.dfm .room-name{font-weight:600}

/* Main */
.dfm .main{display:flex;gap:20px;padding:20px}
.dfm .left{flex:1}
.dfm .right{width:360px}

/* Table grid */
.dfm .table-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}
.dfm .table-card{padding:12px;border-radius:12px;border:1px solid var(--card-border);color:var(--text);background:var(--card);display:flex;flex-direction:column;justify-content:space-between;min-height:110px}
/* Open tables should be shown in a pleasant light-green to indicate availability */
.dfm .table-card.open{background:linear-gradient(180deg,#dff7e0 0%,#bff1c3 100%);color:var(--text)}
.dfm .table-card.closed{background:linear-gradient(180deg,var(--closed-gradient-start) 0%,var(--closed-gradient-end) 100%);color:var(--closed-text)}
.dfm .table-num{font-weight:700;font-size:18px}
.dfm .dealer-name{font-size:14px;margin-top:8px;color:#222;font-weight:600}
.dfm .table-meta{display:flex;justify-content:space-between;align-items:center;margin-top:10px}

/* Panels & common */
.dfm .panel{background:linear-gradient(180deg,var(--panel-overlay), rgba(255,255,255,0.01));padding:12px;border-radius:12px;border:1px solid var(--card-border);margin-bottom:16px}
.dfm .panel h3{margin:0 0 8px 0;font-size:14px}

/* Dealer list/cards */
.dfm .dealer-list{display:flex;flex-direction:column;gap:6px}
.dfm .dealer-card{display:flex;align-items:center;gap:8px;padding:6px;border-radius:6px;background:var(--dealer-card-bg)}
.dfm .avatar{width:32px;height:32px;border-radius:6px;background:linear-gradient(135deg,var(--avatar-gradient-start),var(--avatar-gradient-end));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}
.dfm .small{font-size:12px;color:var(--muted)}
.dfm .dealer-info{flex:1}
.dfm .dealer-name-bold{font-weight:700}

/* Dealer action container used by JS-rendered cards */
.dfm .dealer-actions{display:flex;align-items:center;gap:8px}

/* Drag clone visuals: appended to body temporarily during dragstart. Use
   CSS rather than inline styles so tests and linting pass the "no inline
   styles" requirement. Positioned off-screen so it's not visible except
   as the drag image. */
.drag-clone{position:absolute !important;top:-1000px !important;left:-1000px !important;box-shadow:0 6px 18px rgba(0,0,0,0.25);max-width:320px;opacity:0.98}

/* Auth/login panel helpers used on the login page */
.auth-wrapper{flex:1;display:flex;align-items:center;justify-content:center;padding:40px}
.auth-panel{width:380px;background:rgba(255,255,255,0.02);padding:24px;border-radius:12px;border:1px solid rgba(255,255,255,0.03)}
.auth-panel h2{margin-top:0}

/* Room list row */
.dfm .room-row{border-radius:8px;background:rgba(255,255,255,0.01);border:1px solid rgba(0,0,0,0.02)}

/* utility to force a fixed grid column count for session layouts */
.dfm .grid-4{grid-template-columns:repeat(4,1fr)}
.dfm .grid-5{grid-template-columns:repeat(5,1fr)}
.dfm .grid-6{grid-template-columns:repeat(6,1fr)}

/* Percent badge styling - keep consistent between bench and table cards */
.dfm .badge.pct{
  display:inline-block;
  padding:2px 8px;
  border-radius:8px;
  font-weight:600;
  background:rgba(0,0,0,0.06);
  color:var(--text);
}
.dfm .badge.pct.small{padding:2px 6px;font-size:11px}
/* On closed (dark) table cards use a translucent white badge with light text */
.dfm .table-card.closed .badge.pct{
  background:rgba(255,255,255,0.12);
  color:var(--closed-text);
}

/* Forms & inputs */
.dfm .form-row{display:flex;gap:8px}
.dfm .input{flex:1;padding:8px;border-radius:8px;border:1px solid var(--input-border);background:transparent;color:inherit}
.dfm .mt12{margin-top:12px}

/* Buttons */
.dfm .btn{background:var(--accent);color:var(--accent-text);padding:8px 10px;border-radius:8px;border:none;cursor:pointer}
.dfm .btn.ghost{background:transparent;border:1px solid var(--input-border);color:var(--muted)}

/* Footer */
.dfm footer{padding:12px 24px;color:var(--muted);font-size:13px}

/* Responsive */
@media (max-width:900px){.dfm main{flex-direction:column}.dfm .right{width:100%}}

/* Selection & Drag-and-drop visuals */
.dfm .dealer-card{transition:transform 220ms ease,box-shadow 220ms ease,background-color 180ms ease,opacity 180ms ease}
.dfm .dealer-card.selected{border:2px solid var(--accent);box-shadow:0 10px 30px rgba(13,110,253,0.18);transform:translateY(-3px)}
.dfm .dealer-card[draggable="true"]{cursor:grab}
.dfm .dealer-card.dragging{opacity:0.85;cursor:grabbing;transform:scale(0.98)}

.dfm .table-card{transition:transform 200ms ease,box-shadow 200ms ease,border-color 200ms ease,background 220ms ease}
.dfm .table-card.drag-over{box-shadow:0 18px 40px rgba(13,110,253,0.18);transform:translateY(-6px) scale(1.02);border-color:var(--accent);
  /* Dark-to-light background gradient while dragging over the target table */
  background: linear-gradient(180deg, rgba(13,110,253,0.18) 0%, rgba(13,110,253,0.04) 100%);
  color: var(--accent-text);
}

/* Ensure the table title remains readable on the light gradient by forcing
   the table number/title color to a dark value while dragging over. */
.dfm .table-card.drag-over .table-num,
.dfm .table-card.drag-over .table-title{
  color: #000 !important;
}

/* Subtle pulsing highlight while hovering a valid drop target */
.dfm .table-card.drag-over::after{content:"";position:absolute;inset:0;border-radius:12px;pointer-events:none;box-shadow:0 0 0 0 rgba(13,110,253,0.08);animation:dropPulse 1100ms infinite}
.dfm .table-card{position:relative}

@keyframes dropPulse{0%{box-shadow:0 0 0 0 rgba(13,110,253,0.06)}50%{box-shadow:0 0 0 12px rgba(13,110,253,0.02)}100%{box-shadow:0 0 0 0 rgba(13,110,253,0.00)}}

/* Move animations for dealer cards when they are reassigned
   JS should toggle the .animate-to-bench or .animate-from-bench classes
   on the specific dealer card element to trigger the motion. */
.dfm .dealer-card.animate-to-bench{animation:toBench 420ms cubic-bezier(.2,.9,.2,1) forwards}
.dfm .dealer-card.animate-from-bench{animation:fromBench 420ms cubic-bezier(.2,.9,.2,1) forwards}

@keyframes toBench{
  0%{transform:translateY(0) scale(1);opacity:1}
  60%{transform:translateY(-8px) scale(1.03);opacity:0.95}
  100%{transform:translateY(20px) scale(0.96);opacity:0}
}

@keyframes fromBench{
  0%{transform:translateY(-20px) scale(0.96);opacity:0}
  60%{transform:translateY(6px) scale(1.02);opacity:0.98}
  100%{transform:translateY(0) scale(1);opacity:1}
}

/* Utility: quick fade for removal where JS simply wants to hide then remove element */
.dfm .fade-out{animation:fadeOut 300ms ease forwards}
@keyframes fadeOut{from{opacity:1}to{opacity:0;transform:scale(0.98)}}

/* Animate a bench card moving into a table slot (visual only). JS will
   add .animate-to-table to the element before removing it from the DOM. */
.dfm .dealer-card.animate-to-table{animation:toTable 420ms cubic-bezier(.2,.9,.2,1) forwards}
@keyframes toTable{
  0%{transform:translateY(0) scale(1);opacity:1}
  60%{transform:translateY(-6px) scale(1.03);opacity:0.95}
  100%{transform:translateY(-20px) scale(0.94);opacity:0}
}

