/* ═══════════════════════════════════════════════
   전자결재 플러그인 스타일 v2.0
   ═══════════════════════════════════════════════ */
:root {
  --ea-bg:         #f0f2f5;
  --ea-sidebar-bg: #1a2236;
  --ea-sidebar-w:  240px;
  --ea-accent:     #2563eb;
  --ea-accent-h:   #1d4ed8;
  --ea-danger:     #dc2626;
  --ea-success:    #16a34a;
  --ea-warning:    #d97706;
  --ea-white:      #ffffff;
  --ea-border:     #e2e8f0;
  --ea-text:       #1e293b;
  --ea-muted:      #64748b;
  --ea-radius:     10px;
  --ea-shadow:     0 1px 4px rgba(0,0,0,.08);
  --ea-font:       'Pretendard','Apple SD Gothic Neo','Malgun Gothic',sans-serif;
}
.ea-wrap*,.ea-wrap*::before,.ea-wrap*::after{box-sizing:border-box;margin:0;padding:0;}

/* ── 로그인 ── */
.ea-login-outer{display:flex;align-items:center;justify-content:center;min-height:60vh;background:var(--ea-bg);}
.ea-login-card{background:var(--ea-white);border-radius:16px;box-shadow:0 8px 32px rgba(0,0,0,.12);padding:48px 40px;width:100%;max-width:400px;}
.ea-login-logo{text-align:center;margin-bottom:32px;}
.ea-login-icon{font-size:48px;line-height:1;margin-bottom:12px;}
.ea-login-title{font-size:26px;font-weight:700;color:var(--ea-text);letter-spacing:-.5px;}
.ea-login-sub{font-size:13px;color:var(--ea-muted);margin-top:4px;}

/* ── 레이아웃 ── */
.ea-wrap{display:flex;min-height:80vh;background:var(--ea-bg);font-family:var(--ea-font);color:var(--ea-text);font-size:14px;line-height:1.6;}

