/* ============================================================
   style.css — งาน ผชย.บน.46
   ============================================================ */

/* ── Section 1: Tailwind Replacement CSS ── */
/* === TAILWIND REPLACEMENT CSS === */
*,::before,::after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}
html{line-height:1.5;-webkit-text-size-adjust:100%}
body{margin:0}
hr{height:0;color:inherit;border-top-width:1px}
table{text-indent:0;border-color:inherit;border-collapse:collapse}
button,input,select,textarea{font-family:inherit;font-size:100%;line-height:inherit;color:inherit;margin:0;padding:0}
button,select{text-transform:none}
button,[type='button'],[type='reset'],[type='submit']{-webkit-appearance:button;background-color:transparent;background-image:none}
:-moz-focusring{outline:auto}
:-moz-ui-invalid{box-shadow:none}
::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}
[type='search']{-webkit-appearance:textfield;outline-offset:-2px}
::-webkit-search-decoration{-webkit-appearance:none}
::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}
summary{display:list-item}
blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}
fieldset{margin:0;padding:0}
legend{padding:0}
ol,ul,menu{list-style:none;margin:0;padding:0}
textarea{resize:vertical}
input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}
button,[role="button"]{cursor:pointer}
:disabled{cursor:default}
img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}
img,video{max-width:100%;height:auto}

/* Layout */
.block{display:block}.inline{display:inline}.inline-block{display:inline-block}
.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}
.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}
.flex-1{flex:1 1 0%}.flex-shrink-0{flex-shrink:0}
.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}
.justify-start{justify-content:flex-start}.justify-center{justify-content:center}
.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}
.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}
.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}

/* Gaps */
.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}
.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}

/* Spacing */
.space-x-1>*+*{margin-left:.25rem}.space-x-2>*+*{margin-left:.5rem}.space-x-4>*+*{margin-left:1rem}
.space-y-0\.5>*+*{margin-top:.125rem}.space-y-2>*+*{margin-top:.5rem}
.space-y-3>*+*{margin-top:.75rem}.space-y-4>*+*{margin-top:1rem}
.divide-y>*+*{border-top-width:1px}.divide-gray-600>*+*{border-color:#4b5563}

/* Padding */
.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}
.p-6{padding:1.5rem}.p-8{padding:2rem}
.px-1{padding-left:.25rem;padding-right:.25rem}.px-2{padding-left:.5rem;padding-right:.5rem}
.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}
.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}
.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}
.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}
.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}
.py-8{padding-top:2rem;padding-bottom:2rem}.py-12{padding-top:3rem;padding-bottom:3rem}
.pt-2{padding-top:.5rem}.pt-3{padding-top:.75rem}
.pb-4{padding-bottom:1rem}.pr-1{padding-right:.25rem}

/* Margin */
.m-0{margin:0}.mx-auto{margin-left:auto;margin-right:auto}
.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}
.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}
.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-6{margin-top:1.5rem}
.ml-3{margin-left:.75rem}

/* Width / Height */
.w-full{width:100%}.w-5{width:1.25rem}.w-9{width:2.25rem}.w-12{width:3rem}
.w-14{width:3.5rem}.w-24{width:6rem}.w-32{width:8rem}.w-3\.5{width:.875rem}
.h-1{height:.25rem}.h-2{height:.5rem}.h-5{height:1.25rem}.h-9{height:2.25rem}
.h-12{height:3rem}.h-14{height:3.5rem}.h-24{height:6rem}.h-32{height:8rem}
.h-3\.5{height:.875rem}
.min-w-0{min-width:0}.min-h-\[2rem\]{min-height:2rem}
.max-w-md{max-width:28rem}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}
.max-w-6xl{max-width:72rem}.max-w-7xl{max-width:80rem}

/* Position */
.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}
.inset-0{top:0;right:0;bottom:0;left:0}
.top-0{top:0}.top-2\.5{top:.625rem}.top-4{top:1rem}
.right-3{right:.75rem}.right-4{right:1rem}
.bottom-0{bottom:0}.bottom-4{bottom:1rem}.left-0{left:0}.left-4{left:1rem}

