:root{--blue-50:#eef4ff;--blue-100:#d9e6ff;--blue-200:#bcd4ff;--blue-300:#8ebaff;--blue-400:#5896ff;--blue-500:#3170f0;--blue-600:#1a52d6;--blue-700:#1540ae;--blue-800:#17368e;--blue-900:#193174;--blue-950:#111f47;--gray-50:#f8f9fb;--gray-100:#f1f3f6;--gray-200:#e5e8ee;--gray-300:#d1d6e0;--gray-400:#a0a8b8;--gray-500:#6b7588;--gray-600:#4e5668;--gray-700:#3d4455;--gray-800:#2d3342;--gray-900:#1e2230;--green-500:#22c55e;--green-100:#dcfce7;--yellow-500:#eab308;--yellow-100:#fef9c3;--red-500:#ef4444;--red-100:#fee2e2;--orange-500:#f97316;--orange-100:#fff7ed;--sidebar-w:260px;--header-h:64px;color:var(--gray-900);background:var(--gray-100);font-family:Pretendard Variable,Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{min-height:100vh}#root{min-height:100vh;display:flex}a{color:var(--blue-600);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit;font-size:.875rem}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}.app-layout{width:100%;min-height:100vh;display:flex}.clean-login-shell{background:linear-gradient(#f7f9fc 0%,#eef3f8 100%);width:100%;min-height:100vh}.clean-login-header{align-items:center;padding:28px 40px 0;display:flex}.clean-login-logo{object-fit:contain;width:auto;height:34px}.clean-login-panel{justify-content:center;align-items:center;min-height:calc(100vh - 80px);padding:32px 20px 56px;display:flex}.clean-login-card{background:#fff;border:1px solid #dfe7f1;border-radius:20px;width:100%;max-width:420px;padding:32px 28px 28px;box-shadow:0 18px 60px #0f172f14}.clean-login-title-row{margin-bottom:24px}.clean-login-title-row h1{color:#0f172f;letter-spacing:-.03em;font-size:1.9rem;line-height:1.2}.clean-login-title-row p{color:#6b7588;margin-top:8px;font-size:.92rem}.login-form{flex-direction:column;gap:16px;display:flex}.login-error{background:var(--red-100);color:#b42318;border-radius:12px;padding:12px 14px;font-size:.84rem;font-weight:600}.login-submit{justify-content:center;width:100%;min-height:46px;margin-top:4px}.auth-loading-screen{background:linear-gradient(#f7f9fc 0%,#eef3f8 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.auth-loading-card{color:var(--gray-700);background:#fff;border:1px solid #dfe7f1;border-radius:18px;flex-direction:column;align-items:center;gap:8px;padding:24px 28px;display:flex;box-shadow:0 18px 60px #0f172f14}.spin{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sidebar{width:var(--sidebar-w);background:var(--blue-950);color:#fff;z-index:100;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow-y:auto}.sidebar-logo-wrap{border-bottom:1px solid #ffffff14}.sidebar-user-card{background:#ffffff14;border:1px solid #ffffff14;border-radius:14px;justify-content:space-between;align-items:center;gap:12px;margin:0 20px 18px;padding:14px;display:flex}.sidebar-user-meta{flex-direction:column;gap:4px;min-width:0;display:flex}.sidebar-user-label{color:#ffffff8c;font-size:.72rem}.sidebar-user-meta strong{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;overflow:hidden}.sidebar-role-badge{color:#9fc1ff;background:#5896ff2e;border-radius:999px;flex-shrink:0;align-items:center;padding:5px 9px;font-size:.72rem;font-weight:700;display:inline-flex}.sidebar-nav{flex:1;padding:12px 0}.sidebar-nav a{color:#ffffffa6;border-left:3px solid #0000;align-items:center;gap:12px;padding:10px 20px;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.sidebar-nav a:hover{color:#fff;background:#ffffff0f;text-decoration:none}.sidebar-nav a.active{color:#fff;border-left-color:var(--blue-400);background:#ffffff1a}.sidebar-nav a svg{flex-shrink:0}.sidebar-footer{color:#ffffff59;border-top:1px solid #ffffff14;flex-direction:column;gap:12px;padding:16px 20px;font-size:.75rem;display:flex}.sidebar-logout{color:#ffffffe0;background:#ffffff0a;border:1px solid #ffffff24;border-radius:10px;justify-content:center;align-items:center;gap:8px;width:100%;padding:10px 12px;display:inline-flex}.sidebar-logout:hover{background:#ffffff14}.main-content{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-height:100vh;display:flex}.page-header{border-bottom:1px solid var(--gray-200);background:#fff;justify-content:space-between;align-items:center;gap:16px;padding:20px 32px;display:flex}.page-header h1{color:var(--gray-900);font-size:1.35rem;font-weight:700}.page-header .subtitle{color:var(--gray-500);margin-top:2px;font-size:.85rem}.page-body{flex:1;padding:24px 32px}.card{border:1px solid var(--gray-200);background:#fff;border-radius:12px;overflow:hidden}.card-header{border-bottom:1px solid var(--gray-200);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.card-header h2{color:var(--gray-800);font-size:.95rem;font-weight:600}.card-body{padding:20px}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{border:1px solid var(--gray-200);background:#fff;border-radius:12px;flex-direction:column;gap:8px;padding:20px;display:flex}.stat-card .stat-label{color:var(--gray-500);font-size:.8rem;font-weight:500}.stat-card .stat-value{color:var(--gray-900);font-size:1.6rem;font-weight:700}.stat-card .stat-sub{color:var(--gray-500);font-size:.8rem}.stat-card.blue{border-left:4px solid var(--blue-500)}.stat-card.green{border-left:4px solid var(--green-500)}.stat-card.yellow{border-left:4px solid var(--yellow-500)}.stat-card.red{border-left:4px solid var(--red-500)}.stat-card.orange{border-left:4px solid var(--orange-500)}.table-wrapper{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.85rem}thead th{text-align:left;color:var(--gray-600);background:var(--gray-50);border-bottom:2px solid var(--gray-200);white-space:nowrap;padding:10px 14px;font-weight:600}tbody td{border-bottom:1px solid var(--gray-100);color:var(--gray-700);padding:10px 14px}tbody tr:hover{background:var(--blue-50)}tbody tr{cursor:pointer;transition:background .1s}.badge{border-radius:9999px;align-items:center;padding:2px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-blue{background:var(--blue-100);color:var(--blue-700)}.badge-green{background:var(--green-100);color:#166534}.badge-yellow{background:var(--yellow-100);color:#854d0e}.badge-red{background:var(--red-100);color:#991b1b}.badge-orange{background:var(--orange-100);color:#9a3412}.badge-gray{background:var(--gray-200);color:var(--gray-600)}.progress-bar{background:var(--gray-200);vertical-align:middle;border-radius:3px;width:80px;height:6px;margin-right:6px;display:inline-block;overflow:hidden}.progress-bar .fill{border-radius:3px;height:100%;transition:width .3s}.btn{border:1px solid #0000;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:.85rem;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{background:var(--blue-600);color:#fff;border-color:var(--blue-600)}.btn-primary:hover{background:var(--blue-700)}.btn-secondary{color:var(--gray-700);border-color:var(--gray-300);background:#fff}.btn-secondary:hover{background:var(--gray-50)}.btn-sm{padding:5px 10px;font-size:.8rem}.btn-back{color:var(--gray-500);background:0 0;border:none;align-items:center;gap:4px;margin-bottom:12px;padding:4px 0;font-size:.85rem;display:inline-flex}.btn-back:hover{color:var(--blue-600)}.grid-2{grid-template-columns:1fr 1fr;gap:24px;display:grid}.grid-3{grid-template-columns:1fr 1fr 1fr;gap:24px;display:grid}.filters{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.filters input,.filters select{border:1px solid var(--gray-300);color:var(--gray-700);background:#fff;border-radius:8px;padding:7px 12px}.filters input:focus,.filters select:focus{border-color:var(--blue-400);outline:none;box-shadow:0 0 0 3px #3170f01a}.form-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-group{flex-direction:column;gap:4px;display:flex}.form-group label{color:var(--gray-600);font-size:.8rem;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--gray-300);background:#fff;border-radius:8px;padding:8px 12px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--blue-400);outline:none;box-shadow:0 0 0 3px #3170f01a}.form-actions{border-top:1px solid var(--gray-200);justify-content:flex-end;gap:10px;margin-top:20px;padding-top:16px;display:flex}.chart-container{width:100%;height:300px}.krw{font-variant-numeric:tabular-nums}.page-actions{flex-wrap:wrap;gap:8px;display:flex}.btn.danger{color:var(--red-600);border-color:var(--red-200)}.btn.danger:hover{background:var(--red-50)}.detail-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.detail-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.detail-label{color:var(--gray-500);margin-bottom:6px;font-size:.78rem;display:block}.card-form{max-width:1100px}.full-span{grid-column:1/-1}.pipeline-board{grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;display:grid}.pipeline-column{border:1px solid var(--gray-200);background:#fff;border-radius:12px;padding:12px}.pipeline-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.pipeline-list{flex-direction:column;gap:8px;display:flex}.pipeline-card{border:1px solid var(--gray-200);background:var(--gray-50);text-align:left;border-radius:10px;flex-direction:column;gap:4px;width:100%;padding:10px;display:flex}.pipeline-card span,.pipeline-card small{color:var(--gray-600)}.pipeline-empty{color:var(--gray-400);padding:16px 0;font-size:.85rem}.timeline{flex-direction:column;gap:16px;display:flex}.timeline-item{gap:12px;display:flex}.timeline-dot{background:var(--blue-500);border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:7px}.timeline-meta{color:var(--gray-500);align-items:center;gap:8px;margin-bottom:6px;font-size:.78rem;display:flex}.timeline-item p{color:var(--gray-700);margin-top:6px}.inline-feedback{border-radius:12px;padding:12px 14px;font-size:.84rem;font-weight:600}.inline-feedback.error{background:var(--red-100);color:#b42318}.inline-feedback.success{background:var(--green-100);color:#166534}.user-admin-layout{grid-template-columns:minmax(280px,340px) minmax(0,1fr);gap:24px;display:grid}.user-list-body{max-height:560px;padding:0;overflow:auto}.user-list-item{border:none;border-bottom:1px solid var(--gray-100);text-align:left;background:#fff;justify-content:space-between;align-items:center;gap:12px;width:100%;padding:16px 18px;display:flex}.user-list-item:hover,.user-list-item.active{background:var(--blue-50)}.user-list-item strong{color:var(--gray-900);margin-bottom:4px;display:block}.user-list-item span{color:var(--gray-500);font-size:.82rem}.user-detail-body{padding:24px}.form-grid-role{grid-template-columns:220px minmax(0,1fr)}.role-help-box{align-self:end}.role-help-text{border:1px solid var(--gray-200);background:var(--gray-50);min-height:42px;color:var(--gray-600);border-radius:10px;padding:10px 12px;font-size:.84rem;line-height:1.5}.empty-state{text-align:center;color:var(--gray-400);padding:40px 0}@media (width<=1024px){.sidebar{display:none}.main-content{margin-left:0}.page-body{padding:16px}.stat-grid{grid-template-columns:1fr 1fr}.grid-2,.grid-3,.form-grid,.detail-grid,.detail-grid-3,.pipeline-board,.user-admin-layout{grid-template-columns:1fr}}@media (width<=640px){.clean-login-header{padding:20px 20px 0}.clean-login-card{border-radius:16px;padding:24px 18px 20px}.clean-login-title-row h1{font-size:1.6rem}.stat-grid{grid-template-columns:1fr}}
