:root {
  --bg:#f4f7fb;
  --panel:#ffffff;
  --text:#101827;
  --muted:#65748b;
  --line:#dbe5f2;
  --side:#0d1728;
  --side2:#17243a;
  --side-active:#25344d;
  --primary:#4f6df5;
  --primary-dark:#3856db;
  --danger:#ef5350;
  --ok:#e5f8ee;
  --ok-text:#0f7a3b;
  --soft:#edf3fb;
}
*{box-sizing:border-box}
html,body{margin:0;min-height:100%;font-family:Arial,'Apple SD Gothic Neo','Malgun Gothic',sans-serif;color:var(--text);background:var(--bg)}
button,input,textarea,select{font-family:inherit;font-size:14px}
button{border:0;border-radius:10px;background:#eef3fb;color:#172033;font-weight:800;padding:10px 14px;cursor:pointer;transition:.15s}
button:hover{filter:brightness(.98)}
button.primary,.primary{background:var(--primary);color:#fff}
button.primary:hover{background:var(--primary-dark)}
button.danger,.danger{background:var(--danger);color:#fff}
button.full{width:100%;margin-top:14px}
button:disabled,input:disabled,textarea:disabled,select:disabled{opacity:.55;cursor:not-allowed}
.hidden{display:none!important}.muted{color:var(--muted)}.sub{color:var(--muted);margin-top:-4px;margin-bottom:22px;line-height:1.5}.msg{margin-top:12px;color:#df3b3b;font-weight:800}.control,input,textarea,select{border:1px solid #ced8e8;border-radius:10px;background:#fff;padding:11px 12px;outline:none;width:100%}.control:focus,input:focus,textarea:focus,select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(79,109,245,.12)}textarea{resize:vertical;line-height:1.55;font-family:Consolas,'Malgun Gothic',monospace}.app{display:flex;min-height:100vh}.sidebar{width:240px;flex:0 0 240px;background:var(--side);color:#fff;padding:24px 14px;display:flex;flex-direction:column;gap:16px;position:fixed;left:0;top:0;bottom:0;overflow:auto}.brand{font-size:26px;font-weight:900;letter-spacing:-1px;margin:4px 0 8px}.profile{background:#17243a;border-radius:14px;padding:16px}.profile strong{display:block;font-size:17px;margin-bottom:8px}.profile span{display:block;font-size:12px;font-weight:800;margin-bottom:8px;color:#dce8ff}.profile small{display:block;color:#aab8cf;font-size:12px}.nav{display:flex;flex-direction:column;gap:6px}.nav button{width:100%;text-align:left;background:transparent;color:#eef5ff;border-radius:10px;padding:12px 14px}.nav button:hover,.nav button.active{background:var(--side-active);color:#fff}.nav-group{margin-top:12px}.nav-title{font-size:15px;font-weight:900;margin:12px 0 8px;color:#fff}.writer-list{display:flex;flex-direction:column;gap:4px}.writer-list button{font-weight:800;padding:9px 14px}.writer-list button.active{background:var(--side-active)}.logout{margin-top:auto;background:#fff;color:#172033;text-align:center}.main{margin-left:240px;width:calc(100% - 240px);padding:42px 56px}.page h2{font-size:30px;margin:0 0 12px;letter-spacing:-1px}.cards{display:grid;grid-template-columns:repeat(4,minmax(180px,1fr));gap:16px;margin:22px 0}.card,.panel{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:0 1px 3px rgba(10,20,40,.03)}.card b{display:block;font-size:28px;margin-bottom:12px}.card span{color:var(--muted)}.panel{margin:16px 0}.panel.soft{background:#f8fbff}.grid2{display:grid;grid-template-columns:320px 1fr;gap:18px;align-items:start}.toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:16px}.toolbar input,.toolbar select{width:auto}.row{display:grid;grid-template-columns:110px 1fr;gap:10px;align-items:center;margin:12px 0}.row label{font-weight:900}.list{display:flex;flex-direction:column;gap:8px}.list-item{background:#fff;border:1px solid var(--line);border-radius:12px;padding:13px 14px;cursor:pointer}.list-item:hover{border-color:var(--primary);box-shadow:0 2px 8px rgba(79,109,245,.08)}.list-item strong{display:block;font-size:16px;margin-bottom:5px}.list-item small{display:block;color:var(--muted);font-size:13px}.badge{display:inline-flex;align-items:center;gap:4px;border-radius:999px;background:#eef3fb;color:#2b3952;font-size:12px;font-weight:900;padding:6px 10px}.badge.ok{background:var(--ok);color:var(--ok-text)}.badge.wait{background:#fff3d8;color:#805b00}.approval-mini{display:flex;gap:10px;align-items:center;justify-content:space-between;background:#f8fbff;border:1px solid var(--line);border-radius:12px;padding:12px;margin-bottom:12px}.approval-table small{display:block;margin-top:4px;color:var(--muted)}.prebox{white-space:pre-wrap;background:#0f172a;color:#e7edf9;border-radius:12px;padding:14px;min-height:140px;overflow:auto}.prebox.light{background:#fff;color:#172033;border:1px solid var(--line)}.review-box{white-space:pre-wrap;background:#f8fbff;border:1px dashed var(--line);border-radius:12px;padding:14px;margin-top:12px;min-height:64px}.table{width:100%;border-collapse:collapse}.table th,.table td{border-bottom:1px solid var(--line);padding:11px;text-align:left;vertical-align:top}.table th{background:#f8fbff;font-size:13px}.table input,.table select,.table textarea{min-width:120px}.category-table textarea{min-height:70px}.toast{position:fixed;right:24px;bottom:24px;background:#172033;color:#fff;border-radius:12px;padding:13px 16px;font-weight:800;box-shadow:0 12px 30px rgba(0,0,0,.18);z-index:9999}.login-wrap{max-width:420px;margin:110px auto;padding:0 18px}.login-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px;box-shadow:0 10px 30px rgba(20,30,50,.08)}.login-card h1{font-size:34px;margin:0 0 8px}.login-card p{color:var(--muted);margin:0 0 24px}.login-card label{display:block;font-weight:900;margin:14px 0 8px}.week-manage-note{font-size:12px;color:var(--muted);margin:8px 0 0}.split-toolbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.split-toolbar select{max-width:220px}.save-state{font-size:12px;color:var(--muted);font-weight:800}.loading-inline{opacity:.75}
@media(max-width:1100px){.cards{grid-template-columns:repeat(2,1fr)}.grid2{grid-template-columns:1fr}.main{padding:28px}}
@media(max-width:760px){.sidebar{position:static;width:100%;height:auto}.app{display:block}.main{margin-left:0;width:100%;padding:20px}.cards{grid-template-columns:1fr}.row{grid-template-columns:1fr}.toolbar input,.toolbar select{width:100%;max-width:none!important}}

/* 팀원 보고서 주차별 카테고리 관리 */
.team-week-layout{display:grid;grid-template-columns:minmax(520px,1fr) minmax(420px,.78fr);gap:18px;align-items:start}.team-week-left,.team-week-right{margin-top:0}.week-group-box{margin:12px 0}.week-group-head{justify-content:space-between;margin-bottom:10px}.mini-toolbar{margin-bottom:0}.mini-toolbar button{padding:8px 10px;font-size:12px}.category-board{display:flex;flex-direction:column;gap:12px}.category-board-head{display:flex;align-items:center;justify-content:space-between;background:#f8fbff;border:1px solid var(--line);border-radius:12px;padding:12px 14px}.category-box{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden}.category-box-title{display:flex;align-items:center;justify-content:space-between;background:#f8fbff;border-bottom:1px solid var(--line);padding:12px 14px}.category-item-list{display:flex;flex-direction:column;gap:10px;padding:12px}.category-item{border:1px solid var(--line);border-radius:12px;background:#fff;padding:12px}.category-item-meta{font-size:12px;color:var(--muted);font-weight:800;margin-bottom:8px}.category-item-content{min-height:64px;font-size:13px;background:#fbfdff}.category-item-actions{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;margin-top:8px}.empty-category{margin:0;padding:8px 2px}.loading-inline{padding:10px 2px}
@media(max-width:1300px){.team-week-layout{grid-template-columns:1fr}.team-week-right{order:-1}}
@media(max-width:760px){.category-item-actions{grid-template-columns:1fr}.week-group-head{align-items:flex-start}}

/* 통합보고서 구글시트형 항목 편집 */
.integrated-sheet-panel{margin-top:14px}.sheet-wrap{overflow:auto;max-height:640px;border:1px solid var(--line);border-radius:12px;background:#fff}.sheet-table{min-width:1080px}.sheet-table th{position:sticky;top:0;z-index:1}.sheet-table td{vertical-align:middle}.sheet-table .sheet-content{min-height:70px;line-height:1.5;font-family:Consolas,'Malgun Gothic',monospace}.sheet-table .sheet-order{min-width:60px;text-align:center}.sheet-table .sheet-category{min-width:170px}.sheet-table td strong{display:block;margin-bottom:4px}.sheet-table td small{display:block;color:var(--muted);font-size:12px}.sheet-table tr.is-excluded{opacity:.45;background:#f3f5f8}.sheet-edited-badge{font-size:12px;font-weight:800;color:#3856db;margin-top:5px}.sheet-table button{margin:2px 0;width:100%;padding:8px 9px;font-size:12px}.sheet-table input[type="checkbox"]{width:20px;height:20px;accent-color:var(--primary)}

/* Preview edit for individual weekly report */
.preview-edit-panel .mini-toolbar { gap: 8px; }
.preview-editor {
  width: 100%;
  min-height: 360px;
  line-height: 1.65;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  white-space: pre;
  resize: vertical;
}

/* 상무님 메일 주차별 좌/우 관리 */
.final-mail-layout{display:grid;grid-template-columns:340px minmax(0,1fr);gap:18px;align-items:start}.mail-week-panel{position:sticky;top:24px;max-height:calc(100vh - 90px);overflow:auto}.mail-week-head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;margin-bottom:12px}.mail-week-head h3{margin:0 0 4px}.mail-week-list{display:flex;flex-direction:column;gap:10px}.mail-week-card{width:100%;text-align:left;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px;color:var(--text);box-shadow:none}.mail-week-card:hover{border-color:var(--primary);box-shadow:0 2px 10px rgba(79,109,245,.08)}.mail-week-card.active{background:#eef4ff;border-color:var(--primary);box-shadow:0 0 0 3px rgba(79,109,245,.12)}.mail-week-card strong{display:block;font-size:16px;margin-bottom:6px}.mail-week-card span{display:block;color:var(--muted);font-weight:700;margin-bottom:6px}.mail-week-card small{display:block;color:#26344d;line-height:1.35;max-height:38px;overflow:hidden}.mail-week-card em{display:block;margin-top:8px;color:var(--muted);font-size:12px;font-style:normal}.mail-week-badges{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}.mail-editor-panel{min-width:0}.final-mail-body{min-height:690px;line-height:1.65;font-family:Consolas,'Malgun Gothic',monospace;white-space:pre}.small-notice{font-size:13px;margin-bottom:12px}.mail-body-row{align-items:start}@media(max-width:1200px){.final-mail-layout{grid-template-columns:1fr}.mail-week-panel{position:static;max-height:none}.final-mail-body{min-height:520px}}


/* AX 아이디어 */
.ax-cards{margin-bottom:18px}.ax-layout{display:grid;grid-template-columns:330px minmax(0,1fr);gap:18px;align-items:start}.ax-left{position:sticky;top:24px;max-height:calc(100vh - 80px);overflow:auto}.between{justify-content:space-between}.ax-category-list{display:flex;flex-direction:column;gap:10px;margin-top:12px}.ax-cat{width:100%;text-align:left;background:#eef4fb;border:1px solid #dbe5f2;border-radius:14px;padding:14px;color:#101827;box-shadow:none}.ax-cat:hover{border-color:var(--primary)}.ax-cat.active{background:#25344d;color:#fff;border-color:#25344d}.ax-cat strong{display:block;font-size:16px;margin-bottom:5px}.ax-cat small{display:block;color:inherit;opacity:.78;line-height:1.35}.ax-cat em{display:inline-block;margin-top:8px;font-style:normal;font-size:12px;font-weight:800;background:rgba(255,255,255,.3);border-radius:999px;padding:4px 8px}.ax-right{min-width:0}.ax-form{background:#f8fbff;border:1px solid var(--line);border-radius:14px;padding:16px;margin:14px 0 18px}.grid3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.ax-idea-content{min-height:130px}.ax-idea-list{display:flex;flex-direction:column;gap:12px}.ax-idea-card{border:1px solid var(--line);border-radius:14px;background:#fff;padding:16px}.ax-idea-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.ax-idea-head strong{font-size:17px}.ax-idea-head small{display:block;color:var(--muted);margin-top:5px}.ax-idea-card p{line-height:1.55;margin:12px 0;color:#1d2a3d}.ax-badges{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.danger-light{color:#d43c38;background:#fff2f2}.empty{padding:24px;text-align:center;color:var(--muted);border:1px dashed var(--line);border-radius:14px;background:#fbfdff}@media(max-width:1200px){.ax-layout{grid-template-columns:1fr}.ax-left{position:static;max-height:none}.grid3{grid-template-columns:1fr}}

/* AX HTML 산출물 업로드 */
.ax-html-panel{margin:18px 0}.ax-html-form{background:#f8fbff;border:1px solid var(--line);border-radius:14px;padding:16px;margin:14px 0}.grid4{display:grid;grid-template-columns:1fr 1fr 1fr 1.2fr;gap:12px}.grid4 label{display:block;font-weight:900;margin-bottom:6px}.ax-html-list{display:flex;flex-direction:column;gap:10px}.ax-html-card{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px}.ax-html-card strong{display:block;font-size:16px;margin-bottom:5px}.ax-html-card small{display:block;color:var(--muted);margin-bottom:7px}.ax-html-card code{display:block;background:#f3f6fb;border:1px solid var(--line);border-radius:8px;padding:7px 9px;color:#24324a;word-break:break-all}.button-like{display:inline-flex;align-items:center;justify-content:center;border-radius:10px;border:0;background:#eef3fb;color:#172033;text-decoration:none;padding:8px 10px;font-weight:900;font-size:12px}.button-like:hover{background:#dfe7f4}@media(max-width:1200px){.grid4{grid-template-columns:1fr 1fr}.ax-html-card{flex-direction:column}.ax-html-card .toolbar{width:100%}}@media(max-width:760px){.grid4{grid-template-columns:1fr}}

/* AX HTML 소스 붙여넣기 */
.ax-source-row{margin-top:12px}.ax-html-source{min-height:220px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px;line-height:1.5;white-space:pre;resize:vertical}.ax-source-row label{display:block;font-weight:900;margin-bottom:6px}

/* AX workflow / review management */
.ax-process-panel{margin:18px 0}.ax-process-steps{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.ax-step{border:1px solid var(--line);background:#fff;border-radius:14px;padding:13px;display:flex;flex-direction:column;gap:6px;min-height:110px}.ax-step b{width:28px;height:28px;border-radius:999px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center}.ax-step strong{font-size:15px}.ax-step small{color:var(--muted);line-height:1.35}.ax-review-note{background:#f8fbff;border:1px dashed var(--line);border-radius:12px;padding:11px 12px;margin:10px 0}.ax-review-note b{display:block;margin-bottom:5px}.ax-review-note span{display:block;line-height:1.45}.ax-review-note small{display:block;color:var(--muted);margin-top:6px}.ax-action-toolbar button{font-size:12px;padding:8px 10px}.badge.soft{background:#eef3fb;color:#2b3952}@media(max-width:1200px){.ax-process-steps{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.ax-process-steps{grid-template-columns:1fr}}


/* Notice top-level board */
.notice-cards .card b { color:#0f172a; }
.notice-layout { display:grid; grid-template-columns: 360px minmax(0, 1fr); gap:16px; align-items:start; }
.notice-left, .notice-right { min-height: 520px; }
.notice-list { display:flex; flex-direction:column; gap:10px; margin-top:12px; max-height:650px; overflow:auto; }
.notice-item { width:100%; text-align:left; border:1px solid #dbe5f4; background:#f8fbff; border-radius:14px; padding:14px; color:#0f172a; cursor:pointer; }
.notice-item:hover { background:#eef5ff; }
.notice-item.unread { border-color:#4f6df5; background:#eef4ff; }
.notice-item.pinned { box-shadow: inset 4px 0 0 #4f6df5; }
.notice-item-head { display:flex; justify-content:space-between; align-items:center; gap:8px; }
.notice-item strong { display:block; font-size:15px; }
.notice-item small, .notice-item em { display:block; margin-top:5px; color:#64748b; font-size:12px; font-style:normal; }
.notice-form { margin-top:12px; }
.notice-body { min-height:260px; }
.check-row { display:flex; gap:8px; align-items:center; margin:10px 0 14px; font-weight:700; color:#334155; }
.notice-readonly h3 { margin-top:0; }
.notice-readonly p { line-height:1.7; background:#f8fafc; border:1px solid #dbe5f4; border-radius:14px; padding:18px; min-height:240px; }
.badge.danger { background:#fee2e2; color:#b91c1c; }
@media (max-width: 1100px) { .notice-layout { grid-template-columns: 1fr; } }

.dashboard-grid { display:grid; grid-template-columns: minmax(0, 1.5fr) minmax(340px, .9fr); gap:16px; align-items:start; }
@media (max-width:1100px){ .dashboard-grid { grid-template-columns:1fr; } }

/* final all-features nested menu */
.nav-group { margin-top: 16px; }
.nav-group .nav-title { color:#fff; font-weight:800; margin: 14px 0 6px; font-size: 14px; }
.nav-group button { width:100%; text-align:left; margin: 4px 0; padding: 9px 12px; border-radius: 10px; border:0; background: transparent; color:#dbe7ff; font-weight:700; cursor:pointer; }
.nav-group button:hover { background: rgba(255,255,255,.08); }
.nav-group button.active { background:#2d3f5b; color:#fff; }
.ax-tab-guide { display:flex; gap:10px; align-items:center; flex-wrap:wrap; padding:12px 16px; margin: 10px 0 16px; }

/* 1뎁스/2뎁스 접힘 메뉴 구조 */
.nav .nav-title.nav-toggle{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  background:transparent;color:#fff;border-radius:10px;padding:11px 14px;
  font-size:15px;font-weight:900;margin:6px 0 4px;cursor:pointer;
}
.nav .nav-title.nav-toggle:hover{background:rgba(255,255,255,.08)}
.nav .nav-title.nav-toggle span{font-size:12px;color:#aebdda;transition:transform .18s ease}
.nav-group.open>.nav-title.nav-toggle{background:#17243a;color:#fff}
.nav-group.open>.nav-title.nav-toggle span{transform:rotate(180deg)}
.nav-sub{display:none;padding-left:8px;margin:4px 0 8px;border-left:1px solid rgba(255,255,255,.12)}
.nav-group.open>.nav-sub{display:block}
.nav button.nav-main{font-size:15px;font-weight:900}
.nav-sub button{font-size:13px;padding:9px 12px;color:#dbe7ff}
.nav-sub button.active{background:#2d3f5b;color:#fff}
.writer-list.nav-sub{display:none;gap:4px}
.nav-group.open>.writer-list.nav-sub{display:flex;flex-direction:column}

/* AICC 기술팀 Agile형 대시보드 */
.dash-head{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:18px}.dash-head h2{margin:0 0 8px}.dash-filter{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:10px 12px}.dash-filter span{font-weight:900;color:#172033}.dash-kpis{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px;margin-bottom:18px}.dash-kpi{background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:0 6px 18px rgba(15,23,42,.045)}.dash-kpi small{display:block;color:var(--muted);font-weight:800;margin-bottom:8px}.dash-kpi b{display:block;font-size:30px;letter-spacing:-.6px;color:#06152d}.dash-kpi em{display:block;margin-top:8px;font-style:normal;color:#64748b;font-size:13px}.dash-board-grid{display:grid;grid-template-columns:1.25fr .85fr .85fr;gap:16px;align-items:stretch}.dash-panel{background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:0 6px 18px rgba(15,23,42,.04);min-width:0}.dash-wide{grid-column:span 2}.panel-title{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:14px}.panel-title h3{margin:0;font-size:18px}.panel-title span{color:var(--muted);font-size:13px;font-weight:800}.week-bars{display:flex;flex-direction:column;gap:12px}.week-row{display:grid;grid-template-columns:130px minmax(0,1fr) 110px;gap:12px;align-items:center}.week-row label{font-weight:800;color:#172033}.week-row strong{font-size:13px;color:#52637a;text-align:right}.week-bar-wrap{height:28px;background:#edf2fa;border-radius:999px;position:relative;overflow:hidden}.week-bar{position:absolute;left:0;height:12px;border-radius:999px}.week-bar.planned{top:4px;background:#ec4899}.week-bar.actual{bottom:4px;background:#06b6d4}.dash-legend{display:flex;gap:18px;margin-top:14px;color:#64748b;font-weight:800;font-size:12px}.dash-legend span{display:flex;align-items:center;gap:6px}.dash-legend i{width:10px;height:10px;border-radius:999px;display:inline-block}.planned-dot{background:#ec4899}.actual-dot{background:#06b6d4}.donut-wrap{display:flex;gap:18px;align-items:center}.donut{width:150px;height:150px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex:0 0 auto}.donut.small{width:132px;height:132px}.donut>div{width:78px;height:78px;border-radius:50%;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:900;font-size:24px;box-shadow:inset 0 0 0 1px var(--line)}.donut small{font-size:11px;color:#64748b;margin-top:2px}.legend-list{display:flex;flex-direction:column;gap:8px;font-size:13px;font-weight:800}.legend-list span{display:flex;align-items:center;gap:7px;color:#334155}.legend-list i{display:inline-block;width:10px;height:10px;border-radius:999px}.legend-list.compact{max-height:160px;overflow:auto}.dash-table-panel{overflow:hidden}.dash-table-scroll{overflow:auto}.dash-table{width:100%;border-collapse:collapse}.dash-table th,.dash-table td{border-bottom:1px solid #e5edf7;padding:10px 9px;text-align:left;font-size:13px;vertical-align:middle}.dash-table th{background:#f8fbff;color:#42526b;font-weight:900}.dash-table td b{display:block}.dash-table td small{display:block;color:#64748b;margin-top:3px}.dash-bar{height:12px;background:#edf2fa;border-radius:999px;overflow:hidden;min-width:90px}.dash-bar span{display:block;height:100%;background:#06b6d4;border-radius:999px}.dash-bar.c0 span{background:#2563eb}.dash-bar.c1 span{background:#ec4899}.dash-bar.c2 span{background:#f97316}.dash-bar.c3 span{background:#22c55e}.dash-bar.c4 span{background:#8b5cf6}.status-list{display:flex;flex-direction:column;gap:10px}.status-list>div{display:grid;grid-template-columns:88px minmax(0,1fr) 36px;gap:9px;align-items:center}.status-list span{font-weight:800;color:#334155;font-size:13px}.status-list b{text-align:right}.ax-mini-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:14px}.ax-mini-grid div{background:#f8fbff;border:1px solid #e1e9f5;border-radius:14px;padding:12px;text-align:center}.ax-mini-grid b{display:block;font-size:23px}.ax-mini-grid span{display:block;color:#64748b;font-size:12px;font-weight:900;margin-top:4px}.notice-mini-list{display:flex;flex-direction:column;gap:10px}.notice-mini{width:100%;text-align:left;border:1px solid #dbe5f4;background:#fff;border-radius:14px;padding:12px;color:#172033}.notice-mini.pinned{box-shadow:inset 4px 0 0 #4f6df5}.notice-mini strong{display:block}.notice-mini small{display:block;color:#64748b;margin-top:6px}.recent-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.recent-card{border:1px solid #dbe5f4;background:#fff;border-radius:14px;padding:13px}.recent-card strong{display:block}.recent-card small{display:block;color:#64748b;margin-top:6px}@media(max-width:1500px){.dash-board-grid{grid-template-columns:1fr 1fr}.dash-kpis{grid-template-columns:repeat(3,1fr)}.dash-wide{grid-column:span 2}}@media(max-width:980px){.dash-head{flex-direction:column}.dash-kpis{grid-template-columns:1fr 1fr}.dash-board-grid{grid-template-columns:1fr}.dash-wide{grid-column:span 1}.donut-wrap{flex-direction:column;align-items:flex-start}.week-row{grid-template-columns:1fr}.week-row strong{text-align:left}.recent-grid{grid-template-columns:1fr}}@media(max-width:620px){.dash-kpis{grid-template-columns:1fr}}

/* dashboard layout tune: swap report status/notice placement and make category card fit content */
.category-panel{align-self:start;min-height:0;}
.category-panel .donut-wrap{align-items:flex-start;}
.category-panel .legend-list.compact{max-height:210px;overflow:auto;padding-right:4px;}
.category-panel .donut.small{width:136px;height:136px;}
.category-panel .donut.small>div{width:72px;height:72px;}
.notice-panel{min-height:0;}
.report-status-panel{min-height:0;}
@media(max-width:1500px){.category-panel{align-self:stretch;}}

/* AX 진행현황 표 보강 */
.ax-progress-panel{min-height:360px}
.ax-progress-scroll{max-height:260px;overflow:auto;border:1px solid #e5edf7;border-radius:14px;background:#fff}
.ax-progress-table th:nth-child(1){width:92px}
.ax-progress-table th:nth-child(2){width:120px}
.ax-progress-table th:nth-child(4){width:86px}
.ax-progress-table td{vertical-align:top}
.ax-progress-table a{font-weight:900;color:#2563eb;text-decoration:none}
.ax-progress-table a:hover{text-decoration:underline}
.ax-progress-table .muted{font-size:12px;color:#64748b}
.ax-complete-final{background:#eefbf3;color:#15803d;border:1px solid #bbf7d0}

/* 프로젝트 관리 */
.project-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0 18px}.project-tabs button{background:#eef3fb;color:#172033}.project-tabs button.active{background:var(--primary);color:#fff}.project-kpis{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px;margin:18px 0}.project-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;align-items:start}.project-grid .dash-wide{grid-column:span 2}.project-manage-grid{display:grid;grid-template-columns:minmax(440px,.95fr) minmax(0,1.25fr);gap:16px;align-items:start}.project-form-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.project-form-grid .wide{grid-column:1/-1}.project-form-grid label{display:block;font-weight:900;margin-bottom:6px}.small-select{max-width:380px}.assign-board{display:grid;grid-template-columns:1fr 1fr;gap:16px}.assign-col{border:1px solid var(--line);background:#f8fbff;border-radius:16px;padding:16px;min-height:420px}.assign-col.selected{background:#fff}.assign-col h3{margin-top:0}.assign-list{display:flex;flex-direction:column;gap:10px;max-height:620px;overflow:auto}.person-card{display:flex;justify-content:space-between;align-items:center;gap:12px;background:#fff;border:1px solid #dbe5f4;border-radius:14px;padding:12px}.person-card.selected{background:#f5f9ff}.person-card b{display:block}.person-card small{display:block;color:#64748b;margin-top:4px}.person-card>div:last-child{display:flex;gap:8px;align-items:center}.person-card select{width:120px}.empty{border:1px dashed var(--line);border-radius:14px;padding:20px;text-align:center;color:#64748b;background:#fff}@media(max-width:1400px){.project-kpis{grid-template-columns:repeat(3,1fr)}.project-grid{grid-template-columns:1fr 1fr}.project-manage-grid{grid-template-columns:1fr}.project-form-grid{grid-template-columns:1fr 1fr}}@media(max-width:850px){.project-kpis,.project-grid,.assign-board,.project-form-grid{grid-template-columns:1fr}.project-grid .dash-wide{grid-column:span 1}}

/* Project URL banners */
.project-sites-grid{display:grid;grid-template-columns:minmax(430px,.9fr) minmax(0,1.25fr);gap:16px;align-items:start}
.bulk-box{margin-top:18px;border-top:1px solid var(--line);padding-top:14px}.bulk-box h4{margin:0 0 6px}.bulk-box textarea{min-height:150px;margin:8px 0}
.site-board{min-height:620px}.site-section{margin-bottom:18px}.site-section h4{margin:0 0 10px;font-size:16px}.site-section h4 small{color:#64748b;margin-left:6px}
.site-banner-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.site-banner-card{border:1px solid #dbe5f4;border-radius:16px;background:#fff;padding:14px;box-shadow:0 8px 22px rgba(15,23,42,.05);position:relative;overflow:hidden}.site-banner-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:#2f65f6}.site-banner-card.site-개발:before{background:#10b981}.site-banner-card.site-데모:before{background:#f97316}.site-banner-head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.site-banner-head span{font-size:12px;font-weight:900;border-radius:999px;background:#eef3ff;color:#2f65f6;padding:5px 9px;white-space:nowrap}.site-개발 .site-banner-head span{background:#ecfdf5;color:#047857}.site-데모 .site-banner-head span{background:#fff7ed;color:#c2410c}.site-banner-head b{font-size:16px;line-height:1.35}.site-banner-card p{color:#64748b;font-size:13px;min-height:22px;margin:9px 0}.site-url-chips{display:flex;flex-wrap:wrap;gap:6px;margin:10px 0}.site-url-chips a,.site-url-chips span{font-size:12px;background:#f1f5f9;border:1px solid #dbe5f4;border-radius:999px;padding:6px 9px;color:#0f172a;text-decoration:none;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.site-url-chips a:hover{background:#e0ecff;color:#1749d1}.site-banner-meta{display:flex;justify-content:space-between;gap:10px;align-items:center;border-top:1px solid #edf2f7;padding-top:10px}.site-banner-meta small{color:#64748b}.site-banner-meta>div{display:flex;gap:6px;align-items:center}.button-like{display:inline-flex;align-items:center;justify-content:center;padding:7px 10px;border-radius:10px;background:#eef3fb;text-decoration:none;color:#172033;font-weight:800;font-size:13px}
.site-mini-list{display:flex;flex-direction:column;gap:8px}.site-mini{display:block;border:1px solid #dbe5f4;border-radius:12px;background:#f8fbff;padding:10px;text-decoration:none;color:#0f172a}.site-mini span{font-size:11px;font-weight:900;color:#2f65f6}.site-mini b{display:block;margin-top:2px}.site-mini small{display:block;color:#64748b;margin-top:2px}
@media(max-width:1200px){.project-sites-grid{grid-template-columns:1fr}.site-banner-grid{grid-template-columns:1fr}}

/* 솔루션 배너 등록/노출 */
.solution-banner-panel{min-height:360px}
.solution-form{background:#f8fbff;border:1px solid #e1e9f5;border-radius:16px;padding:14px;margin-bottom:14px}
.solution-form-grid{display:grid;grid-template-columns:1.2fr 1.6fr .8fr .55fr;gap:10px;align-items:end}
.solution-form-grid .wide{grid-column:1/-1}
.solution-form-grid label{display:block;font-weight:900;color:#172033;margin-bottom:6px;font-size:13px}
.solution-actions{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.solution-banner-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.solution-banner-card{border:1px solid #dbe5f4;background:#fff;border-radius:16px;padding:14px;box-shadow:0 6px 14px rgba(15,23,42,.04);display:flex;flex-direction:column;gap:12px;min-height:170px}
.solution-banner-main{cursor:pointer;display:flex;flex-direction:column;gap:7px;min-height:96px}
.solution-banner-main span{display:inline-flex;align-self:flex-start;padding:5px 9px;border-radius:999px;background:#eef4ff;color:#1d4ed8;font-size:12px;font-weight:900}
.solution-banner-main strong{font-size:18px;color:#06152d;line-height:1.25}
.solution-banner-main small{color:#475569;line-height:1.45;min-height:20px}
.solution-banner-main em{font-style:normal;color:#2563eb;font-size:12px;word-break:break-all}
.solution-banner-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap;margin-top:auto}
.solution-banner-actions button{padding:8px 10px;border-radius:10px}
@media(max-width:1500px){.solution-banner-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.solution-form-grid{grid-template-columns:1fr 1fr}}
@media(max-width:760px){.solution-banner-grid,.solution-form-grid{grid-template-columns:1fr}}

/* solution banner dashboard / management */
.solution-banner-panel{min-height:auto}
.solution-banner-panel .panel-title{margin-bottom:12px}
.solution-speed-dial{
  border-radius:24px;
  padding:22px;
  background:
    radial-gradient(circle at 15% 10%, rgba(79,109,245,.35), transparent 28%),
    radial-gradient(circle at 88% 20%, rgba(6,182,212,.35), transparent 24%),
    linear-gradient(135deg,#1f2b76 0%,#4757d6 46%,#18c2d5 100%);
  box-shadow:0 18px 42px rgba(38,75,180,.18);
  overflow:hidden;
}
.solution-speed-row{display:grid;grid-template-columns:150px minmax(0,1fr);gap:18px;align-items:center;margin-bottom:20px}
.solution-speed-row:last-child{margin-bottom:0}
.solution-speed-row-head{color:#fff;min-height:96px;display:flex;flex-direction:column;justify-content:center;gap:8px}
.solution-speed-row-head strong{display:block;font-size:22px;letter-spacing:-.5px}
.solution-speed-row-head span{display:block;font-size:12px;opacity:.84;line-height:1.45}
.solution-speed-row-head em{align-self:flex-start;font-style:normal;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.28);border-radius:999px;padding:5px 10px;font-size:12px;font-weight:900}
.solution-speed-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:14px}
.solution-speed-card{
  min-height:106px;
  border:1px solid rgba(255,255,255,.45);
  border-radius:14px;
  background:rgba(255,255,255,.94);
  box-shadow:0 10px 24px rgba(15,23,42,.16);
  padding:12px 10px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:7px;
  cursor:pointer;
  transition:transform .14s ease, box-shadow .14s ease, background .14s ease;
  overflow:hidden;
}
.solution-speed-card:hover{transform:translateY(-3px);box-shadow:0 18px 32px rgba(15,23,42,.24);background:#fff}
.solution-logo{
  width:46px;height:46px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;font-weight:1000;letter-spacing:-.8px;
  color:#fff;background:linear-gradient(135deg,#2563eb,#06b6d4);
  box-shadow:inset 0 -10px 18px rgba(0,0,0,.12);
}
.solution-logo-운영{background:linear-gradient(135deg,#2563eb,#0ea5e9)}
.solution-logo-개발{background:linear-gradient(135deg,#16a34a,#22c55e)}
.solution-logo-데모{background:linear-gradient(135deg,#f97316,#f43f5e)}
.solution-speed-card b{max-width:100%;font-size:13px;line-height:1.25;color:#07152e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:center}
.solution-speed-card small{max-width:100%;font-size:11px;color:#475569;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:center}
.solution-speed-card.empty-slot{background:rgba(255,255,255,.16);border:1px dashed rgba(255,255,255,.62);box-shadow:none;color:#fff}
.solution-speed-card.empty-slot .solution-logo{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.25);box-shadow:none;color:#fff;font-size:25px}
.solution-speed-card.empty-slot b,.solution-speed-card.empty-slot small{color:#fff;opacity:.94}
.solution-manage-layout{align-items:flex-start}
.solution-manage-layout .small-left{max-width:250px}
.solution-banner-grid.manage{grid-template-columns:repeat(2,minmax(0,1fr))}
.solution-form{margin-top:0}
@media(max-width:1500px){.solution-speed-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.solution-speed-row{grid-template-columns:120px minmax(0,1fr)}}
@media(max-width:900px){.solution-speed-row{grid-template-columns:1fr}.solution-speed-row-head{min-height:auto}.solution-speed-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:560px){.solution-speed-dial{padding:14px}.solution-speed-grid{grid-template-columns:1fr}.solution-banner-grid.manage{grid-template-columns:1fr}.solution-manage-layout{display:block}}

/* 프로젝트 대시보드 - 사람별 프로젝트 관리표 */
.person-project-panel{align-self:start;}
.person-project-panel .muted{margin:0 0 12px;font-size:13px;line-height:1.5}
.person-project-scroll{overflow:auto;border:1px solid #dbe5f4;border-radius:14px;background:#fff;max-height:460px}
.person-project-table{width:100%;border-collapse:separate;border-spacing:0;min-width:1080px}
.person-project-table th{position:sticky;top:0;background:#f8fbff;z-index:1;color:#334155;font-size:13px;border-bottom:1px solid #dbe5f4;padding:12px;text-align:left}
.person-project-table td{border-bottom:1px solid #edf2f7;padding:12px;vertical-align:middle;background:#fff}
.person-project-table tr:last-child td{border-bottom:0}
.person-project-table td b{display:block;font-size:14px;color:#0f172a;margin-bottom:4px}
.person-project-table td small{display:block;color:#64748b;font-size:12px;line-height:1.35}
.timeline-cell{min-width:180px}.timeline-bar{height:18px;background:#e8eef8;border-radius:999px;overflow:hidden;margin-bottom:6px}.timeline-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#4f6df5,#06b6d4)}
.project-people-chips{display:flex;flex-wrap:wrap;gap:6px;min-width:110px}.project-people-chips span{display:inline-flex;background:#eef4ff;color:#1e3a8a;border:1px solid #dbe7ff;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:900}.project-empty-role{display:inline-flex;background:#f1f5f9;color:#94a3b8;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:900}.project-status-chip{display:inline-flex;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:900;margin-bottom:4px}.project-status-chip.active{background:#e0f2fe;color:#0369a1}.project-status-chip.done{background:#dcfce7;color:#15803d}.project-status-chip.wait{background:#fef3c7;color:#92400e}.project-status-chip.danger{background:#fee2e2;color:#b91c1c}
