.layout-root{display:flex;min-height:100vh;flex-direction:column;background:#eef3f8}.layout-body{display:flex;min-height:calc(100vh - 54px);overflow:hidden}.layout-main{display:flex;flex-direction:column;flex:1;min-width:0;overflow:auto;background:#f1f5f9}.page-container{display:flex;flex:1;flex-direction:column;min-height:0;width:100%}.topbar{display:flex;align-items:center;justify-content:space-between;height:54px;padding:0 14px 0 16px;background:#fff;border-bottom:1px solid #ccd4df;box-shadow:0 3px 12px #2835450f;position:relative;z-index:20}.topbar.dashboard-mode{background:#fff;border-bottom-color:#ffffff2e;box-shadow:none;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.topbar-brand-block{display:flex;align-items:center;gap:14px;flex:1;min-width:0}.topbar-mobile-toggle,.topbar-mobile-nav{display:none}.topbar-mobile-toggle{width:38px;height:38px;border:1px solid #dbe6f2;border-radius:12px;background:#f7fbff;color:#1f7de0;align-items:center;justify-content:center;cursor:pointer;flex:0 0 auto}.topbar-mobile-toggle.active{background:#eaf3ff;border-color:#b8d4f4}.topbar-mobile-toggle svg{width:18px;height:18px}.topbar-brand{display:flex;align-items:baseline;gap:3px;flex:0 0 auto;padding:0;border:0;background:transparent;font-weight:800;line-height:1;color:#19a0ff;cursor:pointer}.topbar-brand-name{font-size:24px;color:#f5821e}.topbar-brand-accent{font-size:24px;color:#19a0ff}.topbar-history{display:flex;align-items:center;gap:8px;min-width:0}.topbar-search-shell{position:relative;flex:1;min-width:0;max-width:620px}.topbar-search-box{display:flex;align-items:center;gap:10px;height:40px;padding:0 12px;border:1px solid #b8d4f4;border-radius:14px;background:#f7fbff;box-shadow:0 14px 30px #2e529214}.topbar-search-icon{color:#298af3;display:inline-flex}.topbar-search-box input{flex:1;min-width:0;border:0;background:transparent;outline:none;font-size:13px;color:#213040}.topbar-search-box input::-moz-placeholder{color:#7d8ba1}.topbar-search-box input::placeholder{color:#7d8ba1}.topbar-search-clear{width:24px;height:24px;border:0;border-radius:50%;background:#e4eefc;color:#276fdb;cursor:pointer}.topbar-search-results{position:absolute;top:calc(100% + 10px);left:0;right:0;padding:12px;border:1px solid #dbe4f1;border-radius:18px;background:#fffffffa;box-shadow:0 22px 48px #283c5b29}.topbar-search-results-head,.topbar-popover-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.topbar-search-results-head{padding:4px 4px 10px}.topbar-search-results-head strong,.topbar-popover-head strong{display:block;color:#1e2a38;font-size:14px}.topbar-search-results-head span,.topbar-popover-head span{display:block;margin-top:4px;color:#748295;font-size:11px}.topbar-search-result{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border:0;border-radius:14px;background:transparent;text-align:left;cursor:pointer}.topbar-search-result:hover{background:#f4f8fd}.topbar-search-result strong{color:#1f2b38;font-size:13px}.topbar-search-result p{margin:5px 0 0;color:#6f7c8d;font-size:11px}.topbar-search-result span{color:#2489e8;font-size:11px;font-weight:700}.topbar-search-empty{padding:18px 14px;border-radius:14px;background:#f7f9fc;color:#6f7c8d;font-size:12px;text-align:center}.topbar.dashboard-mode .topbar-icon-btn:hover{background:#ffffff1f}.topbar.dashboard-mode .topbar-avatar{box-shadow:0 4px 14px #0000002e}.topbar-tab{display:inline-flex;align-items:center;min-width:0;max-width:200px;height:36px;padding:0 6px 0 10px;border:1px solid #b8d4f4;border-radius:3px;background:#f7fbff;color:#1d86ea}.topbar-tab.active{border-color:#499bee;background:#eef6ff}.topbar-tab-trigger{display:inline-flex;align-items:center;gap:8px;min-width:0;flex:1;height:100%;padding:0;border:0;background:transparent;color:inherit;font-size:13px;font-weight:700;cursor:pointer}.topbar-tab-text{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-tab-icon{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center}.topbar-tab-icon svg,.topbar-icon-btn svg{width:16px;height:16px}.topbar-tab-close{margin-left:2px;border:0;background:transparent;color:#1d86ea;font-size:16px;line-height:1;cursor:pointer}.topbar-right{display:flex;align-items:center;gap:14px;padding-left:16px}.topbar-user{display:flex;align-items:center;gap:8px;padding:6px 8px;border:0;border-radius:14px;background:transparent;cursor:pointer;min-width:0;text-align:left}.topbar-user:hover{background:#f2f6fb}.topbar-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(180deg,#f3d7c6,#fff4ed);color:#3c414c;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px}.topbar-user-copy{display:flex;flex-direction:column;gap:2px;line-height:1.2;min-width:0}.topbar-user-copy strong{font-size:14px;color:#1f2632}.topbar-user-copy span{font-size:11px;color:#444d5d}.topbar-actions{display:flex;align-items:center;gap:2px}.topbar-popover-anchor{position:relative}.topbar-icon-btn{position:relative;width:30px;height:30px;border:0;background:transparent;color:#343c4a;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;cursor:pointer}.topbar-icon-btn:hover{background:#eef4fa}.topbar-icon-btn.active{background:#eaf3ff;color:#1f7de0}.topbar-icon-badge{position:absolute;top:3px;right:1px;min-width:14px;height:14px;padding:0 3px;border-radius:999px;background:#ff5c5c;color:#fff;font-size:9px;line-height:14px;font-weight:700}.topbar-popover{position:absolute;top:calc(100% + 10px);right:0;padding:14px;border:1px solid #dbe4f1;border-radius:20px;background:#fffffffa;box-shadow:0 22px 48px #283c5b29;z-index:30}.notification-popover{width:min(360px,calc(100vw - 24px))}.organization-popover,.topbar-popover.organization-popover{width:min(1280px,calc(100vw - 32px));max-width:1280px;max-height:calc(100vh - 110px);overflow-y:auto;overscroll-behavior:contain}.topbar-text-btn{border:0;background:transparent;color:#2489e8;font-size:12px;font-weight:700;cursor:pointer}.topbar-notification-list{display:grid;gap:8px;margin-top:14px}.topbar-notification-item{width:100%;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px 14px;border:1px solid transparent;border-radius:14px;text-align:left;cursor:pointer}.topbar-notification-item.unread{background:#eef6ff;border-color:#cfe3fb}.topbar-notification-item.read{background:#f6f8fb}.topbar-notification-copy strong{display:block;color:#1f2b38;font-size:13px}.topbar-notification-copy p{margin:6px 0 0;color:#738091;font-size:11px;line-height:1.5}.topbar-notification-item>span{color:#718092;font-size:11px;white-space:nowrap}.topbar-organization-lead{margin-top:14px;padding:16px 18px;border-radius:18px;background:linear-gradient(135deg,#eff6ff,#f9fbff)}.topbar-organization-badge{display:inline-flex;padding:5px 10px;border-radius:999px;background:#d9ebff;color:#226cd1;font-size:11px;font-weight:800}.topbar-organization-lead strong{display:block;margin-top:10px;color:#1f2b38;font-size:18px}.topbar-organization-lead span{display:block;margin-top:6px;color:#718092;font-size:12px}.topbar-organization-tree{margin-top:14px;display:grid;gap:18px}.topbar-organization-executive-zone{display:grid;gap:12px}.topbar-organization-executive-card{padding:16px 18px;border:1px solid #d8e2ef;border-left:5px solid #355f9d;border-radius:18px;background:#f8fbff;box-shadow:0 8px 20px #283c5b14}.topbar-organization-depth-list{display:grid;gap:12px}.topbar-organization-depth-list.top-level{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));align-items:start}.topbar-organization-depth-list.nested{padding-left:16px;border-left:2px solid #dbe6f2}.topbar-organization-depth-list.nested-horizontal{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));align-items:start}.topbar-organization-depth-card{position:relative;min-width:0;padding:16px 18px;border:1px solid #dfe7f2;border-left:4px solid #4d8fe8;border-radius:16px;background:#fbfdff;box-shadow:0 8px 20px #283c5b0f}.topbar-organization-depth-card.secondary{border-left-color:#7aa8f0;background:#f9fbff}.topbar-organization-depth-card.tertiary{border-left-color:#a8bfdc;background:#f7f9fc}.topbar-organization-depth-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.topbar-organization-depth-head strong{display:block;min-width:0;color:#1f2b38;font-size:15px;line-height:1.45;word-break:break-word}.topbar-organization-depth-head span{flex:0 0 auto;padding:4px 8px;border-radius:999px;background:#eef3f8;color:#5f6d80;font-size:11px;font-weight:700;white-space:nowrap}.topbar-organization-depth-card p,.topbar-organization-executive-card p{margin:6px 0 0;color:#718092;font-size:11px;line-height:1.5;word-break:break-word}.topbar-organization-subtree{margin-top:12px;display:grid;gap:10px}.topbar-organization-empty{margin-top:14px;padding:14px 16px;border-radius:16px;background:#f6f8fb;color:#718092;font-size:12px;line-height:1.6}.topbar-organization-error{border:1px solid #ffd4c1;background:#fff4ef;color:#b85a2e}.topbar-organization-note{margin:10px 0 0;color:#718092;font-size:11px;text-align:right}.topbar-modal-backdrop{position:fixed;inset:0;background:#0f17246b;display:flex;align-items:center;justify-content:center;padding:24px;z-index:80}.topbar-modal{width:min(100%,380px);padding:26px 24px 22px;border-radius:24px;background:#fff;box-shadow:0 28px 60px #111e3533;text-align:center}.topbar-modal-badge{width:54px;height:54px;margin:0 auto 16px;border-radius:18px;background:#fff5ea;color:#f5821e;display:flex;align-items:center;justify-content:center}.topbar-modal-badge svg{width:24px;height:24px}.topbar-modal strong{display:block;color:#1f2b38;font-size:20px}.topbar-modal p{margin:10px 0 0;color:#6f7d8f;font-size:13px;line-height:1.6}.topbar-modal-actions{display:flex;gap:10px;margin-top:22px}.topbar-modal-btn{flex:1;height:42px;border:0;border-radius:14px;font-size:13px;font-weight:800;cursor:pointer}.topbar-modal-btn.secondary{background:#eff3f8;color:#47566a}.topbar-modal-btn.primary{background:linear-gradient(135deg,#f5821e,#ff6b57);color:#fff}.notice-popup-backdrop{position:fixed;inset:0;z-index:1200;display:flex;align-items:center;justify-content:center;padding:24px;background:#0f172a6b;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.notice-popup-panel{width:min(640px,100%);border-radius:24px;background:linear-gradient(180deg,#fffdf9,#fff);box-shadow:0 24px 80px #0f172a33;border:1px solid rgba(249,115,22,.14);padding:28px}.notice-popup-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.notice-popup-eyebrow{display:inline-flex;margin-bottom:8px;color:#ea580c;font-size:12px;font-weight:700;letter-spacing:.08em}.notice-popup-head h2{margin:0;color:#0f172a;font-size:24px;line-height:1.35}.notice-popup-seq{display:inline-flex;align-items:center;justify-content:center;min-width:64px;padding:8px 12px;border-radius:999px;background:#fff7ed;color:#c2410c;font-size:13px;font-weight:700}.notice-popup-meta{display:flex;gap:12px;margin-top:14px;color:#64748b;font-size:13px}.notice-popup-content{margin-top:18px;min-height:180px;max-height:48vh;overflow:auto;padding:18px;border-radius:18px;background:#f8fafc;color:#0f172a;font-size:15px;line-height:1.75;white-space:pre-wrap}.notice-popup-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.topbar-mobile-nav{position:absolute;top:calc(100% + 10px);left:12px;right:12px;padding:16px;border:1px solid #dbe4f1;border-radius:22px;background:#fffffffa;box-shadow:0 24px 52px #283c5b29;opacity:0;transform:translateY(-10px);pointer-events:none;transition:opacity .22s ease,transform .22s ease;z-index:35}.topbar-mobile-nav.open{opacity:1;transform:translateY(0);pointer-events:auto}.topbar-mobile-nav-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.topbar-mobile-nav-head strong{display:block;color:#1f2b38;font-size:15px}.topbar-mobile-nav-head span{display:block;margin-top:6px;color:#748295;font-size:12px;line-height:1.5}.topbar-mobile-nav-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:14px}.topbar-mobile-nav-item{display:grid;gap:10px;min-height:114px;padding:16px 14px;border:1px solid #e0e7f1;border-radius:18px;background:#f8fbff;text-align:left;cursor:pointer;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.topbar-mobile-nav-item:hover,.topbar-mobile-nav-item.active{border-color:#99c9ff;background:linear-gradient(135deg,#eff7ff,#f8fbff);box-shadow:0 14px 28px #346eec1f;transform:translateY(-1px)}.topbar-mobile-nav-icon{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,#2489e8,#4968ff);color:#fff;display:inline-flex;align-items:center;justify-content:center}.topbar-mobile-nav-icon svg{width:20px;height:20px}.topbar-mobile-nav-item strong{color:#1f2b38;font-size:14px}.topbar-mobile-nav-item span:last-child{color:#728092;font-size:12px}.app-sidebar{width:248px;min-width:248px;display:flex;flex-direction:column;background:#343d52;color:#fffffff0;transition:width .24s ease,min-width .24s ease}.app-sidebar.collapsed{width:72px;min-width:72px}.app-sidebar-toolbar{height:80px;border-top:1px solid rgba(255,255,255,.12);border-bottom:1px solid rgba(255,255,255,.16)}.app-sidebar-toolbar.expanded{display:grid;grid-template-columns:repeat(4,1fr)}.app-sidebar-toolbar.collapsed{display:flex;align-items:center;justify-content:center}.app-sidebar-tool{position:relative;border:0;background:transparent;color:#ffffff6b;cursor:pointer;width:100%;height:100%}.app-sidebar-toolbar.collapsed .app-sidebar-tool{width:100%;max-width:72px}.app-sidebar-tool.active{color:#fff}.app-sidebar-tool.active:after{content:"";position:absolute;left:14%;right:14%;bottom:0;height:4px;background:#fff}.app-sidebar-tool-icon{width:28px;height:28px}.app-sidebar-modules{flex:1;overflow:auto;padding:10px 0}.app-sidebar-module{width:100%;display:flex;align-items:center;gap:12px;min-height:64px;padding:0 14px;border:0;background:transparent;color:#ffffff73;text-align:left;cursor:pointer}.app-sidebar-module.active{background:#101624;color:#fff}.app-sidebar-module-icon{width:34px;display:inline-flex;justify-content:center;flex:0 0 auto}.app-sidebar-module-svg{width:24px;height:24px}.app-sidebar-module-label{font-size:15px;font-weight:600;letter-spacing:-.02em;white-space:nowrap;overflow:hidden}.app-sidebar-footer{padding:4px 0 8px}.app-sidebar-footer-toggle{width:100%;height:30px;border:0;background:transparent;color:#ffffff26;cursor:pointer}.app-sidebar-footer-toggle svg{width:20px;height:20px}.rotate-180{transform:rotate(180deg)}.app-sidebar-footer-line{width:calc(100% - 40px);height:1px;margin:6px auto 10px;background:#fff3}.app-sidebar-service{width:100%;display:flex;align-items:center;gap:12px;min-height:56px;padding:0 14px;border:0;background:transparent;color:#ffffff73;cursor:pointer}.app-sidebar-service-icon{width:34px;display:inline-flex;justify-content:center}.app-sidebar-service-label{font-size:15px;font-weight:600;white-space:nowrap;overflow:hidden}.app-sidebar-service-arrow{width:16px;height:16px;margin-left:auto}@media(max-width:1480px){.app-sidebar{width:220px;min-width:220px}.app-sidebar-module-label,.app-sidebar-service-label{font-size:14px}}@media(max-width:1180px){.layout-body{min-height:auto}.app-sidebar.expanded{width:220px;min-width:220px}.app-sidebar.collapsed{width:72px;min-width:72px}}@media(max-width:1100px){.topbar-popover.organization-popover,.organization-popover{width:min(1040px,calc(100vw - 24px))}.topbar-organization-depth-list.top-level{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}}@media(max-width:820px){.topbar{height:auto;flex-direction:column;align-items:stretch;gap:10px;padding:12px}.topbar-right{width:100%;justify-content:space-between;padding-left:0;gap:10px}.topbar-mobile-toggle{display:inline-flex}.topbar-mobile-nav{display:block}.topbar-brand-block{gap:10px;align-items:center}.topbar-history{display:none}.topbar-search-shell{width:100%;max-width:none}.topbar-user{min-width:0;flex:1;padding:6px 0}.topbar-user-copy span{display:none}.topbar-actions{gap:6px}.layout-body{display:block;min-height:auto}.app-sidebar{display:none}.layout-main{min-height:calc(100vh - 108px)}.topbar-mobile-nav-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.topbar-popover{position:fixed;top:100px;left:50%;right:auto;transform:translate(-50%);width:min(640px,calc(100vw - 24px));max-height:calc(100vh - 96px);overflow-y:auto;z-index:60}.notification-popover{width:min(360px,calc(100vw - 24px))}.organization-popover,.topbar-popover.organization-popover{width:min(100vw - 16px,100%)}.topbar-organization-depth-list.top-level{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.topbar-organization-depth-list.nested{padding-left:12px}.topbar-organization-depth-list.nested-horizontal{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.topbar-organization-depth-card,.topbar-organization-executive-card{padding:13px 14px}}@media(max-width:560px){.topbar-right{align-items:flex-start}.topbar-user-copy strong{font-size:13px}.topbar-mobile-nav-grid{grid-template-columns:1fr}.topbar-popover{top:100px;width:calc(100vw - 16px);max-height:calc(100vh - 84px);padding:12px;border-radius:16px}.topbar-popover-head{align-items:flex-start}.topbar-notification-item{padding:10px 12px}.topbar-notification-item>span{font-size:10px}.topbar-organization-lead{padding:14px}.topbar-organization-lead strong{font-size:16px}.topbar-organization-depth-list.top-level,.topbar-organization-depth-list.nested-horizontal{grid-template-columns:1fr}.topbar-organization-depth-head{flex-direction:column;align-items:flex-start}.topbar-organization-depth-head span{margin-top:4px}.topbar-organization-depth-list.nested{padding-left:10px}.notice-popup-backdrop{padding:16px}.notice-popup-panel{padding:22px 18px;border-radius:20px}.notice-popup-head{flex-direction:column}.notice-popup-head h2{font-size:20px}.notice-popup-meta{flex-direction:column;gap:4px}.notice-popup-content{min-height:160px;max-height:42vh}.notice-popup-actions{flex-direction:column}}*{box-sizing:border-box}:root{--app-page-padding: clamp(16px, 1.3vw, 20px);--app-page-padding-mobile: 12px;--app-section-gap: 16px;--app-section-gap-tight: 12px;--app-card-radius: 18px;--app-card-radius-sm: 14px;--app-card-border: rgba(216, 226, 237, .95);--app-card-shadow: 0 10px 24px rgba(31, 41, 55, .08);--app-card-shadow-strong: 0 16px 30px rgba(31, 41, 55, .1);--app-title-xl: clamp(22px, 1.8vw, 26px);--app-title-lg: 18px;--app-title-md: 16px;--app-text-lg: 14px;--app-text-md: 13px;--app-text-sm: 12px;--app-control-height: 38px;--app-control-radius: 10px}html,body,#root{min-height:100%}html,body{overflow-x:hidden}body{margin:0;font-family:Segoe UI,Apple SD Gothic Neo,Noto Sans KR,sans-serif;font-size:var(--app-text-md);line-height:1.45;background:#edf2f7;color:#1f2937}button,input,textarea,select{font:inherit}button{font-family:inherit}a{color:inherit}.section-title{margin:0;font-size:var(--app-title-xl);font-weight:800;line-height:1.2;letter-spacing:-.02em;color:#111827}.section-desc{margin:8px 0 0;color:#6b7280;font-size:var(--app-text-lg);line-height:1.55}.page-header{display:flex;align-items:center;justify-content:space-between;gap:var(--app-section-gap);flex-wrap:wrap;margin-bottom:var(--app-section-gap)}.card{background:#fff;border:1px solid var(--app-card-border);border-radius:var(--app-card-radius);box-shadow:var(--app-card-shadow);overflow:hidden}.btn-primary{display:inline-flex;align-items:center;justify-content:center;min-height:var(--app-control-height);padding:0 16px;font-size:var(--app-text-md);font-weight:700;border-radius:var(--app-control-radius);background:linear-gradient(135deg,#2489e8,#4968ff);color:#fff;border:none;cursor:pointer;box-shadow:0 10px 20px #346eec38;transition:transform .18s ease,box-shadow .18s ease,opacity .18s ease}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 14px 24px #346eec42}.btn-primary:disabled{opacity:.7;cursor:not-allowed;box-shadow:none}.user-name{font-weight:500;color:#111827}.user-email{color:#6b7280}.role-badge{padding:2px 8px;border-radius:999px;font-size:12px;font-weight:600}.role-admin{background:#f3e8ff;color:#7e22ce}.role-editor{background:#dbeafe;color:#1d4ed8}.role-viewer{background:#f3f4f6;color:#4b5563}.status{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500}.status-dot{width:6px;height:6px;border-radius:100%}.status.active{color:#22c55e}.status.active .status-dot{background:#22c55e}.status.inactive{color:#9ca3af}.status.inactive .status-dot{background:#9ca3af}.table-action{text-align:right}.detail-link{font-size:12px;font-weight:500;color:#2563eb;text-decoration:none}.detail-link:hover{border-bottom:2px solid #1d4ed8;color:#1d4ed8}.breadcrumb{display:flex;align-items:center;gap:6px;margin-bottom:var(--app-section-gap);font-size:var(--app-text-lg);color:#6b7280}.breadcrumb-link{text-decoration:none;color:#6b7280}@media(max-width:720px){.page-header{align-items:stretch;margin-bottom:14px}.breadcrumb{flex-wrap:wrap;margin-bottom:14px}.section-title{font-size:22px}.section-desc{font-size:13px}}
