/* ── Reset ──────────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#f5f6f8;--surface:#fff;--border:#e5e7eb;--border-lt:#f0f1f3;
  --text:#111827;--text2:#4b5563;--text3:#9ca3af;
  --accent:#4f46e5;--accent-bg:#eef2ff;--accent-hover:#4338ca;
  --pending:#3b82f6;--pending-bg:#eff6ff;
  --in-process:#f59e0b;--in-process-bg:#fffbeb;
  --completed:#10b981;--completed-bg:#ecfdf5;
  --failed:#ef4444;--failed-bg:#fef2f2;
  --sidebar-w:232px;--r:10px;--rs:6px;
  --shadow:0 1px 3px rgba(0,0,0,.04),0 1px 2px rgba(0,0,0,.06);
  --shadow-lg:0 4px 16px rgba(0,0,0,.08);
  --t:150ms ease;
  --font:'Inter',system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
}
html{font-size:14.5px}
body{font-family:var(--font);background:var(--bg);color:var(--text);display:flex;min-height:100vh;-webkit-font-smoothing:antialiased}

/* ── Sidebar ────────────────────────────────────────────────────────────── */
.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100vh;position:sticky;top:0;overflow:hidden;z-index:10}
.sidebar__header{display:flex;align-items:center;gap:10px;padding:20px 16px 16px;border-bottom:1px solid var(--border)}
.sidebar__logo{width:32px;height:32px;display:grid;place-items:center;background:var(--accent);color:#fff;border-radius:var(--rs);flex-shrink:0}
.sidebar__title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text3)}
.org-list{list-style:none;overflow-y:auto;flex:1;padding:6px 0}
.org-item{padding:10px 16px;font-size:.88rem;font-weight:500;color:var(--text2);cursor:pointer;transition:all var(--t);border-left:3px solid transparent;display:flex;align-items:center;gap:9px}
.org-item:hover{background:var(--bg);color:var(--text)}
.org-item.active{background:var(--accent-bg);color:var(--accent);border-left-color:var(--accent);font-weight:600}
.org-dot{width:7px;height:7px;border-radius:50%;background:var(--border);flex-shrink:0;transition:background var(--t)}
.org-item.active .org-dot{background:var(--accent)}

/* ── Main ───────────────────────────────────────────────────────────────── */
.main{flex:1;padding:0 28px 48px;min-width:0;max-width:1060px}

/* ── Topbar ─────────────────────────────────────────────────────────────── */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:20px 0 16px;border-bottom:1px solid var(--border);margin-bottom:20px}
.topbar__title{font-size:1.15rem;font-weight:700;letter-spacing:-.01em}
.refresh-ts{font-size:.72rem;color:var(--text3);font-family:var(--mono)}

/* Auto-refresh checkbox */
.auto-refresh-toggle{display:flex;align-items:center;gap:6px;cursor:pointer;padding:5px 10px;border:1px solid var(--border);border-radius:var(--rs);font-size:.78rem;font-weight:500;color:var(--text2);transition:all var(--t)}
.auto-refresh-toggle:hover{border-color:var(--accent);color:var(--accent)}
.auto-refresh-toggle input[type="checkbox"]{width:15px;height:15px;cursor:pointer;accent-color:var(--accent);margin:0;pointer-events:auto}
.auto-refresh-toggle.active{background:var(--accent-bg);border-color:var(--accent);color:var(--accent)}