/* ── 사이드바 ── */
.ea-sidebar{width:var(--ea-sidebar-w);background:var(--ea-sidebar-bg);display:flex;flex-direction:column;flex-shrink:0;}
.ea-sidebar-logo{display:flex;align-items:center;gap:10px;padding:24px 20px 20px;border-bottom:1px solid rgba(255,255,255,.08);}
.ea-sidebar-icon{font-size:22px;}
.ea-sidebar-title{font-size:17px;font-weight:700;color:#fff;letter-spacing:-.3px;}
.ea-nav{flex:1;padding:16px 0;overflow-y:auto;}
.ea-nav-item{display:flex;align-items:center;gap:10px;padding:11px 20px;color:rgba(255,255,255,.65);text-decoration:none;font-size:14px;border-left:3px solid transparent;transition:all .18s;}
.ea-nav-item:hover{color:#fff;background:rgba(255,255,255,.06);}
.ea-nav-item.active{color:#fff;background:rgba(37,99,235,.25);border-left-color:var(--ea-accent);}
.ea-nav-icon{font-size:16px;width:20px;text-align:center;}
.ea-badge-count{margin-left:auto;background:#ef4444;color:#fff;border-radius:20px;font-size:11px;font-weight:700;padding:1px 7px;}
.ea-sidebar-footer{border-top:1px solid rgba(255,255,255,.08);padding:16px 20px;}
.ea-user-info{display:flex;align-items:center;gap:10px;margin-bottom:12px;}
.ea-user-avatar{width:36px;height:36px;border-radius:50%;background:var(--ea-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0;}
.ea-user-name{font-size:13px;font-weight:600;color:#fff;}
.ea-user-role{font-size:11px;color:rgba(255,255,255,.5);}
.ea-btn-logout{width:100%;padding:8px;border:1px solid rgba(255,255,255,.2);background:transparent;color:rgba(255,255,255,.7);border-radius:6px;cursor:pointer;font-size:13px;transition:all .15s;}
.ea-btn-logout:hover{background:rgba(255,255,255,.1);color:#fff;}

/* ── 메인 ── */
.ea-main{flex:1;display:flex;flex-direction:column;min-width:0;}
.ea-topbar{background:var(--ea-white);border-bottom:1px solid var(--ea-border);padding:16px 28px;position:sticky;top:0;z-index:50;}
.ea-page-title{font-size:18px;font-weight:700;color:var(--ea-text);}
.ea-view{display:none;padding:24px 28px;flex-direction:column;gap:20px;}
.ea-view.active{display:flex;}

/* ── 위젯 ── */
.ea-widgets{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.ea-widget{background:var(--ea-white);border-radius:var(--ea-radius);box-shadow:var(--ea-shadow);padding:20px;display:flex;align-items:center;gap:16px;border-left:4px solid transparent;transition:box-shadow .15s;}
.ea-widget:hover{box-shadow:0 4px 12px rgba(0,0,0,.12);}
.ea-widget-pending{border-left-color:var(--ea-warning);}
.ea-widget-inprogress{border-left-color:var(--ea-accent);}
.ea-widget-done{border-left-color:var(--ea-success);}
.ea-widget-rejected{border-left-color:var(--ea-danger);}
.ea-widget-icon{font-size:28px;line-height:1;}
.ea-widget-label{font-size:12px;color:var(--ea-muted);margin-bottom:4px;}
.ea-widget-count{font-size:28px;font-weight:800;color:var(--ea-text);line-height:1;}

/* ── 카드 ── */
.ea-card{background:var(--ea-white);border-radius:var(--ea-radius);box-shadow:var(--ea-shadow);padding:24px;}
.ea-card-header{font-size:15px;font-weight:700;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--ea-border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;}
.ea-card-actions{display:flex;gap:12px;justify-content:flex-end;}

/* ── 빠른 기안 버튼 ── */
.ea-quick-btns{display:flex;gap:10px;flex-wrap:wrap;}
.ea-quick-btn{padding:10px 18px;border:1px solid var(--ea-border);border-radius:8px;background:var(--ea-white);cursor:pointer;font-size:14px;font-family:var(--ea-font);transition:all .15s;color:var(--ea-text);}
.ea-quick-btn:hover{border-color:var(--ea-accent);color:var(--ea-accent);background:#eff6ff;}

/* ── 양식 카드 선택 ── */
.ea-form-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.ea-form-card{border:2px solid var(--ea-border);border-radius:var(--ea-radius);padding:24px 16px;text-align:center;cursor:pointer;transition:all .18s;}
.ea-form-card:hover,.ea-form-card.selected{border-color:var(--ea-accent);background:#eff6ff;}
.ea-form-card-icon{font-size:36px;margin-bottom:10px;}
.ea-form-card-name{font-size:15px;font-weight:700;margin-bottom:4px;}
.ea-form-card-desc{font-size:12px;color:var(--ea-muted);}

/* ── 결재선 ── */
.ea-approver-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px;}
.ea-approver-item{display:flex;align-items:center;gap:10px;background:var(--ea-bg);border-radius:6px;padding:10px 14px;}
.ea-approver-step{font-size:12px;font-weight:700;color:var(--ea-accent);width:48px;}
.ea-approver-name{flex:1;font-size:14px;font-weight:600;}
.ea-approver-remove{cursor:pointer;color:var(--ea-muted);font-size:18px;line-height:1;border:none;background:none;padding:0;}
.ea-approver-remove:hover{color:var(--ea-danger);}
.ea-approver-add{display:flex;gap:10px;align-items:center;}

/* ── 탭 버튼 ── */
.ea-tab-btns{display:flex;gap:4px;}
.ea-tab{padding:5px 12px;border-radius:6px;border:1px solid var(--ea-border);background:transparent;cursor:pointer;font-size:13px;font-family:var(--ea-font);transition:all .15s;}
.ea-tab.active{background:var(--ea-accent);color:#fff;border-color:var(--ea-accent);}

/* ── 폼 ── */
.ea-form-group{margin-bottom:16px;}
.ea-form-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-bottom:16px;}
.ea-label{display:block;font-size:13px;font-weight:600;color:var(--ea-text);margin-bottom:6px;}
.ea-input{width:100%;padding:9px 12px;border:1px solid var(--ea-border);border-radius:6px;font-size:14px;font-family:var(--ea-font);transition:border-color .15s;outline:none;}
.ea-input:focus{border-color:var(--ea-accent);box-shadow:0 0 0 3px rgba(37,99,235,.12);}
textarea.ea-input{resize:vertical;min-height:80px;}
.ea-form-group-check{display:flex;flex-direction:column;justify-content:flex-end;}

/* ── 버튼 ── */
.ea-btn{display:inline-flex;align-items:center;justify-content:center;padding:9px 18px;border-radius:6px;font-size:14px;font-weight:600;font-family:var(--ea-font);cursor:pointer;border:none;transition:all .15s;text-decoration:none;}
.ea-btn-primary{background:var(--ea-accent);color:#fff;}
.ea-btn-primary:hover{background:var(--ea-accent-h);}
.ea-btn-outline{background:transparent;color:var(--ea-accent);border:1px solid var(--ea-accent);}
.ea-btn-outline:hover{background:#eff6ff;}
.ea-btn-block{width:100%;}
.ea-btn-sm{padding:5px 12px;font-size:12px;background:var(--ea-bg);color:var(--ea-text);border:1px solid var(--ea-border);}
.ea-btn-danger{background:var(--ea-danger);color:#fff;}
.ea-btn-success{background:var(--ea-success);color:#fff;}

/* ── 알림 ── */
.ea-alert{padding:10px 14px;border-radius:6px;font-size:13px;margin-bottom:16px;}
.ea-alert-error{background:#fef2f2;color:var(--ea-danger);border:1px solid #fecaca;}
.ea-alert-success{background:#f0fdf4;color:var(--ea-success);border:1px solid #bbf7d0;}
.ea-muted{color:var(--ea-muted);font-size:13px;}
.ea-center{text-align:center;padding:20px 0;}

/* ── 테이블 ── */
.ea-table{width:100%;border-collapse:collapse;font-size:13px;}
.ea-table th{background:var(--ea-bg);padding:10px 14px;text-align:left;font-weight:600;border-bottom:1px solid var(--ea-border);}
.ea-table td{padding:10px 14px;border-bottom:1px solid var(--ea-border);vertical-align:middle;}
.ea-table tr:hover td{background:#f8fafc;}
.ea-table-link{color:var(--ea-accent);cursor:pointer;text-decoration:underline;font-weight:600;}

/* ── 배지 ── */
.ea-badge{display:inline-flex;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;}
.ea-badge-active{background:#dcfce7;color:#16a34a;}
.ea-badge-inactive{background:#fee2e2;color:#dc2626;}
.ea-badge-admin{background:#dbeafe;color:#1d4ed8;}
.ea-status{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;}
.ea-status-draft{background:#f1f5f9;color:#64748b;}
.ea-status-pending{background:#fef3c7;color:#92400e;}
.ea-status-approved{background:#dcfce7;color:#166534;}
.ea-status-rejected{background:#fee2e2;color:#991b1b;}
.ea-status-discarded{background:#f1f5f9;color:#94a3b8;}

/* ── 결재선 표시 ── */
.ea-line-steps{display:flex;gap:6px;align-items:center;flex-wrap:wrap;margin-top:12px;}
.ea-line-step{display:flex;flex-direction:column;align-items:center;gap:4px;}
.ea-line-step-name{font-size:12px;font-weight:600;background:var(--ea-bg);padding:6px 12px;border-radius:6px;border:2px solid var(--ea-border);}
.ea-line-step-name.approved{border-color:var(--ea-success);background:#dcfce7;color:#166534;}
.ea-line-step-name.rejected{border-color:var(--ea-danger);background:#fee2e2;color:#991b1b;}
.ea-line-step-name.current{border-color:var(--ea-accent);background:#eff6ff;color:var(--ea-accent);}
.ea-line-arrow{color:var(--ea-muted);font-size:16px;}
.ea-line-step-label{font-size:10px;color:var(--ea-muted);}

/* ── 모달 ── */
.ea-modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px;}
.ea-modal{background:var(--ea-white);border-radius:16px;width:100%;max-width:680px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.2);}
.ea-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--ea-border);}
.ea-modal-header h3{font-size:17px;font-weight:700;}
.ea-modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--ea-muted);line-height:1;}
.ea-modal-body{flex:1;overflow-y:auto;padding:24px;}
.ea-modal-footer{padding:16px 24px;border-top:1px solid var(--ea-border);display:flex;gap:10px;justify-content:flex-end;}

/* ── 문서 상세 ── */
.ea-doc-meta{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px;}
.ea-doc-meta-item{background:var(--ea-bg);border-radius:6px;padding:10px 14px;}
.ea-doc-meta-label{font-size:11px;color:var(--ea-muted);margin-bottom:2px;}
.ea-doc-meta-value{font-size:14px;font-weight:600;}
.ea-doc-content{background:var(--ea-bg);border-radius:6px;padding:16px;margin-bottom:16px;}
.ea-doc-content-row{display:flex;gap:8px;padding:6px 0;border-bottom:1px solid var(--ea-border);}
.ea-doc-content-row:last-child{border-bottom:none;}
.ea-doc-content-label{font-size:12px;color:var(--ea-muted);min-width:100px;font-weight:600;}
.ea-doc-content-value{font-size:13px;flex:1;}
.ea-reject-area{margin-top:12px;}

/* ── 반응형 ── */
@media(max-width:900px){.ea-widgets{grid-template-columns:repeat(2,1fr);}.ea-form-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:640px){.ea-sidebar{display:none;}.ea-widgets{grid-template-columns:1fr 1fr;}.ea-view{padding:16px;}.ea-form-grid{grid-template-columns:1fr 1fr;}}

/* ══ 3단계: 첨부파일 + NAS 설정 ══════════════════ */
.ea-file-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px;}
.ea-file-item{display:flex;align-items:center;gap:8px;background:var(--ea-bg);border-radius:6px;padding:8px 12px;}
.ea-file-icon{font-size:16px;flex-shrink:0;}
.ea-file-name{flex:1;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ea-file-name a{color:var(--ea-accent);text-decoration:none;}
.ea-file-name a:hover{text-decoration:underline;}
.ea-file-size{font-size:11px;color:var(--ea-muted);flex-shrink:0;}

/* NAS 설정 가이드 */
.ea-nas-guide{display:flex;flex-direction:column;gap:8px;}
.ea-nas-guide-item{font-size:13px;padding:8px 12px;background:var(--ea-bg);border-radius:6px;font-family:monospace;}

/* ══ v5.1 추가 ══ */
.ea-line-step-role { font-size:11px; font-weight:700; color:var(--ea-accent); text-align:center; margin-bottom:4px; }
.ea-edit-row td { background:#f8fafc; }
.ea-line-step-name small { font-size:10px; opacity:.75; display:block; }
.ea-line-step-time { font-size:10px; color:var(--ea-muted); margin-top:3px; text-align:center; }
