/* Shared styles — Release-Progress/index.html + pm.html */
/* Generated 2026-02-22 by Task 12 CSS dedup */

:root {
  --bg:#f5f4f0; --surface:#fff; --surface-alt:#fafaf8; --surface-hover:#f2f1ed;
  --border:#e8e6e0; --border-strong:#d4d1c9;
  --text-primary:#1a1915; --text-secondary:#6b6860; --text-muted:#767370;
  --accent:#1a6b3c; --accent-light:#e8f4ed;
  --green:#1a6b3c; --green-bg:#e8f4ed; --green-dot:#22c55e;
  --amber:#92540a; --amber-bg:#fef3e2; --amber-dot:#f59e0b;
  --blue:#1e4d8c;  --blue-bg:#eff4fd;  --blue-dot:#3b82f6;
  --red:#8c1e1e;   --red-bg:#fdf0f0;   --red-dot:#ef4444;
  --purple:#5b21b6;--purple-bg:#f3f0fd;--purple-dot:#8b5cf6;
  --gray:#4a4a4a;  --gray-bg:#f0f0ee;  --gray-dot:#9ca3af;
  --gold:#7a5800;  --gold-bg:#fffbef;  --gold-border:#e8c840;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text-primary);min-height:100vh;font-size:14px;line-height:1.5}

/* ── HEADER (shared parts) ── */
.header-left{display:flex;align-items:center;gap:14px;flex-shrink:0}
.header-title{font-size:15px;font-weight:600;letter-spacing:-0.3px}
.header-subtitle{font-size:11px;color:var(--text-muted)}
.gen-stamp{font-size:11px;color:var(--text-muted);font-family:'DM Mono',monospace}

/* ── DROPDOWN ── */
.dd-wrap{position:relative}
.dd-btn{display:flex;align-items:center;gap:7px;border-radius:20px;padding:6px 13px;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;user-select:none;white-space:nowrap;font-family:'DM Sans',sans-serif}
.dd-btn .chevron{transition:transform .2s;flex-shrink:0;opacity:.7}
.dd-btn.open .chevron{transform:rotate(180deg)}
.release-btn{background:var(--accent-light);color:var(--accent);border:1px solid #b8ddc9;font-family:'DM Mono',monospace}
.release-btn:hover{background:#d8edde;border-color:#8fc4a5}
.dd-panel{display:none;position:absolute;top:calc(100% + 6px);right:0;background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.10);z-index:300;overflow:hidden;min-width:280px}
.dd-panel.open{display:block;animation:dropIn .15s ease}
@keyframes dropIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.dd-panel-header{padding:9px 13px 7px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.7px;color:var(--text-muted);border-bottom:1px solid var(--border)}
.dd-item{padding:9px 13px;cursor:pointer;display:flex;align-items:center;gap:9px;transition:background .1s;border-bottom:1px solid var(--border);font-size:13px}
.dd-item:last-child{border-bottom:none}
.dd-item:hover{background:var(--surface-alt)}
.dd-item.active{background:var(--accent-light)}
.dd-item.active .dd-item-label{color:var(--accent);font-weight:500}
.dd-item-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dd-item-label{flex:1}
.dd-item-sub{font-size:11px;color:var(--text-muted);font-family:'DM Mono',monospace}
.dd-item-check{color:var(--accent);font-size:12px;font-weight:700}

/* ── MAIN ── */
.main{max-width:1320px;margin:0 auto;padding:28px 40px 60px}

/* ── STATS CARD ── */
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:17px 19px;display:flex;flex-direction:column;gap:6px;transition:box-shadow .15s}
.stat-card:hover{box-shadow:0 4px 16px rgba(0,0,0,.06)}
.stat-dot-row{display:flex;align-items:center;gap:7px}
.stat-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.stat-label{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px}
.stat-number{font-size:28px;font-weight:300;letter-spacing:-1.5px;line-height:1}
.stat-sub{font-size:11px;color:var(--text-muted)}

/* ── PROGRESS FILLS + LEGEND ── */
.pf-done{background:var(--green-dot)}
.pf-wip{background:var(--amber-dot)}
.pf-blocked{background:var(--red-dot)}
.pf-todo{background:var(--gray-dot)}
.legend-item{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-muted)}
.legend-dot{width:6px;height:6px;border-radius:50%}