.btn-refresh{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border:1px solid var(--border);border-radius:var(--rs);background:var(--surface);font-family:var(--font);font-size:.8rem;font-weight:600;color:var(--text2);cursor:pointer;transition:all var(--t)}
.btn-refresh:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}
.btn-refresh.spinning .refresh-icon--spin{animation:spin .6s linear infinite}
.btn-refresh.done{border-color:var(--completed);color:var(--completed);background:var(--completed-bg)}
.btn-refresh.done .refresh-icon--spin{display:none}
.btn-refresh.done .refresh-icon--check{display:inline-block !important}
.btn-refresh:not(.done) .refresh-icon--check{display:none !important}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Modal ──────────────────────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.35);backdrop-filter:blur(3px);z-index:100;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{background:var(--surface);border-radius:var(--r);box-shadow:0 20px 60px rgba(0,0,0,.15);width:94%;max-width:780px;max-height:88vh;display:flex;flex-direction:column;animation:slideUp .25s ease}
@keyframes slideUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.modal__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);gap:12px;flex-shrink:0}
.modal__title-wrap{min-width:0;flex:1}
.modal__title{font-size:.95rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.modal__subtitle{font-size:.72rem;color:var(--text3);font-family:var(--mono)}
.modal__controls{display:flex;align-items:center;gap:8px;flex-shrink:0}
.modal__close{display:grid;place-items:center;width:32px;height:32px;border:1px solid var(--border);border-radius:var(--rs);background:var(--surface);color:var(--text3);cursor:pointer;transition:all var(--t)}
.modal__close:hover{border-color:var(--failed);color:var(--failed);background:var(--failed-bg)}
.modal__search{display:flex;align-items:center;gap:8px;padding:10px 20px;border-bottom:1px solid var(--border-lt);color:var(--text3);flex-shrink:0}
.modal__search input{flex:1;border:none;outline:none;font-family:var(--font);font-size:.86rem;color:var(--text);background:transparent}
.modal__search input::placeholder{color:var(--text3)}
.modal__body{overflow-y:auto;flex:1;min-height:0}

/* ── Tabs ───────────────────────────────────────────────────────────────── */
.tab-bar{display:flex;gap:2px;margin-bottom:20px;border-bottom:2px solid var(--border);padding-bottom:0}
.tab{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;font-family:var(--font);font-size:.85rem;font-weight:600;color:var(--text3);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:all var(--t)}
.tab:hover{color:var(--text)}
.tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.tab-content{display:none}
.tab-content.active{display:block}

/* ── Welcome ────────────────────────────────────────────────────────────── */
.welcome{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:90px 24px;text-align:center}
.welcome__icon{width:80px;height:80px;display:grid;place-items:center;background:var(--accent-bg);color:var(--accent);border-radius:50%;margin-bottom:18px}
.welcome h2{font-size:1.12rem;font-weight:700;margin-bottom:5px}
.welcome p{font-size:.9rem;color:var(--text3);max-width:340px}

/* ── Panel ──────────────────────────────────────────────────────────────── */
.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);margin-bottom:20px;overflow:hidden}
.panel__header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border-lt)}
.panel__title{font-size:.92rem;font-weight:700}
.panel__badge{font-size:.72rem;font-weight:600;color:var(--text3);background:var(--bg);padding:3px 10px;border-radius:20px}

/* ── Search Box ─────────────────────────────────────────────────────────── */
.search-box{display:flex;align-items:center;gap:8px;padding:10px 18px;border-bottom:1px solid var(--border-lt);color:var(--text3)}
.search-box input{flex:1;border:none;outline:none;font-family:var(--font);font-size:.86rem;color:var(--text);background:transparent}
.search-box input::placeholder{color:var(--text3)}

