/* wrk-v3.css — consolidated v3 UI overlays (GPS popup, live actions, bubbles) */

/* === GPS Popup v3 === */

/* =====================================================
   WRK GPS Popup — Hi-Tech v3
   Loaded globally via base.blade.php
   ===================================================== */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

/* === Remove Bootstrap fade lag === */
#gps-modal.gpsPopup { padding:0 !important; }
#gps-modal.gpsPopup.fade .modal-dialog {
  transition: transform 0.2s ease, opacity 0.2s ease !important;
  transform: scale(0.95);
  opacity: 0;
}
#gps-modal.gpsPopup.in .modal-dialog,
#gps-modal.gpsPopup.show .modal-dialog {
  transform: scale(1);
  opacity: 1;
}

/* === Modal shell === */
#gps-modal .modal-content {
  border: none !important;
  border-radius: 16px !important;
  overflow: hidden;
  box-shadow: 0 24px 80px rgba(0,0,0,0.35), 0 8px 24px rgba(0,0,0,0.15) !important;
}
#gps-modal .modal-body {
  padding: 0 !important;
  border-radius: 0 !important;
}
#gps-modal .modal-dialog {
  max-width: 420px;
  margin: 80px auto;
}

/* === Accent bar === */
.gps-accent-bar {
  height: 4px;
  background: linear-gradient(90deg, #FFF200, #ffe600, #FFF200);
}

/* === Logo === */
.gps-v3-logo {
  text-align: center;
  padding: 28px 20px 0;
}
.gps-v3-logo .w-mark {
  display: inline-flex;
  width: 48px; height: 48px;
  background: #FFF200;
  border-radius: 12px;
  align-items: center; justify-content: center;
  font-weight: 900; font-size: 24px; color: #000;
  font-family: 'Inter', sans-serif;
  box-shadow: 0 3px 12px rgba(255,242,0,0.3);
  transition: 0.25s cubic-bezier(0.4,0,0.2,1);
}
.gps-v3-logo .w-mark:hover { transform: rotate(-4deg) scale(1.05); }

/* === Header (icon + label) === */
.gps-v3-header {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 18px 20px 0;
}
.gps-v3-header .gps-icon {
  width: 44px; height: 44px;
  background: linear-gradient(135deg, #e3f2fd, #bbdefb);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; color: #1976D2;
  box-shadow: 0 2px 8px rgba(25,118,210,0.2);
  flex-shrink: 0;
  transition: 0.25s cubic-bezier(0.4,0,0.2,1);
}
.gps-v3-header .gps-icon.success {
  background: linear-gradient(135deg, #e8f5e9, #c8e6c9);
  color: #43a047;
  box-shadow: 0 2px 8px rgba(67,160,71,0.2);
}
.gps-v3-header .gps-icon.error {
  background: linear-gradient(135deg, #ffebee, #ffcdd2);
  color: #e53935;
  box-shadow: 0 2px 8px rgba(229,57,53,0.2);
}
.gps-v3-header .gps-label {
  font-size: 16px; font-weight: 700; color: #1a1a1a;
  font-family: 'Inter', sans-serif;
  letter-spacing: -0.02em;
}

/* === Body text === */
.gps-v3-body {
  text-align: center;
  padding: 20px 30px 6px;
}
.gps-v3-body h4 {
  font-size: 18px; font-weight: 800; color: #000;
  font-family: 'Inter', sans-serif;
  margin-bottom: 8px; letter-spacing: -0.02em;
}
.gps-v3-body p {
  font-size: 14px; font-weight: 400; color: #666;
  font-family: 'Inter', sans-serif;
  line-height: 1.6;
  max-width: 320px; margin: 0 auto;
}

/* === Buttons === */
.gps-v3-buttons {
  display: flex; gap: 12px; justify-content: center;
  padding: 20px 30px 28px;
}
.gps-v3-btn {
  flex: 1; max-width: 160px;
  padding: 13px 0;
  border-radius: 30px;
  font-family: 'Inter', sans-serif;
  font-size: 14px; font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  cursor: pointer;
  transition: 0.25s cubic-bezier(0.4,0,0.2,1);
  display: flex; align-items: center; justify-content: center; gap: 8px;
  border: none;
}
.gps-v3-btn.proceed {
  background: #FFF200; color: #000;
  border: 2px solid #0a0a0a;
  box-shadow: 0 2px 10px rgba(255,242,0,0.3);
}
.gps-v3-btn.proceed:hover {
  background: #000; color: #FFF200;
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(0,0,0,0.3);
}
.gps-v3-btn.decline {
  background: #f5f5f5; color: #888;
  border: 1.5px solid #e0e0e0;
}
.gps-v3-btn.decline:hover {
  background: #fff; color: #000;
  border-color: #000;
  transform: translateY(-1px);
}

/* === Requesting state === */
.gps-v3-requesting {
  text-align: center;
  padding: 32px 30px 36px;
  display: none;
}
.gps-v3-requesting .spinner {
  width: 48px; height: 48px;
  border: 3px solid #e0e0e0;
  border-top: 3px solid #FFF200;
  border-radius: 50%;
  animation: gpsV3Spin 0.8s linear infinite;
  margin: 0 auto 18px;
}
@keyframes gpsV3Spin { to { transform: rotate(360deg); } }
.gps-v3-requesting .req-text {
  font-size: 15px; font-weight: 600; color: #333;
  font-family: 'Inter', sans-serif;
  margin-bottom: 4px;
}
.gps-v3-requesting .req-sub {
  font-size: 12px; color: #999;
  font-family: 'Inter', sans-serif;
}

/* === Success state === */
.gps-v3-success {
  text-align: center;
  padding: 32px 30px 36px;
  display: none;
}
.gps-v3-success .check-circle {
  width: 56px; height: 56px;
  background: linear-gradient(135deg, #e8f5e9, #c8e6c9);
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 28px; color: #43a047;
  margin-bottom: 16px;
  box-shadow: 0 3px 12px rgba(67,160,71,0.2);
}
.gps-v3-success .s-text {
  font-size: 15px; font-weight: 600; color: #333;
  font-family: 'Inter', sans-serif;
}
.gps-v3-success .s-sub {
  font-size: 12px; color: #999;
  font-family: 'Inter', sans-serif;
  margin-top: 4px;
}

/* === Error state === */
.gps-v3-error {
  text-align: center;
  padding: 32px 30px 28px;
  display: none;
}
.gps-v3-error .error-circle {
  width: 56px; height: 56px;
  background: linear-gradient(135deg, #ffebee, #ffcdd2);
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 28px; color: #e53935;
  margin-bottom: 16px;
  box-shadow: 0 3px 12px rgba(229,57,53,0.2);
}
.gps-v3-error .e-text {
  font-size: 15px; font-weight: 600; color: #333;
  font-family: 'Inter', sans-serif;
  margin-bottom: 4px;
}
.gps-v3-error .e-sub {
  font-size: 12px; color: #999; line-height: 1.5;
  font-family: 'Inter', sans-serif;
  max-width: 280px; margin: 0 auto;
}
.gps-v3-error .retry-btn {
  margin-top: 18px;
  background: #FFF200; color: #000;
  border: 2px solid #0a0a0a; border-radius: 30px;
  padding: 10px 32px; font-size: 13px; font-weight: 700;
  text-transform: uppercase; cursor: pointer;
  font-family: 'Inter', sans-serif;
  transition: 0.25s cubic-bezier(0.4,0,0.2,1);
}
.gps-v3-error .retry-btn:hover {
  background: #000; color: #FFF200;
  transform: translateY(-1px);
}

/* === Hide old styles === */
#gps-modal .modal-logo,
#gps-modal .modal-heading,
#gps-modal .popupBody,
#gps-modal .popupBtns {
  display: none !important;
}

/* === Mobile === */
@media (max-width: 767px) {
  #gps-modal .modal-dialog { max-width: 340px; margin: 40px auto; }
  .gps-v3-logo { padding: 22px 20px 0; }
  .gps-v3-logo .w-mark { width: 40px; height: 40px; font-size: 20px; border-radius: 10px; }
  .gps-v3-header .gps-label { font-size: 14px; }
  .gps-v3-header .gps-icon { width: 38px; height: 38px; font-size: 18px; }
  .gps-v3-body { padding: 16px 20px 4px; }
  .gps-v3-body h4 { font-size: 16px; }
  .gps-v3-body p { font-size: 13px; }
  .gps-v3-buttons { padding: 16px 20px 24px; }
  .gps-v3-btn { font-size: 13px; padding: 12px 0; }
}

/* === Live Actions v3 === */

/* =====================================================
   WRK Live Action Popups — Hi-Tech v3 Override
   Loaded on workprogressprovider + workprogressworker
   Overrides existing .fix-modal / .bid-modal styles
   ===================================================== */

/* Google Fonts — Inter for sharp modern type */

:root {
  --la-yellow: #FFF200;
  --la-yellow-dim: #e6d900;
  --la-yellow-glow: rgba(255,242,0,0.25);
  --la-yellow-soft: rgba(255,242,0,0.08);
  --la-red: #e53935;
  --la-border: #e4e4e4;
  --la-radius: 14px;
  --la-radius-sm: 8px;
  --la-radius-xs: 6px;
  --la-transition: 0.25s cubic-bezier(0.4,0,0.2,1);
  --la-shadow: 0 24px 80px rgba(0,0,0,0.35), 0 8px 24px rgba(0,0,0,0.15);
}

/* === MODAL SHELL === */
.fix-modal .modal-dialog {
  margin-top: 60px;
}
.fix-modal .modal-content {
  border-radius: var(--la-radius) !important;
  overflow: hidden;
  box-shadow: var(--la-shadow) !important;
  border: none !important;
  transition: var(--la-transition);
}

/* === APPROVE HEADER (YELLOW BAR) === */
.fix-modal .approve-header {
  background: linear-gradient(135deg, var(--la-yellow) 0%, #ffe600 60%, #ffd000 100%) !important;
  min-height: 72px;
}
.fix-modal .approve-header .logo-left {
  display: flex;
  align-items: center;
  justify-content: center;
  border-right: 1px solid rgba(0,0,0,0.06);
}
.fix-modal .approve-header .logo-left img {
  transition: var(--la-transition);
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.1));
}
.fix-modal .approve-header .logo-left img:hover {
  transform: rotate(-3deg) scale(1.05);
}

/* Close button refinement */
.fix-modal .approve-header a[data-dismiss="modal"],
.fix-modal .approve-header > a:first-child {
  border-radius: 0 var(--la-radius) 0 var(--la-radius-xs);
  transition: var(--la-transition);
  font-weight: 600;
}

/* Right heading text */
.fix-modal .right-heading {
  font-family: 'Inter', 'Poppins', sans-serif;
  font-size: 15px;
  line-height: 1.4;
  letter-spacing: -0.01em;
}
.fix-modal .right-heading strong {
  color: #c00;
}

/* === MODAL BODY / CONTENT === */
.fix-modal .approve-modal-content {
  padding: 24px 22px;
  font-family: 'Inter', 'Poppins', sans-serif;
}

/* Background images preserved — just ensure padding doesn't clip */
.fix-modal.bid-modal.price-change .approve-modal-content,
.fix-modal.bid-modal.partial-payment .approve-modal-content,
.fix-modal.bid-modal.cancel-work .approve-modal-content,
.fix-modal.bid-modal.mark-done .approve-modal-content {
  padding: 24px 22px;
}

/* === TYPOGRAPHY === */
.fix-modal h5 {
  font-family: 'Inter', 'Poppins', sans-serif !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  border-bottom: 2px solid var(--la-yellow) !important;
  padding-bottom: 8px !important;
  line-height: 1.5 !important;
}
.fix-modal h6 {
  font-family: 'Inter', 'Poppins', sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  line-height: 1.4 !important;
  letter-spacing: -0.01em;
}

/* === INPUTS — Refined borders, yellow glow on focus === */
.bid-modal .approve-modal-content input[type="text"],
.bid-modal .approve-modal-content input[type="number"],
.bid-modal .approve-modal-content input[name="nprice"],
.bid-modal .approve-modal-content input[name="payamount"] {
  border: 1.5px solid var(--la-border) !important;
  border-radius: var(--la-radius-xs) !important;
  padding: 11px 14px !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 14px !important;
  transition: var(--la-transition) !important;
  background: #fff !important;
}
.bid-modal .approve-modal-content input:focus {
  border-color: var(--la-yellow) !important;
  box-shadow: 0 0 0 3px var(--la-yellow-glow) !important;
  background: var(--la-yellow-soft) !important;
  outline: none !important;
}

.bid-modal .approve-modal-content textarea {
  border: 1.5px solid var(--la-border) !important;
  border-radius: var(--la-radius-xs) !important;
  padding: 12px 14px !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 14px !important;
  transition: var(--la-transition) !important;
  background: #fff !important;
  resize: none;
}
.bid-modal .approve-modal-content textarea:focus {
  border-color: var(--la-yellow) !important;
  box-shadow: 0 0 0 3px var(--la-yellow-glow) !important;
  outline: none !important;
}

/* Input group addon — clean up, yellow on focus */
.bid-modal .approve-modal-content .input-group-addon {
  border: 1.5px solid var(--la-border) !important;
  border-right: none !important;
  border-radius: var(--la-radius-xs) 0 0 var(--la-radius-xs) !important;
  background: #fafafa !important;
  transition: var(--la-transition) !important;
}
.bid-modal .approve-modal-content .input-group:focus-within .input-group-addon {
  background: var(--la-yellow) !important;
  border-color: var(--la-yellow) !important;
}
.bid-modal .approve-modal-content .input-group:focus-within input {
  background: var(--la-yellow-soft) !important;
  border-color: var(--la-yellow) !important;
}

/* Adjacent input rounds only right side */
.bid-modal .approve-modal-content .input-group .input-group-addon + input {
  border-top-left-radius: 0 !important;
  border-bottom-left-radius: 0 !important;
}

/* === REASON DROPDOWN (YELLOW) === */
.bid-modal .approve-modal-content .reason-dp a.dropdown-toggle {
  border-radius: var(--la-radius-xs) !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 600 !important;
  transition: var(--la-transition) !important;
  padding: 11px 16px !important;
}
.bid-modal .approve-modal-content .reason-dp a.dropdown-toggle:hover {
  background-color: var(--la-yellow-dim) !important;
}
.bid-modal .approve-modal-content .reason-dp .dropdown-menu {
  border-radius: 0 0 var(--la-radius-xs) var(--la-radius-xs) !important;
  border: 1px solid var(--la-border) !important;
  box-shadow: 0 4px 16px rgba(0,0,0,0.1) !important;
  overflow: hidden;
}
.bid-modal .approve-modal-content .reason-dp .dropdown-menu a {
  font-family: 'Inter', sans-serif !important;
  font-weight: 500 !important;
  padding: 11px 16px !important;
  transition: var(--la-transition) !important;
}
.bid-modal .approve-modal-content .reason-dp .dropdown-menu a:hover {
  background: var(--la-yellow-soft) !important;
  padding-left: 20px !important;
}

/* === PAYMENT CALCULATOR === */
.payment-calculator {
  border: 1.5px solid var(--la-border) !important;
  border-radius: var(--la-radius-xs) !important;
  overflow: hidden !important;
  background: #fcfcfc !important;
}
.bid-modal .approve-modal-content .payment-calculator p {
  font-family: 'Inter', 'Poppins', sans-serif !important;
  font-weight: 600 !important;
  transition: var(--la-transition);
  padding: 10px 20px !important;
}
.bid-modal .approve-modal-content .payment-calculator p:hover {
  background: var(--la-yellow-soft);
}
.bid-modal .approve-modal-content .payment-calculator p.total-price {
  border-top: 2px solid #1a1a1a !important;
  background: var(--la-yellow-soft) !important;
}
.bid-modal .approve-modal-content .payment-calculator p small {
  font-family: 'Inter', sans-serif !important;
  font-weight: 500 !important;
}

/* === ATTENTION ALERT — Gradient yellow === */
.fix-modal .attention-alert {
  background: linear-gradient(135deg, #fff9c4 0%, #fff59d 100%) !important;
  border: 1px solid rgba(255,242,0,0.3) !important;
  border-radius: var(--la-radius-xs) !important;
  padding: 12px 16px !important;
  font-family: 'Inter', 'Poppins', sans-serif !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  line-height: 1.5 !important;
  transition: var(--la-transition);
}
.fix-modal .attention-alert img {
  filter: drop-shadow(0 1px 2px rgba(0,0,0,0.1));
}

/* Fee charge alert — red-accent gradient variant */
.fix-modal .attention-alert span[style*="color:red"],
.fix-modal .attention-alert strong span[style*="color:red"] {
  font-weight: 800 !important;
}

/* === AGREED BOX (CHECKBOX + TERMS) === */
.bid-modal .agreed-box {
  gap: 10px !important;
  align-items: flex-start !important;
}
.bid-modal .agreed-box input[type="checkbox"] {
  width: 18px !important;
  height: 18px !important;
  margin-top: 2px !important;
  accent-color: var(--la-yellow);
  cursor: pointer;
}
.bid-modal .agreed-box label {
  font-family: 'Inter', 'Poppins', sans-serif !important;
  font-size: 12px !important;
  line-height: 1.6 !important;
}
.bid-modal .agreed-box label a {
  transition: var(--la-transition) !important;
  border-bottom: 1.5px solid var(--la-border) !important;
}
.bid-modal .agreed-box label a:hover {
  border-color: var(--la-yellow) !important;
}

/* === PROCESS FOOTER === */
.fix-modal .process-footer {
  margin-top: 20px !important;
  padding-top: 16px !important;
  border-top: 1px solid #f0f0f0;
}
.fix-modal .process-footer label,
.bid-modal .process-footer label {
  font-family: 'Inter', 'Poppins', sans-serif !important;
  font-size: 12px !important;
  line-height: 1.6 !important;
}
.fix-modal .process-footer label a,
.bid-modal .process-footer label a {
  font-family: 'Inter', sans-serif !important;
  font-size: 12px !important;
  transition: var(--la-transition) !important;
  border-bottom: 1.5px solid var(--la-border) !important;
}
.fix-modal .process-footer label a:hover,
.bid-modal .process-footer label a:hover {
  border-color: var(--la-yellow) !important;
}

/* === BUTTONS — Pill shape, shadow lift === */
.approve-modal-content button,
.process-footer button:not(.outlined-btn) {
  font-family: 'Inter', 'Poppins', sans-serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  border-radius: 30px !important;
  padding: 10px 28px !important;
  text-transform: uppercase !important;
  transition: var(--la-transition) !important;
  box-shadow: 0 2px 8px rgba(255,242,0,0.25);
  letter-spacing: 0.3px;
}
.approve-modal-content button:hover,
.process-footer button:not(.outlined-btn):hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 14px rgba(0,0,0,0.25) !important;
}

/* Outlined button (clear signature) — refined */
.bid-modal .process-footer button.outlined-btn {
  border-radius: var(--la-radius-xs) !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 600 !important;
  font-size: 12px !important;
  padding: 6px 14px !important;
  transition: var(--la-transition) !important;
  border: 1.5px solid #1a1a1a !important;
}
.bid-modal .process-footer button.outlined-btn:hover {
  background: var(--la-yellow) !important;
  border-color: var(--la-yellow) !important;
  transform: translateY(-1px);
}

/* === SIGNATURE CANVAS === */
.bid-modal canvas {
  background-color: #f5f5f4 !important;
  border: 2px dashed var(--la-border) !important;
  border-radius: var(--la-radius-xs) !important;
  cursor: crosshair;
  transition: var(--la-transition);
}
.bid-modal canvas:hover {
  border-color: var(--la-yellow) !important;
  background-color: #fafaf5 !important;
}

/* Signature section label */
.signature-bottom .input-group h6 {
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  font-size: 13px !important;
}
.signature-bottom .input-group h6 img {
  filter: drop-shadow(0 1px 2px rgba(0,0,0,0.1));
}

/* === CHECKBOX REFINEMENTS (all modals) === */
.fix-modal input[type="checkbox"] {
  accent-color: var(--la-yellow);
  cursor: pointer;
}

/* === Accept/Reject buttons (worker mark done approval) === */
.btn_confirm.acceptwrkrmarkdone,
button.acceptwrkrmarkdone {
  background: #43a047 !important;
  color: #fff !important;
  border-color: #43a047 !important;
  border-radius: 30px !important;
  padding: 10px 28px !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 700 !important;
  transition: var(--la-transition) !important;
  box-shadow: 0 3px 10px rgba(67,160,71,0.3) !important;
}
.btn_confirm.acceptwrkrmarkdone:hover,
button.acceptwrkrmarkdone:hover {
  background: #2e7d32 !important;
  transform: translateY(-1px) !important;
}
.btn_confirm.rejectwrkrmarkdone,
button.rejectwrkrmarkdone {
  background: var(--la-red) !important;
  color: #fff !important;
  border-color: var(--la-red) !important;
  border-radius: 30px !important;
  padding: 10px 28px !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 700 !important;
  transition: var(--la-transition) !important;
  box-shadow: 0 3px 10px rgba(229,57,53,0.3) !important;
}
.btn_confirm.rejectwrkrmarkdone:hover,
button.rejectwrkrmarkdone:hover {
  background: #b71c1c !important;
  transform: translateY(-1px) !important;
}

/* Green/Red button styling for new-style accept/reject */
button.greenBtn {
  background: #43a047 !important;
  color: #fff !important;
  border: none !important;
  border-radius: 30px !important;
  padding: 10px 24px !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 700 !important;
  transition: var(--la-transition) !important;
  box-shadow: 0 3px 10px rgba(67,160,71,0.3) !important;
}
button.greenBtn:hover {
  background: #2e7d32 !important;
  transform: translateY(-1px) !important;
}
.bid-modal button.redBtn, .approve-modal-content button.redBtn {
  background: var(--la-red) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 30px !important;
  padding: 10px 24px !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 700 !important;
  transition: var(--la-transition) !important;
  box-shadow: 0 3px 10px rgba(229,57,53,0.3) !important;
}
.bid-modal button.redBtn:hover, .approve-modal-content button.redBtn:hover {
  background: #b71c1c !important;
  transform: translateY(-1px) !important;
}

/* === CANCEL BUTTON (modal dismiss) === */
#cancel-offer,
button[data-dismiss="modal"]:not(.close):not(.approve-header a) {
  transition: var(--la-transition) !important;
}

/* === INLINE PRICE ERROR (Partial Payment) === */
.pp-inline-error {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  margin: 14px 0;
  background: linear-gradient(135deg, #ffebee 0%, #ffcdd2 100%);
  border: 1px solid rgba(229,57,53,0.2);
  border-left: 4px solid #e53935;
  border-radius: var(--la-radius-xs);
  font-family: 'Inter', 'Poppins', sans-serif;
  font-size: 14px;
  font-weight: 500;
  color: #000;
  line-height: 1.5;
  animation: ppErrorSlide 0.25s ease;
}
.pp-inline-error img {
  height: 24px;
  flex-shrink: 0;
  filter: drop-shadow(0 1px 2px rgba(0,0,0,0.1));
}
.pp-inline-error strong {
  color: #e53935;
  font-weight: 800;
}
@keyframes ppErrorSlide {
  from { opacity: 0; transform: translateY(-6px); }
  to { opacity: 1; transform: translateY(0); }
}

/* === MOBILE RESPONSIVE OVERRIDES === */
@media (max-width: 767px) {
  .fix-modal .modal-content {
    border-radius: var(--la-radius-sm) !important;
  }
  .fix-modal .approve-header {
    min-height: 60px;
  }
  .fix-modal .right-heading {
    font-size: 13px !important;
    padding: 10px 14px !important;
  }
  .fix-modal .approve-modal-content {
    padding: 18px 16px !important;
  }
  .fix-modal h5 { font-size: 14px !important; }
  .fix-modal h6 { font-size: 13px !important; }
  .fix-modal .attention-alert {
    font-size: 13px !important;
    padding: 10px 12px !important;
  }
  .fix-modal .process-footer {
    text-align: center;
  }
  .fix-modal .process-footer .pull-left,
  .fix-modal .process-footer .pull-right {
    float: none !important;
    max-width: 100% !important;
    width: 100% !important;
    text-align: center !important;
  }
  .fix-modal .process-footer button {
    margin-top: 15px !important;
  }
  .bid-modal .approve-modal-content .payment-calculator p {
    font-size: 14px !important;
    padding: 8px 14px !important;
  }
}

/* === Bubbles v3 === */

/* =====================================================
   WRK Bubbles UI — Card Grid (Design 3)
   POST WRK Steps 1, 3, 4
   ===================================================== */

/* === TOGGLE CHIPS (Step 1 services) === */
.wrk-chip-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}
.wrk-toggle-chip {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 16px;
  border-radius: 8px;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 500;
  background: #f5f5f5;
  border: 1.5px solid #ddd;
  color: #555;
  cursor: pointer;
  transition: 0.2s cubic-bezier(0.4,0,0.2,1);
  user-select: none;
}
.wrk-toggle-chip .chip-toggle {
  width: 18px; height: 18px;
  border-radius: 4px;
  border: 1.5px solid #ccc;
  display: inline-flex;
  align-items: center; justify-content: center;
  font-size: 10px;
  color: transparent;
  transition: 0.2s;
  flex-shrink: 0;
}
.wrk-toggle-chip:hover {
  border-color: #999;
  background: #f0f0f0;
}
.wrk-toggle-chip.selected {
  background: rgba(255,242,0,0.1);
  border-color: #FFF200;
  color: #000;
  font-weight: 600;
}
.wrk-toggle-chip.selected .chip-toggle {
  background: #FFF200;
  border-color: #FFF200;
  color: #000;
}

/* === CARD GRID (Step 3 traits — keep for traits) === */
.wrk-bubble-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 10px;
  margin-top: 12px;
}
.wrk-bubble-card {
  position: relative;
  padding: 18px 10px 14px;
  border-radius: 8px;
  text-align: center;
  background: #f8f8f8;
  border: 1.5px solid #e0e0e0;
  cursor: pointer;
  transition: 0.2s cubic-bezier(0.4,0,0.2,1);
  user-select: none;
}
.wrk-bubble-card .bubble-icon {
  width: 40px; height: 40px;
  border-radius: 10px;
  background: #eee;
  display: inline-flex;
  align-items: center; justify-content: center;
  font-size: 18px; color: #999;
  margin-bottom: 8px;
  transition: 0.2s cubic-bezier(0.4,0,0.2,1);
}
.wrk-bubble-card .bubble-name {
  font-family: 'Inter', sans-serif;
  font-size: 11px; font-weight: 600;
  color: #555; line-height: 1.3;
}
.wrk-bubble-card .bubble-check {
  display: none;
  position: absolute; top: 6px; right: 6px;
  width: 20px; height: 20px;
  border-radius: 50%;
  background: #FFF200;
  color: #000;
  font-size: 11px; line-height: 20px;
  text-align: center; font-weight: 900;
  box-shadow: 0 2px 6px rgba(255,242,0,0.3);
}

/* Hover */
.wrk-bubble-card:hover {
  border-color: #FFF200;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.08);
}
.wrk-bubble-card:hover .bubble-icon {
  color: #b8a900;
  background: rgba(255,242,0,0.12);
}

/* Selected */
.wrk-bubble-card.selected {
  border-color: #FFF200;
  background: rgba(255,242,0,0.08);
  box-shadow: 0 2px 16px rgba(255,242,0,0.2);
}
.wrk-bubble-card.selected .bubble-icon {
  background: #FFF200;
  color: #000;
}
.wrk-bubble-card.selected .bubble-name {
  color: #000;
  font-weight: 700;
}
.wrk-bubble-card.selected .bubble-check {
  display: block;
}

/* === SELECTED CHIPS BAR === */
.wrk-bubble-selected {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 0;
  margin-bottom: 10px;
  padding: 10px 14px 10px 36px;
  background: #f5f5f5;
  border-radius: 8px;
  border: 1px solid #e0e0e0;
  min-height: 36px;
  box-sizing: border-box !important;
  width: 100% !important;
}
.wrk-bubble-selected:empty::after {
  content: 'No services selected';
  color: #aaa; font-size: 12px;
  font-family: 'Inter', sans-serif;
}
.wrk-bubble-chip {
  display: inline-flex;
  align-items: center; gap: 5px;
  padding: 4px 12px;
  border-radius: 20px;
  font-family: 'Inter', sans-serif;
  font-size: 11px; font-weight: 600;
  background: #FFF200; color: #000;
  cursor: pointer;
  transition: 0.2s;
}
.wrk-bubble-chip:hover {
  background: #e6d900;
  transform: scale(0.97);
}
.wrk-bubble-chip .chip-x {
  font-size: 14px; font-weight: 800; line-height: 1;
}

/* === HEADER ROW (label + search + count) === */
.wrk-bubble-header {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 8px;
}
.wrk-bubble-header .field-work { flex-shrink: 0; }
.wrk-bubble-header .wrk-bubble-count { margin-left: auto; flex-shrink: 0; }

/* === SEARCH FILTER === */
.wrk-bubble-search-wrap {
  margin-top: 6px;
  margin-bottom: 6px;
}
.wrk-bubble-search-wrap,
.wrk-bubble-selected,
.wrk-bubble-search {
  box-sizing: border-box !important;
}
.wrk-bubble-search-wrap.wrk-bubble-search-inline {
  margin-top: 0;
  margin-bottom: 0;
  flex: 1 1 160px;
  max-width: 260px;
}
.wrk-bubble-search-wrap > i { display: none !important; }
.wrk-bubble-search {
  width: 100% !important;
  padding: 10px 14px 10px 36px !important;
  background-color: #f5f5f5 !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='15' height='15' fill='%23999'%3E%3Cpath d='M10.68 9.588a5.5 5.5 0 1 0-1.09 1.09l3.266 3.266a.77.77 0 0 0 1.09-1.09L10.68 9.588zM5.5 9.5a4 4 0 1 1 0-8 4 4 0 0 1 0 8z'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: 12px center !important;
  border: 1px solid #e0e0e0 !important;
  border-radius: 8px !important;
  color: #333 !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 13px !important;
  outline: none !important;
  transition: border-color 0.2s, box-shadow 0.2s !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}
.wrk-bubble-search:focus {
  border-color: #FFF200;
  box-shadow: 0 0 0 3px rgba(255,242,0,0.2);
}

/* === COUNT BADGE === */
.wrk-bubble-count {
  font-family: 'Inter', sans-serif;
  font-size: 11px; font-weight: 700;
  color: #b8a900;
  background: rgba(255,242,0,0.12);
  border: 1px solid rgba(255,242,0,0.25);
  padding: 2px 10px;
  border-radius: 20px;
  float: right;
  margin-top: 2px;
}

/* === TRAITS — PURPLE TOGGLE CHIPS (Step 3) === */
.wrk-toggle-chip.trait-toggle:hover {
  border-color: #a855f7;
}
.wrk-toggle-chip.trait-toggle.selected {
  background: rgba(168,85,247,0.1);
  border-color: #a855f7;
  color: #000;
  font-weight: 600;
}
.wrk-toggle-chip.trait-toggle.selected .chip-toggle {
  background: #a855f7;
  border-color: #a855f7;
  color: #fff;
}

/* Trait chips */
.wrk-bubble-chip.trait-chip {
  background: #a855f7;
  color: #fff;
}
.wrk-bubble-chip.trait-chip:hover {
  background: #9333ea;
}

/* === PREVIEW PILLS (Step 4) === */
.wrk-preview-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
  margin-bottom: 8px;
}
.wrk-preview-pill {
  display: inline-flex;
  align-items: center; gap: 6px;
  padding: 6px 16px;
  border-radius: 20px;
  font-family: 'Inter', sans-serif;
  font-size: 12px; font-weight: 600;
  background: rgba(255,242,0,0.08);
  border: 1px solid #FFF200;
  color: #b8a900;
}
.wrk-preview-pill i { font-size: 10px; }
.wrk-preview-pill.trait-pill {
  background: rgba(168,85,247,0.08);
  border-color: #a855f7;
  color: #7c3aed;
}

/* Remove pill — on preview page (Step 4) */
.wrk-preview-pill .pill-remove {
  cursor: pointer;
  font-size: 14px; font-weight: 800;
  margin-left: 4px;
  opacity: 0.6;
  transition: 0.2s;
}
.wrk-preview-pill .pill-remove:hover {
  opacity: 1;
  color: #e53935;
}

/* === HIDE OLD SELECT2 when bubble grid is active === */
.wrk-bubble-active .select2-container,
.wrk-bubble-active .select2 {
  display: none !important;
}
.wrk-bubble-active .select-bottomtext {
  display: none !important;
}

/* === MOBILE === */
@media (max-width: 767px) {
  .wrk-chip-grid { gap: 5px; }
  .wrk-toggle-chip { font-size: 11px; padding: 6px 10px; max-width: 100%; word-break: break-word; }
  .wrk-toggle-chip .chip-toggle { width: 14px; height: 14px; font-size: 8px; min-width: 14px; }
  .wrk-bubble-search { font-size: 12px !important; padding: 9px 12px 9px 34px !important; }
  .wrk-bubble-selected { padding: 6px 8px; min-height: 32px; }
  .wrk-bubble-chip { font-size: 10px; padding: 3px 8px; }
  .wrk-bubble-count { font-size: 10px; padding: 2px 8px; }
  .wrk-preview-pills { gap: 6px; }
  .wrk-preview-pill { font-size: 11px; padding: 5px 12px; }
  .wrk-bubble-header { gap: 6px; }
}