/* ── COUNTDOWN (shared parts) ── */
.countdown-banner.urgent{background:#fdf0f0;border-color:#f5b8b8}
.countdown-banner.soon{background:#fef3e2;border-color:#fcd89a}
.countdown-left{flex-shrink:0}
.countdown-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.7px;color:var(--text-muted)}
.countdown-dates{font-size:11px;color:var(--text-muted);font-family:'DM Mono',monospace;margin-top:2px}
.countdown-middle{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px}
.cdown-prog-lbl{font-size:10px;color:var(--text-muted)}
.cdown-prog-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s}
.cdown-prog-fill.urgent{background:var(--red-dot)}
.cdown-prog-fill.soon{background:var(--amber-dot)}
.countdown-banner.urgent .cdown-unit{background:#fff5f5;border-color:#f5b8b8}
.countdown-banner.soon .cdown-unit{background:#fffbf0;border-color:#fcd89a}
.cdown-num.urgent{color:var(--red)}
.cdown-num.soon{color:var(--amber)}
.cdown-lbl{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.7px;color:var(--text-muted)}

/* ── FILTER BAR (shared parts) ── */
.filter-lbl{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);margin-right:2px;white-space:nowrap}
.filter-divider{width:1px;height:18px;background:var(--border);margin:0 4px;flex-shrink:0}
.filter-btn{padding:3px 9px;border-radius:20px;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);font-size:11.5px;font-family:'DM Sans',sans-serif;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:4px;white-space:nowrap}
.filter-btn:hover{border-color:var(--border-strong);background:var(--surface-alt)}
.filter-btn.active{background:var(--text-primary);color:#fff;border-color:var(--text-primary)}
.filter-count{background:var(--border);color:var(--text-muted);border-radius:10px;padding:0 5px;font-size:10px;font-weight:600}
.filter-btn.active .filter-count{background:rgba(255,255,255,.25);color:rgba(255,255,255,.85)}

/* ── TEAM FILTER DROPDOWN ── */
.tf-wrap{position:relative;flex-shrink:0}
.tf-btn{display:flex;align-items:center;gap:6px;padding:5px 12px;border:1px solid var(--border);border-radius:20px;background:var(--surface);font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:all .15s}
.tf-btn:hover,.tf-btn.open{border-color:var(--accent);color:var(--accent)}
.tf-dd{display:none;position:absolute;top:calc(100% + 6px);right:0;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:4px;min-width:220px;box-shadow:0 8px 24px rgba(0,0,0,.10);z-index:300}
.tf-dd.open{display:block;animation:dropIn .15s ease}
.tf-ctrl{display:flex;gap:6px;padding:5px 8px 7px;border-bottom:1px solid var(--border);margin-bottom:2px}
.tf-ctrl-btn{flex:1;padding:4px 0;border:1px solid var(--border);border-radius:20px;background:var(--surface);color:var(--text-secondary);font-size:11px;font-weight:500;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s}
.tf-ctrl-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.tf-ctrl-btn:disabled{color:var(--text-muted);cursor:default}
.tf-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;cursor:pointer}
.tf-item:hover{background:var(--surface-alt)}
.tf-item input[type=checkbox]{width:15px;height:15px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}
.tf-name{font-size:13px;color:var(--text-primary)}.tf-empty{padding:8px 12px;font-size:12px;color:var(--text-muted)}

/* ── DATA TABLE (shared rows) ── */
.data-table{width:100%;border-collapse:collapse}
.data-table thead th{padding:9px 14px;text-align:left;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.7px;color:var(--text-muted);background:var(--surface-alt);border-bottom:1px solid var(--border)}
.data-table tbody tr{border-bottom:1px solid var(--border);transition:background .1s}
.data-table tbody tr:last-child{border-bottom:none}
.data-table tbody tr:hover{background:var(--surface-alt)}
.num{text-align:right;font-family:'DM Mono',monospace;font-size:12px}

