:root{--bg: #f7f8fa;--surface: #ffffff;--surface-2: #f9fafb;--surface-3: #f3f4f6;--panel: var(--surface);--border: #b8bfc9;--border-strong: #8b94a3;--text: #111827;--text-muted: #6b7280;--text-subtle: #9ca3af;--muted: var(--text-muted);--accent: #4f46e5;--accent-hover: #4338ca;--accent-active: #3730a3;--accent-soft: #eef2ff;--accent-border: #c7d2fe;--accent-contrast: #ffffff;--primary: var(--accent);--primary-dark: var(--accent-hover);--success: #16a34a;--success-soft: #dcfce7;--success-border: #bbf7d0;--danger: #dc2626;--danger-soft: #fee2e2;--danger-border: #fecaca;--warning: #b45309;--warning-soft: #fffbeb;--warning-border: #fde68a;--green: var(--success);--red: var(--danger);--sidebar-bg: #0f172a;--sidebar-fg: #cbd5e1;--sidebar-fg-dim: #94a3b8;--sidebar-active: rgba(79, 70, 229, .16);--sidebar-hover: rgba(255, 255, 255, .06);--sidebar-border: rgba(255, 255, 255, .08);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--radius-sm: 6px;--radius: 8px;--radius-md: 10px;--radius-lg: 12px;--radius-full: 999px;--shadow-subtle: 0 1px 2px rgba(0, 0, 0, .05);--shadow-card: 0 1px 3px rgba(0, 0, 0, .08);--shadow-pop: 0 10px 25px -5px rgba(0, 0, 0, .18), 0 8px 10px -6px rgba(0, 0, 0, .12);--shadow: var(--shadow-card);--fs-xs: 12px;--fs-sm: 13px;--fs-base: 14px;--fs-md: 15px;--fs-lg: 18px;--fs-xl: 22px;--fs-2xl: 26px;--ring: 0 0 0 3px rgba(79, 70, 229, .18);--transition: .15s ease;--sidebar-w: 232px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Pretendard,Pretendard Variable,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Apple SD Gothic Neo,Noto Sans KR,Malgun Gothic,sans-serif;background:var(--bg);color:var(--text);font-size:var(--fs-base);line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3{letter-spacing:-.01em}.app-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);color:var(--sidebar-fg);display:flex;flex-direction:column;flex-shrink:0;position:sticky;top:0;height:100vh}.brand{font-size:var(--fs-lg);font-weight:700;color:#fff;padding:var(--space-5) var(--space-5) var(--space-4);cursor:pointer;letter-spacing:-.02em;display:flex;align-items:center;gap:var(--space-2)}.brand span{color:#a5b4fc}.nav{display:flex;flex-direction:column;padding:var(--space-2) var(--space-3);gap:2px;flex:1;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:10px var(--space-3);border-radius:var(--radius);color:var(--sidebar-fg);text-decoration:none;font-weight:500;font-size:var(--fs-base);transition:background var(--transition),color var(--transition);line-height:1.2}.nav-item:hover{background:var(--sidebar-hover);color:#fff;text-decoration:none}.nav-item.active{background:var(--sidebar-active);color:#fff;box-shadow:inset 2px 0 0 var(--accent)}.nav-icon{display:inline-flex;width:18px;height:18px;flex-shrink:0;opacity:.85}.nav-icon svg{width:100%;height:100%}.nav-item.active .nav-icon{opacity:1}.sidebar-foot{border-top:1px solid var(--sidebar-border);padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-3)}.sidebar-user{display:flex;align-items:center;gap:var(--space-3);padding:2px var(--space-1);min-width:0}.sidebar-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--accent);color:#fff;font-weight:700;font-size:var(--fs-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;text-transform:uppercase}.sidebar-user-meta{display:flex;flex-direction:column;gap:3px;min-width:0}.user-box{display:flex;align-items:center;gap:var(--space-3)}.user-name{font-weight:600;color:#fff;font-size:var(--fs-base);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:var(--fs-xs);background:#a5b4fc29;color:#c7d2fe;padding:2px 8px;border-radius:var(--radius-full);width:fit-content;font-weight:600}.main{flex:1;display:flex;flex-direction:column;min-width:0}.content{padding:var(--space-6);flex:1;max-width:1320px;width:100%}.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-5);flex-wrap:wrap;gap:var(--space-3)}.page-head h1{font-size:var(--fs-xl);font-weight:700;margin:0;color:var(--text)}.page-loading{padding:56px 24px;text-align:center;color:var(--text-muted);font-size:var(--fs-md)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid transparent;border-radius:var(--radius);padding:9px 16px;font-size:var(--fs-base);font-weight:600;line-height:1.2;cursor:pointer;background:var(--surface-3);color:var(--text);transition:background var(--transition),border-color var(--transition),color var(--transition),box-shadow var(--transition);white-space:nowrap}.btn:hover:not(:disabled){background:var(--border)}.btn:focus-visible{outline:none;box-shadow:var(--ring)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:5px 10px;font-size:var(--fs-xs);margin-right:var(--space-1)}.btn-block{width:100%}.btn-primary{background:var(--accent);color:var(--accent-contrast);box-shadow:var(--shadow-subtle)}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:active:not(:disabled){background:var(--accent-active)}.btn-ghost{background:var(--surface);border-color:var(--border);color:var(--text)}.btn-ghost:hover:not(:disabled){background:var(--surface-3);border-color:var(--border-strong)}.btn-danger{background:var(--danger-soft);color:var(--danger);border-color:var(--danger-border)}.btn-danger:hover:not(:disabled){background:#fecaca}.sidebar-foot .btn-ghost{background:#ffffff0a;border-color:var(--sidebar-border);color:var(--sidebar-fg)}.sidebar-foot .btn-ghost:hover:not(:disabled){background:var(--sidebar-hover);color:#fff;border-color:#ffffff2e}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);margin-bottom:var(--space-5);box-shadow:var(--shadow-card)}.card h2{font-size:var(--fs-md);font-weight:600;margin:0 0 var(--space-4);color:var(--text)}.card-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-5)}.card-foot{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border)}@media (max-width: 900px){.card-row{grid-template-columns:1fr}}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--space-4);margin-bottom:var(--space-5)}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-card);position:relative;overflow:hidden;transition:box-shadow var(--transition),transform var(--transition)}.stat-card:hover{box-shadow:var(--shadow-pop)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--border-strong)}.stat-card.accent-blue:before{background:var(--accent)}.stat-card.accent-green:before{background:var(--success)}.stat-card.accent-gray:before{background:var(--text-subtle)}.stat-value{font-size:var(--fs-2xl);font-weight:700;line-height:1.1;letter-spacing:-.02em;color:var(--text)}.stat-label{color:var(--text-muted);margin-top:var(--space-2);font-size:var(--fs-sm);font-weight:500}.field{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}.field>span{font-weight:600;font-size:var(--fs-sm);color:var(--text)}.field-inline{display:flex;flex-direction:column;gap:5px}.field-inline>span{font-size:var(--fs-xs);color:var(--text-muted);font-weight:600}.field-inline.grow{flex:1;min-width:200px}.field-check{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-4)}.field-check input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}input[type=text],input[type=password],input[type=url],input[type=date],input[type=file],select,textarea{padding:9px 11px;border:1px solid var(--border-strong);border-radius:var(--radius);font-size:var(--fs-base);font-family:inherit;color:var(--text);background:var(--surface);width:100%;transition:border-color var(--transition),box-shadow var(--transition)}input::placeholder,textarea::placeholder{color:var(--text-subtle)}input[type=file]{padding:7px 11px;background:var(--surface-2);cursor:pointer}textarea{resize:vertical;min-height:72px}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:var(--ring)}input:disabled,select:disabled,textarea:disabled{background:var(--surface-3);color:var(--text-muted);cursor:not-allowed}.req{color:var(--danger);font-style:normal;font-weight:700;margin-left:2px}.hint{color:var(--text-muted);font-size:var(--fs-xs);line-height:1.45}.form-card{max-width:680px}.form-actions{display:flex;gap:var(--space-3);margin-top:var(--space-2)}.modal-body .form-actions{padding:0 var(--space-5) var(--space-5);margin-top:0}.link-row{display:flex;gap:var(--space-2);margin-bottom:var(--space-2)}.preview-box{margin-bottom:var(--space-4)}.preview-box img{max-width:280px;max-height:280px;border:1px solid var(--border);border-radius:var(--radius);display:block}.warn-box{background:var(--warning-soft);border:1px solid var(--warning-border);color:var(--warning);padding:var(--space-3) var(--space-4);border-radius:var(--radius);margin-bottom:var(--space-4);font-size:var(--fs-sm);line-height:1.5}.filters-card{padding:var(--space-4) var(--space-5)}.filters-grid{display:flex;flex-wrap:wrap;gap:var(--space-4);align-items:flex-end}.filters-actions{margin-top:var(--space-4);display:flex;gap:var(--space-2)}.filters.inline{display:flex;gap:var(--space-3);align-items:flex-end;flex-wrap:wrap}.card>.data-table,.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{text-align:left;padding:11px var(--space-3);border-bottom:1px solid var(--border-strong);vertical-align:middle}.data-table thead th{font-size:var(--fs-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600;background:var(--surface-2);border-bottom:2px solid var(--border-strong);position:sticky;top:0}.data-table tbody tr{transition:background var(--transition)}.data-table tbody tr:hover{background:var(--surface-2)}.data-table tbody tr:last-child td{border-bottom:none}.data-table tr.row-inactive{opacity:.55}.memo-cell{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-muted)}.empty-cell{text-align:center;color:var(--text-muted);padding:48px 24px;font-size:var(--fs-sm)}.thumb{width:44px;height:44px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border);display:block;background:var(--surface-3)}.badge{display:inline-flex;align-items:center;font-size:var(--fs-xs);padding:3px 9px;border-radius:var(--radius-full);font-weight:600;line-height:1.4}.badge-green{background:var(--success-soft);color:#15803d;border:1px solid var(--success-border)}.badge-gray{background:var(--surface-3);color:var(--text-muted);border:1px solid var(--border)}@media (max-width: 768px){.card{overflow-x:auto}.data-table{min-width:640px}}.pagination{display:flex;align-items:center;gap:var(--space-1);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border);flex-wrap:wrap}.pagination button{border:1px solid var(--border);background:var(--surface);color:var(--text);min-width:34px;padding:6px 11px;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--fs-sm);font-weight:500;transition:background var(--transition),border-color var(--transition)}.pagination button:hover:not(:disabled):not(.active){background:var(--surface-3);border-color:var(--border-strong)}.pagination button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.pagination button:disabled{opacity:.4;cursor:not-allowed}.page-info{margin-left:auto;color:var(--text-muted);font-size:var(--fs-xs)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:flex-start;justify-content:center;padding:64px 20px;z-index:100;overflow-y:auto;animation:overlay-in .15s ease}.modal{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:540px;box-shadow:var(--shadow-pop);border:1px solid var(--border);animation:modal-in .18s ease}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border)}.modal-head h2{margin:0;font-size:var(--fs-lg);font-weight:600}.modal-body{padding:var(--space-5)}.modal-body .field:last-child{margin-bottom:0}.detail-img{max-width:100%;max-height:320px;border-radius:var(--radius);border:1px solid var(--border);margin-bottom:var(--space-4);display:block}.detail-dl{display:grid;grid-template-columns:110px 1fr;gap:var(--space-2) var(--space-3);margin:0}.detail-dl dt{font-weight:600;color:var(--text-muted);font-size:var(--fs-sm)}.detail-dl dd{margin:0;color:var(--text)}.link-list{margin:0;padding-left:var(--space-4)}.link-list li{margin-bottom:var(--space-1);word-break:break-all}.empty-box{background:var(--surface);border:1px dashed var(--border-strong);border-radius:var(--radius-lg);padding:56px 24px;text-align:center;color:var(--text-muted);font-size:var(--fs-md)}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);background-image:radial-gradient(circle at 50% 0%,#eef2ff 0%,var(--bg) 55%);padding:var(--space-5)}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-6);width:100%;max-width:400px;box-shadow:var(--shadow-pop)}.login-brand{font-size:var(--fs-2xl);font-weight:700;letter-spacing:-.02em;color:var(--text)}.login-brand span{color:var(--accent)}.login-sub{color:var(--text-muted);margin:var(--space-1) 0 var(--space-6);font-size:var(--fs-sm)}.login-card .field{margin-bottom:var(--space-4)}.login-card .btn-block{margin-top:var(--space-2)}.toast-wrap{position:fixed;top:20px;right:20px;display:flex;flex-direction:column;gap:var(--space-2);z-index:9999}.toast{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius);color:#fff;box-shadow:var(--shadow-pop);font-weight:500;font-size:var(--fs-sm);max-width:360px;border-left:3px solid rgba(255,255,255,.4);animation:toast-in .2s ease}.toast-error{background:var(--danger)}.toast-success{background:var(--success)}.toast-info{background:#334155}@keyframes toast-in{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}@keyframes modal-in{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 768px){.app-shell{flex-direction:column}.sidebar{width:100%;height:auto;position:relative;flex-direction:row;align-items:center;flex-wrap:wrap;padding-bottom:var(--space-2)}.brand{padding:var(--space-3) var(--space-4)}.nav{flex-direction:row;overflow-x:auto;flex:1 1 100%;order:3;padding:var(--space-2)}.nav-item{white-space:nowrap}.sidebar-foot{border-top:none;border-left:1px solid var(--sidebar-border);margin-left:auto;flex-direction:row;align-items:center;padding:var(--space-2) var(--space-4)}.sidebar-foot .btn-block{width:auto}.content{padding:var(--space-4)}}