/* Overflow */
.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}

/* Border */
.border{border-width:1px}.border-t{border-top-width:1px}.border-b{border-bottom-width:1px}
.border-b-2{border-bottom-width:2px}.border-b-4{border-bottom-width:4px}
.border-gray-300{border-color:#d1d5db}.border-gray-500{border-color:#6b7280}
.border-gray-600{border-color:#4b5563}.border-opacity-50{border-opacity:.5;--tw-border-opacity:.5}
.border-white\/30{border-color:rgba(255,255,255,.3)}
.border-blue-400{border-color:#60a5fa}.border-blue-500{border-color:#3b82f6}
.border-green-400{border-color:#4ade80}.border-green-500{border-color:#22c55e}
.border-yellow-400{border-color:#facc15}.border-yellow-500{border-color:#eab308}
/* card border override — จางลงกว่า default */
.work-card.border-green-500  { border-color: rgba(34,197,94,.35)  !important; }
.work-card.border-blue-500   { border-color: rgba(59,130,246,.35) !important; }
.work-card.border-yellow-500 { border-color: rgba(234,179,8,.35)  !important; }
.rounded{border-radius:.25rem}.rounded-lg{border-radius:.5rem}
.rounded-full{border-radius:9999px}.rounded-t-xl{border-radius:.75rem .75rem 0 0}

/* Background */
.bg-white{background-color:#fff}
.bg-gray-200{background-color:#e5e7eb}.bg-gray-500{background-color:#6b7280}
.bg-gray-600{background-color:#4b5563}.bg-gray-700{background-color:#374151}
.bg-gray-800{background-color:#1f2937}
.bg-blue-500{background-color:#3b82f6}.bg-blue-600{background-color:#2563eb}
.bg-green-600{background-color:#16a34a}.bg-yellow-600{background-color:#ca8a04}
.bg-orange-600{background-color:#ea580c}.bg-purple-600{background-color:#9333ea}
.bg-red-500{background-color:#ef4444}
.bg-opacity-20{background-color:rgba(0,0,0,0);--tw-bg-opacity:.2}
.bg-opacity-40{opacity:1}
.bg-opacity-50{opacity:1}
.bg-opacity-60{opacity:1}

/* Real bg-opacity via inline approach */
.bg-gray-700.bg-opacity-50{background-color:rgba(55,65,81,.5)}
.bg-gray-700.bg-opacity-60{background-color:rgba(55,65,81,.6)}
.bg-gray-800.bg-opacity-40{background-color:rgba(31,41,55,.4)}
.bg-gray-800.bg-opacity-50{background-color:rgba(31,41,55,.5)}
.bg-gray-600.bg-opacity-50{background-color:rgba(75,85,99,.5)}
.bg-green-600.bg-opacity-20{background-color:rgba(22,163,74,.2)}
.bg-blue-600.bg-opacity-20{background-color:rgba(37,99,235,.2)}
.bg-yellow-600.bg-opacity-20{background-color:rgba(202,138,4,.2)}

/* Gradient */
.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}
.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}
.from-gray-600{--tw-gradient-from:#4b5563;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to,rgba(75,85,99,0))}
.via-gray-700{--tw-gradient-stops:var(--tw-gradient-from),#374151,var(--tw-gradient-to,rgba(55,65,81,0))}
.to-gray-800{--tw-gradient-to:#1f2937}
.from-blue-400{--tw-gradient-from:#60a5fa;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to,rgba(96,165,250,0))}
.from-blue-500{--tw-gradient-from:#3b82f6;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to,rgba(59,130,246,0))}
.to-blue-500{--tw-gradient-to:#3b82f6}
.to-blue-600{--tw-gradient-to:#2563eb}
.via-purple-500{--tw-gradient-stops:var(--tw-gradient-from),#a855f7,var(--tw-gradient-to,rgba(168,85,247,0))}

/* Opacity */
.opacity-5{opacity:.05}.opacity-10{opacity:.1}

/* Shadow */
.shadow-sm{box-shadow:0 1px 2px 0 rgba(0,0,0,.05)}
.shadow-md{box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06)}
.shadow-lg{box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05)}
.shadow-2xl{box-shadow:0 25px 50px -12px rgba(0,0,0,.25)}
.drop-shadow-md{filter:drop-shadow(0 4px 3px rgba(0,0,0,.07)) drop-shadow(0 2px 2px rgba(0,0,0,.06))}
.drop-shadow-lg{filter:drop-shadow(0 10px 8px rgba(0,0,0,.04)) drop-shadow(0 4px 3px rgba(0,0,0,.1))}

/* Text */
.text-white{color:#fff}.text-gray-200{color:#e5e7eb}.text-gray-300{color:#d1d5db}
.text-gray-400{color:#9ca3af}.text-gray-800{color:#1f2937}
.text-blue-400{color:#60a5fa}.text-green-400{color:#4ade80}
.text-yellow-300{color:#fde047}.text-yellow-400{color:#facc15}
.text-red-400{color:#f87171}.text-purple-400{color:#c084fc}
.text-xs{font-size:.75rem;line-height:1rem}.text-sm{font-size:.875rem;line-height:1.25rem}
.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}
.text-xl{font-size:1.25rem;line-height:1.75rem}.text-2xl{font-size:1.5rem;line-height:2rem}
.text-6xl{font-size:3.75rem;line-height:1}
.font-normal{font-weight:400}.font-medium{font-weight:500}
.font-semibold{font-weight:600}.font-bold{font-weight:700}
.italic{font-style:italic}.leading-none{line-height:1}
.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}
.whitespace-nowrap{white-space:nowrap}
.uppercase{text-transform:uppercase}.tracking-wide{letter-spacing:.025em}

/* Cursor / pointer */
.cursor-pointer{cursor:pointer}.pointer-events-none{pointer-events:none}

/* Blur */
.blur-lg{filter:blur(16px)}.blur-xl{filter:blur(24px)}
.backdrop-blur-md{backdrop-filter:blur(12px)}

/* Transform / Transition */
.transform{transform:translateX(var(--tw-translate-x,0)) translateY(var(--tw-translate-y,0)) rotate(var(--tw-rotate,0)) skewX(var(--tw-skew-x,0)) skewY(var(--tw-skew-y,0)) scaleX(var(--tw-scale-x,1)) scaleY(var(--tw-scale-y,1))}
.-translate-y-1{--tw-translate-y:-0.25rem;transform:translateY(-0.25rem)}
.transition-all{transition:all .15s ease}.transition-colors{transition:color .15s ease,background-color .15s ease,border-color .15s ease}

/* Focus */
.focus\:outline-none:focus{outline:none}
.focus\:ring-2:focus{box-shadow:0 0 0 2px rgba(59,130,246,.5)}
.focus\:ring-blue-500:focus{box-shadow:0 0 0 2px #3b82f6}

/* Hover */
.hover\:bg-blue-700:hover{background-color:#1d4ed8}
.hover\:bg-gray-600:hover{background-color:#4b5563}
.hover\:bg-gray-700:hover{background-color:#374151}
.hover\:bg-green-700:hover{background-color:#15803d}
.hover\:bg-orange-700:hover{background-color:#c2410c}
.hover\:bg-purple-700:hover{background-color:#7e22ce}
.hover\:bg-opacity-30:hover{background-color:rgba(0,0,0,0)}
.hover\:bg-opacity-40:hover{opacity:1}
.hover\:bg-opacity-50:hover{opacity:1}
.hover\:text-white:hover{color:#fff}
.hover\:text-gray-200:hover{color:#e5e7eb}
.hover\:border-blue-400:hover{border-color:#60a5fa}

/* Responsive */
@media (min-width:640px){
  .sm\:inline{display:inline}
  .sm\:hidden{display:none}
}
@media (min-width:768px){
  .md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
}
@media (min-width:1024px){
  .lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .lg\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}
}

/* Table */
table{width:100%}
thead{background-color:#4b5563}
th{padding:.75rem .5rem;text-align:left;font-size:.875rem;font-weight:600}
td{padding:.5rem}

/* ── Section 2: Custom Application CSS ── */
* { font-family: 'Sarabun', sans-serif !important; box-sizing: border-box; }
    body { background: #374151; }

    .tab-content { display: none; }
    .tab-content.active { display: block; }

    /* Report modal — mobile responsive */
    @media (max-width: 640px) {
      .report-hide-mobile { display: none !important; }
      .report-text-xs td  { font-size: 11px !important; padding: 6px 4px !important; }
      .report-text-xs th  { font-size: 10px !important; padding: 6px 4px !important; }
      #report-performer-stats .rub-bar-col { display: none !important; }
    }

    /* section header — ชื่อตัด ellipsis บนมือถือ จำนวนงานไม่ตัด */
    .section-title-text {
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
      min-width: 0;
    }

    /* ── Card layout ───────────────────────────────── */

    /* === DESKTOP === */
    .card-inner {
      display: flex; flex-direction: row;
      align-items: stretch; gap: 0;
    }
    .card-main { flex:1; min-width:0; padding:14px 16px; }
    .card-title {
      font-size:15px; font-weight:700; color:#fff;
      margin-bottom:4px; line-height:1.35; word-break:break-word;
    }
    .card-location { font-size:13px; color:#d1d5db; margin-bottom:10px; }
    .card-label    { color:#fde047; font-weight:500; }
    .card-extra    { font-size:12px; color:#d1d5db; margin-top:6px; }
    .card-issues   { font-size:12px; color:#fca5a5; margin-top:6px; }
    .card-actions {
      display:flex; flex-direction:column;
      align-items:center; justify-content:center;
      gap:10px; flex-shrink:0;
      padding:14px 12px; border-left:none;
    }
    .card-actions button { width:88px; text-align:center; }
    .card-meta { display:flex; flex-direction:row; font-size:13px; color:#e5e7eb; }
    .card-meta-item { flex:1; padding-right:12px; }
    .card-meta-item:last-child { padding-right:0; }

    /* === MOBILE === */
    @media (max-width: 640px) {
      .work-card { position: relative; }
      .card-inner { flex-direction: column; }
      .card-main {
        /* เว้นขวาบนให้ badge+update ไม่ทับ */
        padding: 12px 14px 10px 14px;
      }
      .card-actions { display: none; }

      /* badge มุมขวาบน */
      .mob-badge {
        position: absolute;
        top: 10px;
        right: 10px;
        max-width: 140px;
        z-index: 2;
      }
      .mob-badge .status-badge {
        display: block;
        text-align: center;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        max-width: 140px;
        line-height: 1.4;
      }

      /* ปุ่ม update ใต้ badge */
      .mob-update {
        position: absolute;
        top: 40px;
        right: 10px;
        z-index: 2;
      }
      .mob-update button {
        font-size: 12px;
        white-space: nowrap;
        min-width: 72px;
        padding-left: 10px;
        padding-right: 10px;
      }

      /* ชื่องาน + สถานที่: เว้นขวาให้ badge ไม่ทับ */
      .card-title    { padding-right: 150px; min-height: 22px; }
      .card-location { padding-right: 80px; margin-bottom: 8px; }

      /* meta แนวตั้ง */
      .card-meta { flex-direction:column; gap:3px; }
      .card-meta-item { flex:none; padding-right:0; }
    }

    @media (min-width: 641px) {
      .mob-badge  { display: none; }
      .mob-update { display: none; }
    }

    /* ── Stat bar — full width, 2-col on mobile ───────────── */
    .stat-row {
      display: grid;
      grid-template-columns: repeat(6, 1fr);
      gap: 8px;
      width: 100%;
      padding: 2px 0 6px;
    }
    @media (max-width: 640px) {
      .stat-row { grid-template-columns: repeat(2, 1fr); gap: 8px; }
    }
    @media (min-width: 641px) and (max-width: 900px) {
      .stat-row { grid-template-columns: repeat(3, 1fr); }
    }

    .stat-pill {
      width: 100%;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 5px;
      padding: 12px 8px;
      border-radius: 10px;
      background: #4b5563;
      border: none;
      color: #fff;
      cursor: pointer;
      transition: background .18s, transform .18s, box-shadow .18s;
      user-select: none;
      line-height: 1;
      box-shadow: 0 2px 6px rgba(0,0,0,.25);
    }
    .stat-pill:hover {
      background: #5a6478;
      transform: translateY(-2px);
      box-shadow: 0 6px 16px rgba(0,0,0,.35);
    }
    .stat-pill .pill-count {
      font-size: 26px;
      font-weight: 700;
      line-height: 1;
      color: #fff;
    }
    .stat-pill .pill-label {
      font-size: 12px;
      font-weight: 500;
      color: #d1d5db;
      text-align: center;
    }
    .stat-pill.active {
      background: #22c55e !important;
      box-shadow: 0 4px 16px rgba(34,197,94,.4);
      transform: translateY(-2px);
    }
    .stat-pill.active .pill-count { color: #fff; }
    .stat-pill.active .pill-label { color: #dcfce7; }

    /* badge จำนวนงาน กำลังดำเนินการ — มุมขวาบนของ pill */
    .stat-pill { position: relative; }
    .pill-inprog {
      position: absolute;
      top: -7px;
      right: -7px;
      background: #f97316;
      color: #fff;
      font-size: 11px;
      font-weight: 700;
      min-width: 18px;
      height: 18px;
      border-radius: 999px;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 0 4px;
      box-shadow: 0 0 0 2px #374151;
      animation: pip-blink 1.4s ease-in-out infinite;
      line-height: 1;
      z-index: 2;
    }
    @keyframes pip-blink {
      0%, 100% { opacity: 1; transform: scale(1);   }
      50%       { opacity: .6; transform: scale(.88); }
    }

    .stat-btn { cursor: pointer; transition: all 0.2s ease; }
    .stat-btn:hover { transform: translateY(-2px); }
    .stat-btn.active {
      background-color: rgb(34 197 94) !important;
      box-shadow: 0 0 20px rgba(34,197,94,0.5);
      transform: translateY(-2px);
    }

    @keyframes spin { to { transform: rotate(360deg); } }
    .animate-spin { animation: spin 1s linear infinite; }
    @keyframes bounce { 0%,100%{transform:translateY(-25%)} 50%{transform:none} }
    .animate-bounce { animation: bounce 1s infinite; }
    @keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.5} }
    .animate-pulse { animation: pulse 2s cubic-bezier(0.4,0,0.6,1) infinite; }

    /* Modal overlay */
    @keyframes modalIn  { from { opacity:0; transform:scale(.88) translateY(12px); } to { opacity:1; transform:scale(1) translateY(0); } }
    @keyframes modalOut { from { opacity:1; transform:scale(1) translateY(0); }  to { opacity:0; transform:scale(.88) translateY(12px); } }
    @keyframes overlayIn  { from { opacity:0; } to { opacity:1; } }
    @keyframes overlayOut { from { opacity:1; } to { opacity:0; } }

    .modal-overlay {
      display: none; position: fixed; inset: 0;
      background: rgba(0,0,0,0.65);
      backdrop-filter: blur(3px);
      z-index: 50; align-items: center; justify-content: center; padding: 1rem;
    }
    .modal-overlay.open { display: flex; animation: overlayIn .22s ease forwards; }
    .modal-overlay.closing { animation: overlayOut .22s ease forwards; }
    .modal-box {
      background: rgba(30,40,55,0.97);
      backdrop-filter: blur(16px);
      border: 1px solid rgba(255,255,255,0.15);
      border-radius: 1rem;
      color: white;
      max-height: 90vh;
      overflow-y: auto;
      width: 100%;
      box-shadow: 0 24px 60px rgba(0,0,0,.55);
    }
    .modal-overlay.open .modal-box { animation: modalIn .28s cubic-bezier(.34,1.38,.64,1) forwards; }
    .modal-overlay.closing .modal-box { animation: modalOut .22s ease forwards; }

    /* Member picker */
    .member-checkbox-item { display: flex; align-items: center; gap: 0.5rem; padding: 0.4rem 0.6rem; border-radius: 0.5rem; cursor: pointer; transition: background 0.15s; }
    .member-checkbox-item:hover { background: rgba(255,255,255,0.1); }
    .member-checkbox-item input[type=checkbox] { width: 1rem; height: 1rem; accent-color: #3b82f6; cursor: pointer; flex-shrink: 0; }
    .unit-group-header { font-size: 0.75rem; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; padding: 0.4rem 0.6rem 0.2rem; color: #fbbf24; border-bottom: 1px solid rgba(255,255,255,0.1); margin-bottom: 0.25rem; }
    .member-tag { display: inline-flex; align-items: center; gap: 0.3rem; background: rgba(59,130,246,0.3); border: 1px solid rgba(59,130,246,0.5); border-radius: 9999px; padding: 0.15rem 0.6rem; font-size: 0.8rem; }
    .member-tag .remove-tag { cursor: pointer; color: #93c5fd; font-size: 0.9rem; line-height: 1; }
    .member-tag .remove-tag:hover { color: #ef4444; }
    .other-unit-toggle { background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.2); border-radius: 0.5rem; padding: 0.4rem 0.75rem; font-size: 0.85rem; cursor: pointer; transition: background 0.15s; }
    .other-unit-toggle:hover { background: rgba(255,255,255,0.15); }
    .other-unit-tab.active { background: #2563eb; color: white; border-color: #3b82f6; }
    .members-loading { display: flex; align-items: center; gap: 0.5rem; color: #9ca3af; font-size: 0.85rem; padding: 0.5rem; }
    .members-loading .dot { width: 6px; height: 6px; background: #6b7280; border-radius: 50%; animation: bounce 1s infinite; }
    .members-loading .dot:nth-child(2) { animation-delay: 0.15s; }
    .members-loading .dot:nth-child(3) { animation-delay: 0.3s; }
  
    /* ── Scroll to top button ─────────────────────────── */
    #scroll-top-btn {
      position: fixed;
      bottom: 28px;
      right: 24px;
      width: 46px;
      height: 46px;
      border-radius: 50%;
      background: linear-gradient(135deg, #16a34a, #22c55e);
      color: #fff;
      border: none;
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      box-shadow: 0 4px 16px rgba(34,197,94,.45);
      opacity: 0;
      transform: translateY(16px) scale(0.85);
      transition: opacity .3s ease, transform .3s ease, box-shadow .2s ease;
      pointer-events: none;
      z-index: 999;
    }
    #scroll-top-btn.visible {
      opacity: 1;
      transform: translateY(0) scale(1);
      pointer-events: auto;
    }
    #scroll-top-btn:hover {
      box-shadow: 0 8px 24px rgba(34,197,94,.65);
      transform: translateY(-3px) scale(1.08);
    }
    #scroll-top-btn:active {
      transform: scale(0.95);
    }
    #scroll-top-btn svg {
      width: 22px; height: 22px;
      stroke: #fff; stroke-width: 2.5;
      fill: none; stroke-linecap: round; stroke-linejoin: round;
    }

/* ── Section 3: Loading Bar Shimmer Animation ── */
@keyframes shimmer {
      0%   { transform:translateX(-100%); }
      100% { transform:translateX(350%); }
    }