/* ── TYPE BADGES ── */
.type-badge{width:18px;height:18px;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700;flex-shrink:0}
.tb-story{background:#dbeafe;color:#1d4ed8} .tb-bug{background:#fee2e2;color:#b91c1c}
.tb-task{background:#e8f4ed;color:#1a6b3c} .tb-subtask{background:#f3f0fd;color:#5b21b6}
.tb-active{outline:2px solid currentColor;outline-offset:1px;cursor:pointer}
.type-badge[onclick]{cursor:pointer}

/* ── JIRA KEY ── */
.jira-key{font-family:'DM Mono',monospace;font-size:11px;font-weight:500;color:var(--text-secondary);text-decoration:none;flex-shrink:0;white-space:nowrap}
.jira-key:hover{color:var(--accent);text-decoration:underline}

/* ── STATUS PILL ── */
.spill{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:500;white-space:nowrap;border:1px solid transparent;flex-shrink:0}
.sdot{width:5px;height:5px;border-radius:50%;flex-shrink:0}
.s-done{background:var(--green-bg);color:var(--green);border-color:#b8ddc9}.s-done .sdot{background:var(--green-dot)}
.s-wip{background:var(--amber-bg);color:var(--amber);border-color:#fcd89a}.s-wip .sdot{background:var(--amber-dot)}
.s-review{background:var(--blue-bg);color:var(--blue);border-color:#b3caf5}.s-review .sdot{background:var(--blue-dot)}
.s-selected{background:var(--purple-bg);color:var(--purple);border-color:#c8b8f5}.s-selected .sdot{background:var(--purple-dot)}
.s-blocked{background:var(--red-bg);color:var(--red);border-color:#f5b8b8}.s-blocked .sdot{background:var(--red-dot)}
.s-backlog{background:var(--gray-bg);color:var(--gray);border-color:var(--border-strong)}.s-backlog .sdot{background:var(--gray-dot)}

/* ── PRIORITY PILL ── */
.priority-pill{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:20px;font-size:11px;font-weight:500;white-space:nowrap;cursor:pointer;border:1px solid transparent;transition:opacity .15s;user-select:none}
.priority-pill:hover{opacity:.75}
.p-highest,.p-high{background:#fee2e2;color:#b91c1c;border-color:#f5b8b8}
.p-medium{background:#fef3e2;color:#92540a;border-color:#fcd89a}
.p-low,.p-lowest{background:#eff4fd;color:#1e4d8c;border-color:#b3caf5}
.p-none{background:var(--gray-bg);color:var(--text-muted);border-color:var(--border-strong)}
.pri-panel{display:none;position:fixed;background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.13);z-index:500;overflow:hidden;min-width:210px}
.pri-panel.open{display:block;animation:dropIn .15s ease}
.pri-panel-hdr{padding:8px 12px 6px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.7px;color:var(--text-muted);border-bottom:1px solid var(--border)}
.pri-option{padding:8px 12px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background .1s;border-bottom:1px solid var(--border);font-size:13px}
.pri-option:last-of-type{border-bottom:none}
.pri-option:hover{background:var(--surface-alt)}
.pri-option.current{background:var(--accent-light)}
.pri-option.current .pri-opt-label{color:var(--accent);font-weight:500}
.pri-opt-label{flex:1}
.pri-panel-status{padding:7px 12px;font-size:11px;display:flex;align-items:center;gap:6px;border-top:1px solid var(--border)}
.pri-panel-status.saving{color:var(--text-muted);background:var(--surface-alt)}
.pri-panel-status.error{color:var(--red);background:var(--red-bg)}

/* ── NO SP ── */
.no-sp{color:var(--red);font-size:10px}

/* ── LOADING STATE ── */
.loading-state{padding:24px 0;display:flex;flex-direction:column;gap:12px}
.loading-pulse{border-radius:12px;background:var(--border);animation:pulse 1.4s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.4}50%{opacity:1}}

/* ── FOOTER ── */
.footer{margin-top:28px;padding-top:16px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.footer-left{font-size:11px;color:var(--text-muted)}
.footer-right{font-size:11px;color:var(--text-muted);font-family:'DM Mono',monospace}

@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.fade-in{animation:fadeIn .3s ease both}
