*{box-sizing:border-box}body{margin:0;font-family:system-ui,Apple SD Gothic Neo,sans-serif;color:#1f2937;background:#f9fafb}.layout{display:flex;min-height:100vh}.sidebar{width:210px;background:#151a24;color:#e5e7eb;flex-shrink:0;position:sticky;top:0;height:100vh;display:flex;flex-direction:column}.sidebar nav{flex:1;overflow-y:auto}.side-foot{border-top:1px solid #262d3b;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:8px}.side-user{min-width:0}.side-name{font-size:13px;font-weight:600;color:#e9ecf1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.side-role{font-size:11px;color:#8b94a4;margin-top:2px}.side-logout{flex-shrink:0;background:#262d3b;color:#cbd5e1;border:none;border-radius:6px;padding:6px 10px;font-size:12px;cursor:pointer}.side-logout:hover{background:#323b4d;color:#fff}.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f5f6f8;padding:20px}.auth-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:32px 28px;width:100%;max-width:380px;box-shadow:0 4px 24px #0000000d;display:flex;flex-direction:column}.auth-brand{font-size:20px;font-weight:800;color:#151a24}.auth-sub{color:#69727f;font-size:13px;margin:4px 0 18px}.auth-card h2{font-size:17px;margin:0 0 16px}.auth-card label{display:flex;flex-direction:column;gap:5px;font-size:13px;color:#475569;margin-bottom:12px}.auth-card input,.auth-card select{padding:9px 11px;border:1px solid #d1d5db;border-radius:7px;font-size:14px}.auth-btn{width:100%;margin:6px 0 0;padding:10px;justify-content:center}.auth-foot{text-align:center;font-size:13px;color:#69727f;margin-top:14px}.auth-foot a{color:#159a98;text-decoration:none;font-weight:600}.sidebar .brand{padding:20px 16px;font-weight:700;font-size:16px;border-bottom:1px solid #1f2937}.sidebar nav{display:flex;flex-direction:column;padding:8px 0}.nav-section{padding:6px 0}.nav-module{padding:8px 16px 4px;font-size:11px;letter-spacing:.04em;color:#64748b;font-weight:700}.nav-link{display:flex;align-items:center;gap:6px;padding:9px 16px 9px 22px;color:#cbd5e1;text-decoration:none;font-size:14px}.nav-link:hover{background:#1f2937}.nav-link.active{background:#159a98;color:#fff}.nav-link.soon{color:#475569;cursor:default}.nav-link.soon em{font-style:normal;font-size:10px;background:#1f2937;color:#64748b;padding:1px 5px;border-radius:4px}.content{flex:1;padding:24px 32px;max-width:1100px}.breadcrumb{color:#6b7280;font-size:13px}h1{font-size:22px;margin:6px 0 20px}.toolbar{display:flex;gap:8px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.toolbar input,.toolbar select{padding:8px 10px;border:1px solid #d1d5db;border-radius:6px;font-size:14px}.toolbar input{min-width:180px}.toolbar .meta{margin-left:auto;color:#6b7280;font-size:13px}table{width:100%;border-collapse:collapse;background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}th,td{padding:10px 14px;text-align:left;border-bottom:1px solid #f1f5f9;font-size:14px}th{background:#f8fafc;color:#475569;font-weight:600}td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}tbody tr:hover{background:#f8fafc}.empty{text-align:center;color:#9ca3af;padding:32px}.error{background:#fef2f2;color:#b91c1c;padding:10px 14px;border-radius:6px;margin-bottom:12px;font-size:14px}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}.kpi{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px}.kpi-label{color:#6b7280;font-size:13px}.kpi-value{font-size:24px;font-weight:700;margin:6px 0 2px}.kpi-sub{color:#9ca3af;font-size:12px}.delta{font-size:22px;font-weight:700}.delta.up{color:#0e7d7b}.delta.down{color:#c2683a}.delta.none{color:#9ca3af;font-size:20px}.panel{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:18px 20px;margin-bottom:20px}.panel h2{font-size:15px;margin:0 0 14px;color:#374151}.bar-row{display:flex;align-items:center;gap:10px;margin:8px 0;font-size:13px}.bar-name{width:90px;flex-shrink:0;color:#475569}.bar-track{flex:1;background:#f1f5f9;border-radius:4px;height:14px;overflow:hidden}.bar-fill{height:100%;background:#159a98;border-radius:4px}.bar-val{width:120px;text-align:right;flex-shrink:0;font-variant-numeric:tabular-nums}.bar-val em{color:#9ca3af;font-style:normal;font-size:12px}.trend{display:flex;align-items:flex-end;gap:8px;height:200px;padding-top:10px}.trend-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%}.trend-bar{width:70%;background:#43c0be;border-radius:4px 4px 0 0;min-height:2px;transition:height .2s}.trend-col:hover .trend-bar{background:#159a98}.trend-amt{font-size:10px;color:#6b7280;margin-top:4px}.trend-label{font-size:11px;color:#9ca3af;margin-top:2px}tbody tr.clickable{cursor:pointer}.breadcrumb a{color:#6b7280;text-decoration:none}.breadcrumb a:hover{text-decoration:underline}.detail-head{display:flex;align-items:center;gap:10px;margin:6px 0 18px}.detail-head h1{margin:0}.badge{background:#eff6ff;color:#159a98;font-size:12px;font-weight:600;padding:3px 10px;border-radius:999px}.kpi-grid.kpi-3{grid-template-columns:repeat(3,1fr)}.kpi-value small{font-size:13px;color:#9ca3af;font-weight:400}.kpi-value.sm{font-size:18px}.tabs{display:flex;gap:4px;border-bottom:1px solid #e5e7eb;margin-bottom:18px}.tab{background:none;border:none;padding:10px 16px;font-size:14px;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent}.tab:hover{color:#151a24}.tab.active{color:#159a98;border-bottom-color:#159a98;font-weight:600}.panel-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.panel-head h2{margin:0}.btn{padding:7px 14px;border:1px solid #d1d5db;background:#fff;border-radius:6px;font-size:13px;cursor:pointer;margin-left:6px}.btn:hover{background:#f8fafc}.btn.primary{background:#159a98;color:#fff;border-color:#159a98}.btn.primary:disabled{opacity:.6;cursor:default}.info-grid{margin:0}.info-row{display:flex;border-bottom:1px solid #f1f5f9;padding:10px 0}.info-row dt{width:140px;flex-shrink:0;color:#6b7280;font-size:14px}.info-row dd{margin:0;flex:1;font-size:14px}.info-row dd input{width:100%;max-width:360px;padding:6px 9px;border:1px solid #d1d5db;border-radius:6px;font-size:14px}.muted{color:#9ca3af}.matrix-wrap{overflow-x:auto}.matrix{min-width:720px}.matrix th,.matrix td{white-space:nowrap;padding:8px 10px}.matrix .sticky{position:sticky;left:0;background:#fff;z-index:1;min-width:160px}.matrix thead .sticky{background:#f8fafc}.matrix .total{font-weight:700;background:#f8fafc}.matrix tfoot td{font-weight:700;background:#f8fafc;border-top:2px solid #e5e7eb}.status{background:#f0fdf4;color:#16a34a;font-size:12px;padding:2px 8px;border-radius:4px}.chip-list{list-style:none;padding:0;margin:8px 0 0;display:flex;gap:8px;flex-wrap:wrap}.chip{background:#f1f5f9;color:#334155;font-size:13px;padding:5px 12px;border-radius:999px}.kpi-value.neg{color:#dc2626}.kpi-value.pos{color:#16a34a}.bar-fill.cost{background:#f97316}.trend-pair{display:flex;align-items:flex-end;justify-content:center;gap:3px;width:100%;height:100%}.trend-pair .trend-bar{width:42%}.trend-bar.cost{background:#fb923c}.trend-bar.cost:hover,.trend-col:hover .trend-bar.cost{background:#ea580c}.trend-bar.rev{background:#43c0be}.matrix.pl tbody .pl-revenue td{background:#f8fafc}.matrix.pl tbody .pl-subtotal td{font-weight:700;border-top:1px solid #cbd5e1;background:#f1f5f9}.matrix.pl tbody .pl-profit td{font-weight:700;color:#b45309;background:#fffbeb}.matrix.pl tbody .pl-total td{font-weight:800;color:#15803d;background:#f0fdf4;border-top:2px solid #cbd5e1}.check{display:flex;align-items:center;gap:5px;font-size:13px;color:#475569}.tag{background:#eef2ff;color:#4338ca;font-size:12px;padding:2px 8px;border-radius:4px}.tag.media{background:#eaf0fb;color:#3760b5}.tag.cloud{background:#f0eafb;color:#6b46c1}.tag.common{background:#f1f3f5;color:#5a626d}.tag.run{background:#e4f3f2;color:#0e7d7b}.unit-tag{font-size:11px;padding:2px 8px;border-radius:5px;font-weight:600}td .sub{font-size:12px;color:#9ca3af;margin-top:2px}.todo{display:flex;align-items:flex-start;gap:6px}.todo.done span{color:#9ca3af;text-decoration:line-through}.todo em{color:#9ca3af;font-style:normal}.check-btn{background:none;border:none;cursor:pointer;font-size:16px;line-height:1;padding:0;color:#159a98}.form-panel{background:#f8fafc}.form-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.form-grid label{display:flex;flex-direction:column;gap:4px;font-size:13px;color:#475569}.form-grid label.wide{grid-column:span 2}.form-grid input,.form-grid select{padding:7px 9px;border:1px solid #d1d5db;border-radius:6px;font-size:14px}.form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:14px}.kanban{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}.kan-col{background:#f1f5f9;border-radius:8px;min-height:120px;display:flex;flex-direction:column}.kan-head{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;font-weight:600;font-size:13px;border-bottom:1px solid #e2e8f0}.kan-meta{color:#64748b;font-size:11px;font-weight:400}.kan-body{padding:8px;display:flex;flex-direction:column;gap:8px}.kan-empty{color:#cbd5e1;text-align:center;padding:12px 0}.kan-card{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:10px;font-size:13px}.kan-title{font-weight:600;margin-bottom:4px}.kan-sub{color:#6b7280;font-size:12px}.kan-amt{color:#159a98;font-weight:700;margin-top:6px}.kan-close{color:#9ca3af;font-size:11px;margin-top:2px}.kan-move{margin-top:8px;width:100%;padding:4px 6px;border:1px solid #e2e8f0;border-radius:5px;font-size:12px}.upload-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.upload-row input[type=file]{font-size:14px}.ok-banner{background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-weight:600}.info-banner{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe;padding:12px 16px;border-radius:8px;margin-bottom:16px}.brand-sub{display:block;font-size:11px;color:#8b94a4;font-weight:400;margin-top:4px}.nav-num{font-family:ui-monospace,monospace;color:#159a98;font-size:10px}.seg{display:inline-flex;border:1px solid #d1d5db;border-radius:7px;overflow:hidden}.seg-btn{background:#fff;border:none;padding:7px 14px;font-size:13px;cursor:pointer;color:#475569;border-right:1px solid #e5e7eb}.seg-btn:last-child{border-right:0}.seg-btn.on{background:#159a98;color:#fff;font-weight:600}.note-box{font-size:12.5px;color:#6b7280;margin-top:12px;padding:10px 12px;background:#fafbfc;border:1px solid #eef0f3;border-radius:8px}.note-box b{color:#c2683a}.mini{padding:4px 6px;border:1px solid #d8dde3;border-radius:5px;font-size:12px;background:#fff}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.cal-head{margin-bottom:6px}.cal-wd{text-align:center;font-size:12px;color:#6b7280;font-weight:600;padding:4px 0}.cal-cell{min-height:86px;border:1px solid #eef0f3;border-radius:6px;padding:5px;background:#fff}.cal-cell.empty{background:#fafbfc;border-style:dashed}.cal-day{font-size:12px;color:#69727f;margin-bottom:4px}.cal-item{font-size:10.5px;padding:2px 5px;border-radius:4px;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-item.evt{background:#e4f3f2;color:#0e7d7b}.cal-item.todo{background:#f7ece4;color:#c2683a}