/* ── Template Grid ──────────────────────────────────────────────────────── */
.templates-panel{display:flex;flex-direction:column;max-height:420px}
.template-grid{display:grid;grid-template-columns:1fr;gap:0;overflow-y:auto;flex:1;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.template-grid::-webkit-scrollbar{width:5px}
.template-grid::-webkit-scrollbar-track{background:transparent}
.template-grid::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.template-grid::-webkit-scrollbar-thumb:hover{background:var(--text3)}

.tmpl-card{display:flex;align-items:center;gap:10px;padding:9px 16px;cursor:pointer;transition:all var(--t);border-bottom:1px solid var(--border-lt)}
.tmpl-card:last-child{border-bottom:none}
.tmpl-card:hover{background:#f8f9fb}
.tmpl-card.active{background:var(--accent-bg);border-left:3px solid var(--accent);padding-left:13px}
.tmpl-card__info{flex:1;min-width:0;display:flex;align-items:center;gap:10px}
.tmpl-card__name{font-size:.84rem;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}
.tmpl-card.active .tmpl-card__name{color:var(--accent);font-weight:600}
.tmpl-card__uuid{font-family:var(--mono);font-size:.64rem;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px;flex-shrink:0}
.tmpl-card.active .tmpl-card__uuid{color:var(--accent);opacity:.6}
.tmpl-card__date{font-size:.7rem;color:var(--text3);white-space:nowrap;flex-shrink:0}
.tmpl-card__arrow{color:var(--text3);flex-shrink:0;opacity:0;transition:opacity var(--t)}
.tmpl-card:hover .tmpl-card__arrow,.tmpl-card.active .tmpl-card__arrow{opacity:1}

.template-empty{padding:28px 16px;text-align:center;color:var(--text3);font-size:.86rem}

/* Load more */
.load-more-wrap{display:flex;align-items:center;justify-content:center;gap:12px;padding:14px 18px;border-top:1px solid var(--border-lt)}
.btn-load-more{padding:7px 22px;border:1px solid var(--accent);border-radius:var(--rs);background:transparent;color:var(--accent);font-family:var(--font);font-size:.82rem;font-weight:600;cursor:pointer;transition:all var(--t)}
.btn-load-more:hover{background:var(--accent);color:#fff}
.load-more-info{font-size:.75rem;color:var(--text3)}

/* ── Execution List ─────────────────────────────────────────────────────── */
.exec-list-wrap{max-height:200px;overflow-y:auto}
.exec-list{list-style:none}
.exec-item{display:flex;align-items:center;gap:12px;padding:10px 18px;font-size:.84rem;cursor:pointer;transition:all var(--t);border-bottom:1px solid var(--border-lt)}
.exec-item:last-child{border-bottom:none}
.exec-item:hover{background:#f8f9fb}
.exec-item.active{background:var(--accent-bg)}
.exec-id{font-family:var(--mono);font-size:.8rem;font-weight:500;min-width:68px}
.exec-item.active .exec-id{color:var(--accent);font-weight:600}
.exec-date{font-size:.78rem;color:var(--text3);min-width:125px}
.exec-status{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:20px;font-size:.7rem;font-weight:600;white-space:nowrap}
.exec-status::before{content:'';width:5px;height:5px;border-radius:50%;flex-shrink:0}
.exec-status--pending-data-generation{background:var(--pending-bg);color:var(--pending)}
.exec-status--pending-data-generation::before{background:var(--pending);animation:pulse 1.5s ease infinite}
.exec-status--completed{background:var(--completed-bg);color:var(--completed)}
.exec-status--completed::before{background:var(--completed)}
.exec-status--completed-with-errors{background:var(--in-process-bg);color:var(--in-process)}
.exec-status--completed-with-errors::before{background:var(--in-process)}
.exec-status--failed{background:var(--failed-bg);color:var(--failed)}
.exec-status--failed::before{background:var(--failed)}
.exec-latest{font-size:.64rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--accent);background:var(--accent-bg);padding:2px 7px;border-radius:4px}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* ── Image Progress ─────────────────────────────────────────────────────── */
.image-progress{padding:18px;border-top:1px solid var(--border)}
.progress-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.progress-title{font-size:.9rem;font-weight:700}
.progress-exec-badge{font-family:var(--mono);font-size:.76rem;color:var(--accent);background:var(--accent-bg);padding:3px 10px;border-radius:var(--rs)}

.progress-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:18px}
.pcard{padding:14px 12px;border-radius:var(--r);text-align:center;transition:transform var(--t)}
.pcard:hover{transform:translateY(-1px)}
.pcard__val{font-size:1.5rem;font-weight:700;line-height:1;margin-bottom:3px;font-family:var(--mono);letter-spacing:-.02em}
.pcard__lbl{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.pcard--completed{background:var(--completed-bg)}.pcard--completed .pcard__val,.pcard--completed .pcard__lbl{color:var(--completed)}
.pcard--in-process{background:var(--in-process-bg)}.pcard--in-process .pcard__val,.pcard--in-process .pcard__lbl{color:var(--in-process)}
.pcard--pending{background:var(--pending-bg)}.pcard--pending .pcard__val,.pcard--pending .pcard__lbl{color:var(--pending)}
.pcard--failed{background:var(--failed-bg)}.pcard--failed .pcard__val,.pcard--failed .pcard__lbl{color:var(--failed)}

.progress-bar-wrap{margin-bottom:18px}
.progress-bar{height:12px;background:var(--bg);border-radius:8px;overflow:hidden;margin-bottom:6px}
.progress-bar__fill{height:100%;background:linear-gradient(90deg,var(--completed),#34d399);border-radius:8px;transition:width 600ms cubic-bezier(.4,0,.2,1);width:0;position:relative}
.progress-bar__fill::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:shimmer 2s infinite}
@keyframes shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
.progress-bar__info{display:flex;justify-content:space-between;font-size:.8rem}
.progress-bar__info span:first-child{font-weight:700;color:var(--completed);font-family:var(--mono)}
.progress-bar__info span:last-child{color:var(--text3)}

.progress-meta{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding-top:14px;border-top:1px solid var(--border-lt)}
.meta-item{display:flex;flex-direction:column;gap:1px}
.meta-lbl{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text3)}
.meta-val{font-size:.82rem;color:var(--text)}
.meta-val.error{color:var(--failed)}

/* ── SFTP Panel ─────────────────────────────────────────────────────────── */
.sftp-toolbar{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:12px;padding:16px 18px;border-bottom:1px solid var(--border-lt)}
.sftp-dates{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap}
.sftp-field{display:flex;flex-direction:column;gap:4px}
.sftp-field label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text3)}
.sftp-field input{padding:7px 10px;border:1px solid var(--border);border-radius:var(--rs);font-family:var(--font);font-size:.84rem;color:var(--text);outline:none;transition:border var(--t)}
.sftp-field input:focus{border-color:var(--accent)}

.sftp-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:var(--rs);font-family:var(--font);font-size:.82rem;font-weight:600;cursor:pointer;transition:all var(--t);white-space:nowrap;height:36px}
.sftp-btn--fetch{background:var(--accent);color:#fff}
.sftp-btn--fetch:hover{background:var(--accent-hover)}
.sftp-btn--fetch:disabled{opacity:.5;cursor:not-allowed}
.sftp-btn--download{background:var(--completed);color:#fff}
.sftp-btn--download:hover{background:#059669}

.sftp-welcome{display:flex;flex-direction:column;align-items:center;gap:10px;padding:50px 20px;text-align:center}
.sftp-welcome p{color:var(--text3);font-size:.9rem;max-width:360px}
.sftp-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:40px;color:var(--text3);font-size:.88rem}
.spinner{width:20px;height:20px;border:2.5px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}

.sftp-summary{display:flex;gap:12px;padding:12px 18px;border-bottom:1px solid var(--border-lt)}
.sftp-summary span{background:var(--bg);padding:5px 12px;border-radius:var(--rs);font-size:.82rem;font-weight:600;color:var(--text2)}
.sftp-summary span strong{color:var(--text)}

.sftp-table-wrap{overflow:auto;max-height:460px}
.sftp-table{width:100%;border-collapse:collapse;min-width:680px}
.sftp-table thead th{position:sticky;top:0;background:var(--bg);padding:10px 14px;font-size:.7rem;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;text-align:left;border-bottom:1px solid var(--border)}
.sftp-table tbody tr{border-bottom:1px solid var(--border-lt);transition:background var(--t)}
.sftp-table tbody tr:hover{background:#f8f9fb}
.sftp-table tbody td{padding:9px 14px;font-size:.84rem;color:var(--text)}
.sftp-table tbody td:first-child,.sftp-table tbody td:nth-child(4),.sftp-table tbody td:nth-child(5),.sftp-table tbody td:nth-child(6){font-family:var(--mono);font-size:.8rem}
.sftp-tag{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.72rem;font-weight:600}
.sftp-tag--renewal{background:#dbeafe;color:#1e40af}
.sftp-tag--cross-sell{background:#fce7f3;color:#9d174d}
.sftp-tag--pension{background:#d1fae5;color:#065f46}

.sftp-empty{text-align:center;padding:40px;color:var(--text3);font-size:.88rem}

/* ── Toast ──────────────────────────────────────────────────────────────── */
.toast{position:fixed;bottom:20px;right:20px;background:var(--failed);color:#fff;padding:10px 18px;border-radius:var(--rs);font-size:.84rem;font-weight:500;box-shadow:0 6px 20px rgba(239,68,68,.3);opacity:0;transform:translateY(10px);transition:all 300ms;pointer-events:none;z-index:100}
.toast.visible{opacity:1;transform:translateY(0);pointer-events:auto}

/* ── Responsive ─────────────────────────────────────────────────────────── */
@media(max-width:900px){.progress-cards{grid-template-columns:repeat(2,1fr)}.progress-meta{grid-template-columns:1fr}}
@media(max-width:700px){
  body{flex-direction:column}
  .sidebar{width:100%;min-width:100%;height:auto;position:relative;border-right:none;border-bottom:1px solid var(--border)}
  .org-list{display:flex;overflow-x:auto;padding:8px 12px;gap:6px}
  .org-item{white-space:nowrap;border-left:none;padding:8px 14px;border-radius:var(--rs);font-size:.82rem}
  .org-item.active{border-left:none}
  .main{padding:0 14px 36px}
  .sftp-toolbar{flex-direction:column}
}
