@import"https://cdn.jsdelivr.net/gh/orioncactus/pretendard/dist/web/variable/pretendardvariable.css";.login-page{display:grid;grid-template-columns:1fr 1fr;min-height:100vh;background:var(--color-surface)}.login-visual{position:relative;background:linear-gradient(135deg,#13294b,#1a3a5c 45%,#2e6da4);color:#fff;padding:var(--space-12);display:flex;flex-direction:column;justify-content:space-between;overflow:hidden}.login-visual:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 20% 30%,rgba(255,255,255,.15) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(255,255,255,.1) 0%,transparent 50%);pointer-events:none}.login-brand{position:relative;display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-h3);font-weight:700;letter-spacing:-.02em}.brand-mark{width:36px;height:36px;border-radius:var(--radius-md);background:#fff3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:grid;place-items:center;font-size:18px}.login-tagline{position:relative}.login-tagline h1{font-size:40px;font-weight:700;line-height:1.2;color:#fff;letter-spacing:-.02em;margin-bottom:var(--space-4)}.login-tagline p{font-size:var(--text-h3);color:#ffffffd9;font-weight:400;line-height:1.6;max-width:420px}.login-meta{position:relative;font-size:var(--text-sm);color:#ffffffb3}.login-form-panel{display:flex;align-items:center;justify-content:center;padding:var(--space-12)}.login-form-wrap{width:100%;max-width:380px}.login-form-header{margin-bottom:var(--space-8)}.login-form-header h2{font-size:var(--text-h1);font-weight:700;letter-spacing:-.02em;margin-bottom:var(--space-2)}.login-form-header p{color:var(--color-text-muted);font-size:var(--text-body)}.login-tabs{display:flex;gap:var(--space-1);background:var(--color-bg);padding:var(--space-1);border-radius:var(--radius-md);margin-bottom:var(--space-6)}.tab-btn{flex:1;height:36px;padding:0 var(--space-3);border-radius:var(--radius-sm);background:transparent;color:var(--color-text-muted);font-size:var(--text-sm);font-weight:500;transition:all var(--duration-fast) var(--ease)}.tab-btn.active{background:var(--color-surface);color:var(--color-text);box-shadow:var(--shadow-xs)}.tab-btn:not(.active):hover{color:var(--color-text)}.login-form{display:flex;flex-direction:column;gap:var(--space-4)}.error-msg{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-danger);background:var(--color-danger-bg);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md)}.submit-btn{margin-top:var(--space-2);height:44px;font-size:var(--text-body);font-weight:600}.login-foot{margin-top:var(--space-8);padding-top:var(--space-6);border-top:1px solid var(--color-border);font-size:var(--text-sm);color:var(--color-text-muted);text-align:center}@media (max-width: 900px){.login-page{grid-template-columns:1fr}.login-visual{padding:var(--space-8);min-height:280px}.login-tagline h1{font-size:28px}.login-form-panel{padding:var(--space-8)}}.kpi-card-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-5);transition:all var(--duration) var(--ease)}.kpi-card-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.kpi-card-icon{width:44px;height:44px;border-radius:var(--radius-md);display:grid;place-items:center;flex-shrink:0}.kpi-card-icon-info{background:var(--color-info-bg);color:var(--color-info)}.kpi-card-icon-purple{background:var(--color-purple-bg);color:var(--color-purple)}.kpi-card-icon-warning{background:var(--color-warning-bg);color:var(--color-warning)}.kpi-card-icon-success{background:var(--color-success-bg);color:var(--color-success)}.kpi-card-icon-danger{background:var(--color-danger-bg);color:var(--color-danger)}.kpi-card-icon-neutral{background:#f3f4f6;color:#4b5563}.kpi-card-body{display:flex;flex-direction:column;gap:2px;min-width:0}.kpi-card-label{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:500}.kpi-card-value{font-size:24px;font-weight:700;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.dashboard{display:flex;flex-direction:column;gap:var(--space-6)}.page-header h1{font-size:var(--text-h1);font-weight:700;letter-spacing:-.02em;margin-bottom:4px}.kpi-grid{display:grid;gap:var(--space-4)}.kpi-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-5);transition:all var(--duration) var(--ease)}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.kpi-icon{width:44px;height:44px;border-radius:var(--radius-md);display:grid;place-items:center;flex-shrink:0}.kpi-icon-info{background:var(--color-info-bg);color:var(--color-info)}.kpi-icon-purple{background:var(--color-purple-bg);color:var(--color-purple)}.kpi-icon-warning{background:var(--color-warning-bg);color:var(--color-warning)}.kpi-icon-success{background:var(--color-success-bg);color:var(--color-success)}.kpi-body{display:flex;flex-direction:column;gap:2px;min-width:0}.kpi-label{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:500}.kpi-value{font-size:24px;font-weight:700;letter-spacing:-.02em}.empty-state{padding:var(--space-12);display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-3)}.empty-icon{font-size:48px;margin-bottom:var(--space-2)}.empty-state h2{font-size:var(--text-h2);font-weight:600}.empty-state .btn{margin-top:var(--space-4)}.db-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.db-section-title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-h3);font-weight:600}.kpi-grid{grid-template-columns:repeat(5,1fr)}.kpi-grid-4{grid-template-columns:repeat(4,1fr)}.db-crm-note{display:flex;align-items:flex-start;gap:var(--space-4);padding:var(--space-5)}.db-crm-note-icon{font-size:32px;flex-shrink:0}.db-crm-note-title{font-weight:600;margin-bottom:var(--space-1)}.chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.chart-grid-1{grid-template-columns:1fr}.chart-card{padding:var(--space-5)}.chart-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.chart-card-title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-body);font-weight:600;color:var(--color-text)}.chart-skeleton{height:220px;background:linear-gradient(90deg,#f3f4f6 25%,#e9edf2,#f3f4f6 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:var(--radius-md)}.chart-empty{height:220px;display:flex;align-items:center;justify-content:center;color:var(--color-text-subtle);font-size:var(--text-sm)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (max-width: 1300px){.kpi-grid{grid-template-columns:repeat(3,1fr)}.kpi-grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 900px){.kpi-grid,.kpi-grid-4{grid-template-columns:repeat(2,1fr)}.chart-grid{grid-template-columns:1fr}}@media (max-width: 600px){.kpi-grid,.kpi-grid-4{grid-template-columns:1fr}}.pagination{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding-top:var(--space-4)}.pg-info{font-size:var(--text-sm);color:var(--color-text-muted)}.pg-info strong{color:var(--color-text);font-weight:600}.pg-controls{display:flex;gap:2px}.pg-btn{min-width:32px;height:32px;padding:0 var(--space-2);border-radius:var(--radius-sm);background:transparent;color:var(--color-text-muted);font-size:var(--text-sm);font-weight:500;display:inline-flex;align-items:center;justify-content:center;transition:all var(--duration-fast) var(--ease)}.pg-btn:hover:not(:disabled):not(.active){background:var(--color-bg);color:var(--color-text)}.pg-btn:disabled{opacity:.4;cursor:not-allowed}.pg-btn.active{background:var(--color-primary-50);color:var(--color-primary-700);font-weight:600}.pg-size-select{height:32px;padding:0 var(--space-2);border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface);font-size:var(--text-sm);color:var(--color-text)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#11182780;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center;z-index:100;padding:var(--space-6);animation:fadeIn .15s ease-out}.modal-container{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-height:85vh;display:flex;flex-direction:column;animation:slideUp .2s cubic-bezier(.4,0,.2,1)}.modal-sm{max-width:420px}.modal-md{max-width:600px}.modal-lg{max-width:800px}.modal-xl{max-width:1100px}.modal-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;gap:var(--space-4)}.modal-title{font-size:var(--text-h3);font-weight:600;letter-spacing:-.01em;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-close{width:32px;height:32px;border-radius:var(--radius-md);display:grid;place-items:center;color:var(--color-text-muted);transition:all var(--duration-fast) var(--ease);flex-shrink:0}.modal-close:hover{background:var(--color-bg);color:var(--color-text)}.modal-body{padding:var(--space-6);overflow-y:auto;flex:1}.modal-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:var(--space-2);background:var(--color-bg);border-radius:0 0 var(--radius-xl) var(--radius-xl)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.notice-detail{display:flex;flex-direction:column;gap:var(--space-5)}.notice-meta{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-2);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border)}.meta-divider{color:var(--color-text-subtle);margin:0 2px}.notice-content{font-size:var(--text-body);line-height:1.7;color:var(--color-text);white-space:pre-wrap;word-break:break-word;min-height:120px}.notice-form{display:flex;flex-direction:column;gap:var(--space-4)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.notice-textarea{height:auto;min-height:240px;padding:var(--space-3);resize:vertical;font-family:inherit;line-height:1.6}.danger-text{color:var(--color-danger)}.danger-text:hover{background:var(--color-danger-bg)!important;color:var(--color-danger)!important}.adv-search{display:flex;flex-direction:column;gap:var(--space-4)}.date-row{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:var(--space-2)}.date-sep{color:var(--color-text-muted);font-weight:500}.adv-hint{margin-top:var(--space-2)}.notice-page{display:flex;flex-direction:column;gap:var(--space-4)}.page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-2)}.search-card{padding:var(--space-4) var(--space-5)}.search-form{display:grid;grid-template-columns:140px 1fr auto auto;gap:var(--space-2);align-items:center}.search-form .input{width:100%}@media (max-width: 700px){.search-form{grid-template-columns:1fr 1fr}}.tdm{display:flex;flex-direction:column;gap:var(--space-5)}.tdm-title{font-size:var(--text-h2);font-weight:600;letter-spacing:-.01em;line-height:1.4;padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border)}.tdm-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4) var(--space-6)}.tdm-field{display:flex;flex-direction:column;gap:4px;min-width:0}.tdm-full{grid-column:1 / -1}.tdm-label{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:500}.tdm-value{font-size:var(--text-body);color:var(--color-text);font-weight:500;word-break:break-word}.tdm-section h4{font-size:var(--text-sm);font-weight:600;margin-bottom:var(--space-2);color:var(--color-text)}.tdm-textbox{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--color-text);white-space:pre-wrap;line-height:1.6;min-height:56px;word-break:break-word}@media (max-width: 800px){.tdm-grid{grid-template-columns:1fr 1fr}}.service-page{display:flex;flex-direction:column;gap:var(--space-4)}.quick-select{width:180px}.search-actions .search-type{width:110px}.search-actions .search-input{width:220px}.font-mono{font-family:Consolas,Monaco,JetBrains Mono,monospace;font-size:var(--text-xs);color:var(--color-text)}.row-p1{background:linear-gradient(to right,var(--color-danger-bg) 0%,transparent 50px)}.row-p1:hover{background:linear-gradient(to right,var(--color-danger-bg) 0%,var(--color-bg) 80px)!important}.pb-wrap{display:flex;align-items:center;gap:var(--space-2);min-width:0}.pb-track{flex:1;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-pill);overflow:hidden;height:8px;min-width:80px}.pb-fill{height:100%;border-radius:var(--radius-pill);transition:width var(--duration) var(--ease)}.pb-fill-success{background:var(--color-success)}.pb-fill-primary{background:var(--color-primary-500)}.pb-fill-warning{background:var(--color-warning)}.pb-fill-neutral{background:var(--color-text-subtle)}.pb-label{font-size:var(--text-xs);color:var(--color-text-muted);font-variant-numeric:tabular-nums;min-width:36px;text-align:right;flex-shrink:0}.pb-lg .pb-track{height:10px}.pb-lg .pb-label{font-size:var(--text-sm)}.pdm{display:flex;flex-direction:column;gap:var(--space-5)}.pdm-title{font-size:var(--text-h2);font-weight:600;letter-spacing:-.01em;line-height:1.4;padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border)}.pdm-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4) var(--space-6)}.pdm-field{display:flex;flex-direction:column;gap:4px;min-width:0}.pdm-full{grid-column:1 / -1}.pdm-label{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:500}.pdm-value{font-size:var(--text-body);color:var(--color-text);font-weight:500;word-break:break-word}.pdm-section h4{font-size:var(--text-sm);font-weight:600;margin-bottom:var(--space-2);color:var(--color-text)}.pdm-textbox{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--color-text);white-space:pre-wrap;line-height:1.6;min-height:56px;word-break:break-word}.pdm-note .pdm-textbox{background:#fffbeb;border-color:#fde68a}@media (max-width: 800px){.pdm-grid{grid-template-columns:1fr 1fr}}.project-page{display:flex;flex-direction:column;gap:var(--space-4)}.kpi-grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-4)}@media (max-width: 1300px){.kpi-grid-5{grid-template-columns:repeat(3,1fr)}}@media (max-width: 700px){.kpi-grid-5{grid-template-columns:1fr 1fr}}.filter-card{padding:var(--space-4) var(--space-5)}.filter-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);flex-wrap:wrap}.quick-filters{display:flex;gap:var(--space-2);flex-wrap:wrap}.quick-select{width:200px}.search-actions{display:flex;gap:var(--space-2);align-items:center;flex-wrap:wrap}.search-actions .search-type{width:140px}.search-actions .search-input{width:200px}@media (max-width: 1100px){.search-actions .search-input{width:160px}}.active-filters{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px dashed var(--color-border)}.active-filters-label{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:500}.filter-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 4px 4px 10px;background:var(--color-primary-50);color:var(--color-primary-700);border-radius:var(--radius-pill);font-size:var(--text-xs);font-weight:500;border:1px solid var(--color-primary-100)}.filter-chip button{width:18px;height:18px;border-radius:var(--radius-pill);display:grid;place-items:center;color:var(--color-primary-700);background:transparent;transition:background var(--duration-fast) var(--ease)}.filter-chip button:hover{background:var(--color-primary-100)}.clear-all-btn{margin-left:auto;font-size:var(--text-xs)}.data-table tbody td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);font-size:var(--text-sm);color:var(--color-text)}.data-table tbody tr.row-clickable{cursor:pointer;transition:background var(--duration-fast) var(--ease)}.data-table tbody tr.row-clickable:hover{background:var(--color-bg)}.row-delayed{background:linear-gradient(to right,var(--color-warning-bg) 0%,transparent 50px)}.row-delayed:hover{background:linear-gradient(to right,var(--color-warning-bg) 0%,var(--color-bg) 80px)!important}.title-cell{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:0}.project-code{font-family:Consolas,Monaco,JetBrains Mono,monospace;font-size:var(--text-xs);color:var(--color-text);white-space:nowrap}.text-danger{color:var(--color-danger)}.row-no{font-variant-numeric:tabular-nums;font-weight:500}.radio-group{display:flex;flex-wrap:wrap;gap:var(--space-2)}.radio-pill{position:relative;display:inline-flex;align-items:center;height:36px;padding:0 var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-pill);background:var(--color-surface);font-size:var(--text-sm);color:var(--color-text);cursor:pointer;transition:all var(--duration-fast) var(--ease);-webkit-user-select:none;user-select:none}.radio-pill input{position:absolute;opacity:0;width:0;height:0}.radio-pill:hover:not(.is-disabled){background:var(--color-bg);border-color:var(--color-border-strong)}.radio-pill.is-selected{background:var(--color-primary-50);color:var(--color-primary-700);border-color:var(--color-primary-200);font-weight:600}.radio-pill.is-disabled{opacity:.5;cursor:not-allowed}.request-page{display:flex;flex-direction:column;gap:var(--space-4)}.request-grid{display:grid;grid-template-columns:1fr 360px;gap:var(--space-4);align-items:flex-start}@media (max-width: 1100px){.request-grid{grid-template-columns:1fr}}.request-form{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-6)}.form-hint{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:4px}@media (max-width: 600px){.form-row-2{grid-template-columns:1fr}}.request-textarea{height:auto;min-height:280px;padding:var(--space-3);resize:vertical;font-family:Pretendard Variable,Pretendard,system-ui,sans-serif;line-height:1.6}.dropzone.is-over{border-color:var(--color-primary-600);background:var(--color-primary-50);color:var(--color-primary-700);transform:scale(1.005)}.sales-page{display:flex;flex-direction:column;gap:var(--space-4)}.success-banner{display:flex;align-items:center;gap:var(--space-2);background:var(--color-success-bg);color:var(--color-success);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;border:1px solid #a7f3d0}.sales-grid{display:grid;grid-template-columns:1fr 360px;gap:var(--space-4);align-items:flex-start}@media (max-width: 1100px){.sales-grid{grid-template-columns:1fr}}.sales-form{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-6)}.form-section{display:flex;flex-direction:column;gap:var(--space-4)}.section-title{font-size:var(--text-h3);font-weight:600;color:var(--color-text);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border)}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--space-4)}@media (max-width: 800px){.form-row-2{grid-template-columns:1fr}.form-row-3{grid-template-columns:1fr 1fr}}@media (max-width: 600px){.form-row-3{grid-template-columns:1fr}}.sales-textarea{height:auto;min-height:160px;padding:var(--space-3);resize:vertical;font-family:inherit;line-height:1.6}.product-grid{display:flex;flex-wrap:wrap;gap:var(--space-2)}.product-chip{position:relative;display:inline-flex;align-items:center;height:36px;padding:0 var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-pill);background:var(--color-surface);font-size:var(--text-sm);color:var(--color-text);cursor:pointer;transition:all var(--duration-fast) var(--ease);-webkit-user-select:none;user-select:none}.product-chip input{position:absolute;opacity:0;width:0;height:0}.product-chip:hover{background:var(--color-bg);border-color:var(--color-border-strong)}.product-chip.is-selected{background:var(--color-primary-50);color:var(--color-primary-700);border-color:var(--color-primary-200);font-weight:600}.dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-8) var(--space-6);border:2px dashed var(--color-border-strong);border-radius:var(--radius-lg);background:var(--color-bg);color:var(--color-text-muted);cursor:pointer;transition:all var(--duration-fast) var(--ease);text-align:center}.dropzone:hover{border-color:var(--color-primary-500);background:var(--color-primary-50);color:var(--color-primary-700)}.dropzone.is-over{border-color:var(--color-primary-600);background:var(--color-primary-50);color:var(--color-primary-700)}.dz-title{font-size:var(--text-sm);font-weight:500;color:inherit}.file-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-2)}.file-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm)}.file-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.file-size{font-size:var(--text-xs);font-variant-numeric:tabular-nums}.file-remove{width:24px;height:24px;border-radius:var(--radius-pill);display:grid;place-items:center;color:var(--color-text-muted);background:transparent;transition:all var(--duration-fast) var(--ease)}.file-remove:hover{background:var(--color-danger-bg);color:var(--color-danger)}.form-actions{display:flex;align-items:center;gap:var(--space-2);padding-top:var(--space-3);border-top:1px solid var(--color-border)}.submit-btn{height:44px;padding:0 var(--space-6);font-size:var(--text-body);font-weight:600}.recent-card{position:sticky;top:calc(60px + var(--space-4));padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-3)}.recent-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.recent-empty{padding:var(--space-4) 0;text-align:center}.recent-list{list-style:none;display:flex;flex-direction:column}.recent-item{padding:var(--space-3) 0;border-bottom:1px solid var(--color-border);display:flex;flex-direction:column;gap:6px}.recent-item:last-child{border-bottom:none}.recent-title{font-size:var(--text-sm);font-weight:500;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.recent-meta{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.recent-file{display:inline-flex;align-items:center;gap:2px;font-size:var(--text-xs);color:var(--color-text-muted)}.recent-foot{display:flex;justify-content:space-between;font-size:var(--text-xs)}.account-page{display:flex;flex-direction:column;gap:var(--space-4)}.page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--space-4)}.page-title-wrap{display:flex;align-items:center;gap:var(--space-3)}.page-icon{width:44px;height:44px;border-radius:var(--radius-md);background:var(--color-primary-50);color:var(--color-primary-700);display:grid;place-items:center;flex-shrink:0}.page-header h1{font-size:var(--text-h1);font-weight:700;letter-spacing:-.02em;margin-bottom:2px}.page-desc{font-size:var(--text-sm)}.tab-bar{display:flex;gap:var(--space-2);border-bottom:1px solid var(--color-border);margin-bottom:-1px}.tab-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:transparent;color:var(--color-text-muted);font-size:var(--text-sm);font-weight:500;border-bottom:2px solid transparent;transition:all var(--duration-fast) var(--ease);margin-bottom:-1px}.tab-btn:hover{color:var(--color-text)}.tab-btn.is-active{color:var(--color-primary-700);border-bottom-color:var(--color-primary-600);font-weight:600}.account-card{padding:var(--space-5)}.tab-toolbar{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-4);flex-wrap:wrap}.toolbar-search{width:280px}.group-desc{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.table-wrap{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.data-table thead th{text-align:left;font-size:var(--text-xs);font-weight:600;color:var(--color-text-muted);letter-spacing:.04em;text-transform:uppercase;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);background:var(--color-bg);white-space:nowrap}.data-table thead th:first-child{border-top-left-radius:var(--radius-md)}.data-table thead th:last-child{border-top-right-radius:var(--radius-md)}.data-table tbody td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);color:var(--color-text)}.data-table tbody tr:last-child td{border-bottom:none}.text-center{text-align:center}.text-right{text-align:right}.font-mono{font-family:Consolas,Monaco,monospace;font-size:var(--text-xs)}.empty-cell{text-align:center!important;padding:var(--space-12)!important;color:var(--color-text-muted)}.row-actions{display:flex;gap:2px;justify-content:flex-end}.danger-btn{color:var(--color-danger)}.danger-btn:hover{background:var(--color-danger-bg)!important;color:var(--color-danger)!important}.active-icon{color:var(--color-success)}.inactive-icon{color:var(--color-text-subtle)}.perm-table tbody td{padding:var(--space-2) var(--space-3);vertical-align:middle}.perm-icon{margin-right:6px}.perm-key{margin-left:var(--space-2);font-family:Consolas,Monaco,monospace}.tristate-cell{display:inline-flex;align-items:center;justify-content:center;width:56px;height:30px;border-radius:var(--radius-md);font-size:var(--text-xs);font-weight:700;border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;transition:all var(--duration-fast) var(--ease);color:var(--color-text-muted)}.tristate-cell:hover{border-color:var(--color-border-strong)}.tristate-on{background:var(--color-success-bg);color:var(--color-success);border-color:#a7f3d0}.tristate-off{background:#f3f4f6;color:#9ca3af;border-color:var(--color-border)}.tristate-inherit{background:transparent;color:var(--color-text-subtle);font-weight:500;border-style:dashed}.perm-help{background:var(--color-info-bg);color:var(--color-info);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);margin-bottom:var(--space-4);border:1px solid #bfdbfe;line-height:1.5}.user-detail{display:flex;flex-direction:column;gap:var(--space-4)}.user-tabs{display:flex;gap:var(--space-1);background:var(--color-bg);padding:var(--space-1);border-radius:var(--radius-md);margin-bottom:var(--space-2)}.user-tab{flex:1;height:36px;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:0 var(--space-3);border-radius:var(--radius-sm);background:transparent;color:var(--color-text-muted);font-size:var(--text-sm);font-weight:500;transition:all var(--duration-fast) var(--ease)}.user-tab.is-active{background:var(--color-surface);color:var(--color-text);box-shadow:var(--shadow-xs);font-weight:600}.user-tab:not(.is-active):hover{color:var(--color-text)}.success-msg{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-success);background:var(--color-success-bg);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md)}.form-vertical{display:flex;flex-direction:column;gap:var(--space-4)}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.req{color:var(--color-danger);margin-left:2px}.cust-mapping{display:flex;flex-direction:column;gap:var(--space-3)}.cm-selected{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3);background:var(--color-bg);border-radius:var(--radius-md);border:1px solid var(--color-border)}.cm-selected-head{display:flex;align-items:center;justify-content:space-between}.cm-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;background:var(--color-primary-600);color:#fff;border-radius:var(--radius-pill);font-size:var(--text-xs);font-weight:600;margin-left:4px}.cm-chips{display:flex;flex-wrap:wrap;gap:var(--space-1);min-height:28px}.cm-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 4px 4px 10px;background:var(--color-primary-50);color:var(--color-primary-700);border-radius:var(--radius-pill);font-size:var(--text-xs);font-weight:500;border:1px solid var(--color-primary-100)}.cm-chip button{width:18px;height:18px;border-radius:var(--radius-pill);display:grid;place-items:center;color:var(--color-primary-700);background:transparent;transition:background var(--duration-fast) var(--ease)}.cm-chip button:hover{background:var(--color-primary-100)}.cm-search-bar{display:flex;gap:var(--space-2);align-items:center}.cm-search-input{flex:1;position:relative}.cm-search-input .input{padding-left:36px;padding-right:36px}.cm-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-text-muted);pointer-events:none}.cm-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:22px;height:22px;border-radius:var(--radius-pill);display:grid;place-items:center;color:var(--color-text-muted);background:transparent;transition:background var(--duration-fast) var(--ease)}.cm-search-clear:hover{background:var(--color-bg);color:var(--color-text)}.cm-list{list-style:none;margin:0;padding:0;max-height:320px;overflow-y:auto;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface)}.cm-row{display:flex;align-items:center;gap:var(--space-3);padding:10px var(--space-4);border-bottom:1px solid var(--color-border);cursor:pointer;transition:background var(--duration-fast) var(--ease);-webkit-user-select:none;user-select:none}.cm-row:last-child{border-bottom:none}.cm-row:hover{background:var(--color-bg)}.cm-row.is-selected{background:var(--color-primary-50)}.cm-row.is-selected:hover{background:var(--color-primary-100)}.cm-check{display:inline-flex;color:var(--color-text-muted);flex-shrink:0}.cm-row.is-selected .cm-check{color:var(--color-primary-600)}.cm-name{flex:1;font-size:var(--text-sm);font-weight:500;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cm-code{font-family:Consolas,Monaco,monospace;font-size:var(--text-xs);color:var(--color-text-muted)}.cm-empty{padding:var(--space-8);text-align:center;color:var(--color-text-muted);font-size:var(--text-sm)}.cm-foot{text-align:right}.all-customers-page{display:flex;flex-direction:column;gap:var(--space-4)}.all-customers-page .page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--space-4)}.all-customers-page .page-title-wrap{display:flex;align-items:center;gap:var(--space-3)}.all-customers-page .page-icon{width:44px;height:44px;border-radius:var(--radius-md);background:var(--color-primary-50);color:var(--color-primary-700);display:grid;place-items:center;flex-shrink:0}.all-customers-page .page-header h1{font-size:var(--text-h1);font-weight:700;letter-spacing:-.02em;margin-bottom:2px}.all-customers-page .page-desc{font-size:var(--text-sm)}.all-customers-page .tab-bar{display:flex;gap:var(--space-2);border-bottom:1px solid var(--color-border);margin-bottom:-1px}.all-customers-page .tab-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:transparent;color:var(--color-text-muted);font-size:var(--text-sm);font-weight:500;border-bottom:2px solid transparent;transition:all var(--duration-fast) var(--ease);margin-bottom:-1px}.all-customers-page .tab-btn:hover{color:var(--color-text)}.all-customers-page .tab-btn.is-active{color:var(--color-primary-700);border-bottom-color:var(--color-primary-600);font-weight:600}.all-dashboard{display:flex;flex-direction:column;gap:var(--space-6)}.ad-section-head{display:flex;align-items:center;justify-content:space-between}.section-title{font-size:var(--text-h2);font-weight:700;color:var(--color-text)}.ad-group{display:flex;flex-direction:column;gap:var(--space-3)}.ad-group-title{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-h3);font-weight:600;color:var(--color-text);padding-bottom:var(--space-2);border-bottom:1px solid var(--color-border)}.kpi-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}@media (max-width: 1100px){.kpi-grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.kpi-grid-4{grid-template-columns:1fr}}.ad-note{padding:var(--space-5);background:var(--color-info-bg);border-color:#bfdbfe}.ad-note p{color:var(--color-info);line-height:1.6}@keyframes spin-rotate{to{transform:rotate(360deg)}}.spin{animation:spin-rotate 1s linear infinite}.sidebar{position:fixed;inset:0 auto 0 0;width:240px;background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;z-index:10}.sidebar-brand{display:flex;align-items:center;gap:var(--space-3);padding:0 var(--space-5);height:60px;font-weight:700;font-size:15px;letter-spacing:-.02em;color:#1a3a5c;border-bottom:1px solid var(--color-border);background:#fff}.sidebar-brand .brand-mark{width:32px;height:32px;border-radius:var(--radius-md);background:linear-gradient(135deg,#1a3a5c,#2e6da4);color:#fff;display:grid;place-items:center;font-size:13px;font-weight:700;letter-spacing:0}.sidebar-nav{flex:1;padding:var(--space-3) var(--space-2);overflow-y:auto;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:10px var(--space-3);border-radius:var(--radius-md);color:var(--color-text-muted);font-size:var(--text-sm);font-weight:500;text-decoration:none;transition:all var(--duration-fast) var(--ease);position:relative}.nav-item:hover{background:var(--color-bg);color:var(--color-text)}.nav-item.active{background:var(--color-primary-50);color:var(--color-primary-700);font-weight:600;position:relative}.nav-item.active:before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:0 3px 3px 0;background:var(--color-primary-600)}.nav-icon{flex-shrink:0;color:currentColor}.nav-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-ext{color:var(--color-text-subtle);flex-shrink:0}.sidebar-foot{padding:var(--space-4) var(--space-5);border-top:1px solid var(--color-border)}.app-header{height:60px;background:linear-gradient(135deg,#1a3a5c,#2e6da4);color:#fff;border-bottom:1px solid rgba(0,0,0,.1);padding:0 var(--space-6);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:5;box-shadow:0 1px 3px #1a3a5c33}.app-header-right{display:flex;align-items:center;gap:var(--space-3)}.app-header .btn-ghost{color:#ffffffd9}.app-header .btn-ghost:hover{background:#ffffff1f;color:#fff}.user-menu{position:relative}.user-trigger{display:flex;align-items:center;gap:var(--space-3);padding:6px 10px 6px 6px;border-radius:var(--radius-md);transition:background var(--duration-fast) var(--ease);color:#fff}.user-trigger:hover{background:#ffffff1f}.avatar{width:32px;height:32px;border-radius:var(--radius-pill);background:#fff;color:#1a3a5c;display:grid;place-items:center;font-size:13px;font-weight:700;box-shadow:0 0 0 2px #ffffff40}.user-info{display:flex;flex-direction:column;align-items:flex-start;line-height:1.2}.user-name{font-size:var(--text-sm);font-weight:600;color:#fff}.user-group{font-size:var(--text-xs);color:#ffffffb3}.chev{color:#ffffffb3;transition:transform var(--duration-fast) var(--ease)}.chev.open{transform:rotate(180deg)}.user-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:220px;padding:var(--space-2);box-shadow:var(--shadow-lg);z-index:20;color:var(--color-text);background:var(--color-surface)}.dropdown-header{padding:var(--space-3);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-2);color:var(--color-text)}.dropdown-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--color-text);text-align:left;transition:background var(--duration-fast) var(--ease)}.dropdown-item:hover{background:var(--color-bg)}.dropdown-item.danger{color:var(--color-danger)}.dropdown-item.danger:hover{background:var(--color-danger-bg)}.app-layout{min-height:100vh;background:var(--color-bg)}.app-main{margin-left:240px;min-height:100vh;display:flex;flex-direction:column}.app-content{flex:1;padding:var(--space-8);max-width:1440px;width:100%}.app-loading{display:grid;place-items:center;min-height:100vh;background:var(--color-bg)}.spinner{width:36px;height:36px;border:3px solid var(--color-border);border-top-color:var(--color-primary-500);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-error{min-height:100vh;display:grid;place-items:center;padding:var(--space-6);background:var(--color-bg)}.app-error-card{max-width:480px;width:100%;padding:var(--space-8);text-align:center}.error-icon-wrap{width:64px;height:64px;border-radius:var(--radius-pill);background:var(--color-danger-bg);color:var(--color-danger);display:grid;place-items:center;margin:0 auto var(--space-4)}.app-error-card h2{font-size:var(--text-h2);font-weight:600;margin-bottom:var(--space-4)}.error-hints{text-align:left;background:var(--color-bg);padding:var(--space-4);border-radius:var(--radius-md);border:1px solid var(--color-border);margin:var(--space-4) 0}.error-hints p{margin-bottom:var(--space-2);font-size:var(--text-sm)}.error-hints ul{list-style:none;font-size:var(--text-sm);color:var(--color-text)}.error-hints li{padding:var(--space-1) 0;padding-left:var(--space-4);position:relative}.error-hints li:before{content:"•";position:absolute;left:var(--space-2);color:var(--color-text-muted)}.error-hints code{font-family:Consolas,Monaco,monospace;background:var(--color-surface);padding:1px 6px;border-radius:var(--radius-sm);border:1px solid var(--color-border);font-size:12px}.error-actions{display:flex;gap:var(--space-2);justify-content:center;margin-top:var(--space-4)}@media (max-width: 900px){.app-main{margin-left:0}.sidebar{transform:translate(-100%);transition:transform .2s}.sidebar.open{transform:translate(0)}}:root{--color-primary-50: #eff6fb;--color-primary-100: #d6e4f0;--color-primary-200: #b3cce0;--color-primary-500: #2e6da4;--color-primary-600: #1f5586;--color-primary-700: #1a3a5c;--color-bg: #f3f5f8;--color-surface: #ffffff;--color-border: #d8dee6;--color-border-strong: #c0c8d3;--color-text: #111827;--color-text-muted: #6b7280;--color-text-subtle: #9ca3af;--color-success: #10b981;--color-success-bg: #d1fae5;--color-warning: #f59e0b;--color-warning-bg: #fef3c7;--color-danger: #ef4444;--color-danger-bg: #fee2e2;--color-info: #3b82f6;--color-info-bg: #dbeafe;--color-purple: #8b5cf6;--color-purple-bg: #ede9fe;--color-orange: #ea580c;--color-orange-bg: #ffedd5;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-pill: 9999px;--shadow-xs: 0 1px 2px 0 rgba(17, 24, 39, .04);--shadow-sm: 0 1px 3px 0 rgba(17, 24, 39, .06), 0 1px 2px 0 rgba(17, 24, 39, .04);--shadow-md: 0 4px 6px -1px rgba(17, 24, 39, .06), 0 2px 4px -1px rgba(17, 24, 39, .04);--shadow-lg: 0 10px 15px -3px rgba(17, 24, 39, .08), 0 4px 6px -2px rgba(17, 24, 39, .04);--shadow-xl: 0 20px 25px -5px rgba(17, 24, 39, .1), 0 10px 10px -5px rgba(17, 24, 39, .04);--text-display: 32px;--text-h1: 24px;--text-h2: 20px;--text-h3: 16px;--text-body: 14px;--text-sm: 13px;--text-xs: 12px;--ease: cubic-bezier(.4, 0, .2, 1);--duration-fast: .1s;--duration: .2s;--duration-slow: .3s}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:Pretendard Variable,Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Roboto,Helvetica Neue,Segoe UI,Apple SD Gothic Neo,sans-serif;font-size:var(--text-body);font-weight:400;color:var(--color-text);background-color:var(--color-bg);line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}h1,h2,h3,h4,h5{line-height:1.3;color:var(--color-text);font-weight:600}h1{font-size:var(--text-h1);font-weight:700}h2{font-size:var(--text-h2)}h3{font-size:var(--text-h3)}a{color:var(--color-primary-600);text-decoration:none;transition:color var(--duration-fast) var(--ease)}a:hover{color:var(--color-primary-700)}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer;background:none;border:none}:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px;border-radius:var(--radius-sm)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-pill);border:2px solid var(--color-bg)}::-webkit-scrollbar-thumb:hover{background:var(--color-border-strong)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);height:40px;padding:0 var(--space-4);border-radius:var(--radius-md);font-size:var(--text-body);font-weight:500;transition:all var(--duration-fast) var(--ease);white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary-600);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-700)}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-bg);border-color:var(--color-border-strong)}.btn-ghost{background:transparent;color:var(--color-text-muted)}.btn-ghost:hover:not(:disabled){background:var(--color-bg);color:var(--color-text)}.btn-sm{height:32px;padding:0 var(--space-3);font-size:var(--text-sm)}.btn-lg{height:48px;padding:0 var(--space-5);font-size:var(--text-h3)}.input{width:100%;height:40px;padding:0 var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-body);color:var(--color-text);transition:all var(--duration-fast) var(--ease);outline:none}.input::placeholder{color:var(--color-text-subtle)}.input:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100)}.input.is-error{border-color:var(--color-danger)}.input.is-error:focus{box-shadow:0 0 0 3px var(--color-danger-bg)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card-padding{padding:var(--space-6)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);height:22px;padding:0 var(--space-3);border-radius:var(--radius-pill);font-size:var(--text-xs);font-weight:500;white-space:nowrap}.badge-info{background:var(--color-info-bg);color:var(--color-info)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning)}.badge-purple{background:var(--color-purple-bg);color:var(--color-purple)}.badge-orange{background:var(--color-orange-bg);color:var(--color-orange)}.badge-success{background:var(--color-success-bg);color:var(--color-success)}.badge-danger{background:var(--color-danger-bg);color:var(--color-danger)}.badge-neutral{background:#f3f4f6;color:#4b5563}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-label{font-size:var(--text-sm);font-weight:500;color:var(--color-text)}.form-error{font-size:var(--text-xs);color:var(--color-danger);margin-top:var(--space-1)}.text-muted{color:var(--color-text-muted)}.text-subtle{color:var(--color-text-subtle)}.text-sm{font-size:var(--text-sm)}.text-xs{font-size:var(--text-xs)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}
