You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

2 lines
14 KiB

:root{--brand-primary:#b11e23}.dashboard-page{--brand-primary:#b11e23;--workbench-font-base:16px;--workbench-font-sm:14px;--workbench-font-lg:18px;--workbench-font-h1:22px;--workbench-font-h2:18px;font-family:var(--slake-font-family,"Noto Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif);font-size:var(--workbench-font-base);color:#000;line-height:1.55}.dashboard-page-title,.radar-page-title{color:#111827;font-size:var(--workbench-font-h1);margin:0;padding-left:.72rem;font-weight:600;line-height:1.25;position:relative}.dashboard-page-title:before,.radar-page-title:before{content:"";background:var(--brand-primary);border-radius:999px;width:3px;position:absolute;top:.16rem;bottom:.16rem;left:0}.dashboard-section-title{color:#1f2937;font-size:var(--workbench-font-h2);margin:0;padding-left:.62rem;font-weight:600;line-height:1.35;position:relative}.dashboard-section-title:before{content:"";background:#b11e23bf;border-radius:999px;width:3px;height:.72em;position:absolute;top:.36em;left:0}.dashboard-count-badge{color:var(--brand-primary);min-height:24px;font-size:var(--workbench-font-sm);background:#b11e2314;border-radius:999px;align-items:center;padding:.16rem .56rem;font-weight:500;display:inline-flex}.dashboard-overview-card{background:linear-gradient(#fff 0%,#fbfcfe 100%)}.executive-metric-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem;display:grid}.executive-metric{background:linear-gradient(#fff 0%,#fbfcfe 100%);border:1px solid #e5e7eb;border-radius:8px;min-height:86px;padding:.72rem .78rem;box-shadow:0 5px 14px #0f172a09}.executive-metric.primary{background:#b11e2309;border-color:#b11e234d}.executive-metric .metric-head{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.executive-metric .metric-head span{color:#6b7280;font-size:var(--workbench-font-sm)}.executive-metric .metric-head .metric-icon{width:24px;height:24px;color:var(--brand-primary);background:#b11e2314;border-radius:6px;justify-content:center;align-items:center;font-size:18px;display:inline-flex}.executive-metric strong{color:#1f2937;margin:.28rem 0 .18rem;font-size:1.5rem;line-height:1.1;display:block}.executive-metric em{color:#6b7280;font-size:var(--workbench-font-sm);font-style:normal;display:block}.dashboard-todo-list{gap:.65rem;display:grid}.dashboard-todo-card{color:#1f2937;text-align:left;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:8px;grid-template-columns:34px minmax(0,1fr) auto;align-items:center;gap:.68rem;width:100%;padding:.68rem .72rem;transition:border-color .15s,background .15s;display:grid}.dashboard-todo-card:hover{background:#b11e2309;border-color:#b11e2359}.dashboard-todo-icon{width:34px;height:34px;color:var(--brand-primary);background:#b11e2314;border-radius:8px;justify-content:center;align-items:center;font-size:16px;display:inline-flex}.dashboard-todo-card b,.dashboard-todo-card em{display:block}.dashboard-todo-card b{font-size:var(--workbench-font-base)}.dashboard-todo-card em{color:#667085;font-size:var(--workbench-font-sm);margin-top:.12rem}.dashboard-todo-card strong{color:#1f2937;font-size:1.25rem}.dashboard-todo-card.is-urgent{border-color:#dc354559}.dashboard-todo-card.is-warning{border-color:#f0a80073}.dashboard-calendar-actions{background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;align-items:center;gap:.25rem;padding:.2rem;display:inline-flex}.dashboard-calendar-actions button{color:#667085;font-size:var(--workbench-font-sm);cursor:pointer;background:0 0;border:0;border-radius:6px;align-items:center;gap:.28rem;padding:.28rem .55rem;line-height:1.2;display:inline-flex}.dashboard-calendar-actions button:hover{color:var(--brand-primary);background:#fff;box-shadow:0 1px 4px #0f172a0f}.dashboard-event-list{background:#f8fafc;border:1px solid #edf1f5;border-radius:8px;grid-template-columns:repeat(4,minmax(0,1fr));gap:.55rem;margin-bottom:.75rem;padding:.45rem;display:grid}.dashboard-event-row{background:0 0;border:0;border-radius:6px;grid-template-columns:28px auto minmax(0,1fr);align-items:center;gap:.18rem .5rem;min-height:52px;padding:.34rem .45rem;display:grid}.dashboard-event-row+.dashboard-event-row{border-left:1px solid #e5e7eb;border-radius:0;padding-left:.85rem}.dashboard-event-row .event-row-icon{width:28px;height:28px;color:var(--brand-primary);background:#b11e2314;border-radius:6px;grid-row:span 2;justify-content:center;align-items:center;font-size:14px;display:inline-flex}.dashboard-event-row span,.dashboard-event-row em{display:block}.dashboard-event-row span{color:#6b7280;font-size:var(--workbench-font-sm)}.dashboard-event-row strong{color:#1f2937;font-size:var(--workbench-font-lg);grid-area:1/3;justify-self:start;line-height:1}.dashboard-event-row em{color:#6b7280;font-size:var(--workbench-font-sm);grid-column:2/-1;font-style:normal}.calendar-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:6px;display:grid}.calendar-grid-heads{margin-bottom:6px}.calendar-weeks{flex-direction:column;gap:6px;display:flex}.calendar-week-grid{grid-template-columns:repeat(7,minmax(0,1fr));align-items:start;gap:6px;display:grid}.calendar-head{text-align:center;color:#6b7280;font-size:.74rem;font-weight:600}.dashboard-calendar{--calendar-lane-height:26px;--calendar-min-lanes:3}.dashboard-calendar .calendar-cell{min-height:calc(1.25rem + max(var(--event-lanes,0), var(--calendar-min-lanes)) * var(--calendar-lane-height) + .5rem)}.calendar-cell{min-height:52px;font-size:var(--workbench-font-sm);color:#374151;z-index:1;background:#fff;border:1px solid #e5e7eb;border-radius:8px;grid-row:1;padding:.35rem;position:relative}.calendar-day-num{z-index:2;line-height:1.25;position:relative}.calendar-cell.muted{color:#adb5bd;background:#f8fafc}.calendar-cell.past{color:#a0a8b3;background:#f8fafc;border-color:#edf1f5}.dashboard-calendar .calendar-cell.is-today{background:#b11e230b;border-color:#b11e236b}.dashboard-calendar .calendar-cell.is-today .calendar-day-num{color:var(--brand-primary);font-weight:600}.calendar-cell.is-today{background:#b11e230a;border-color:#b11e2373}.dashboard-calendar .calendar-cell.has-event{background:#fff}.calendar-cell.has-event{padding-bottom:.2rem}.calendar-event-link{appearance:none;width:100%;max-width:100%;color:var(--brand-primary);text-align:left;cursor:pointer;white-space:normal;word-break:break-word;overflow-wrap:anywhere;background:#b11e2314;border:0;border-radius:6px;margin-top:.3rem;padding:.18rem .36rem;font-size:12px;font-weight:500;line-height:1.35;display:block}.calendar-event-link.is-past-event{color:#6c757d;background:#e9ecef}.calendar-event-link.is-past-event:hover{color:#495057;text-underline-offset:2px;background:#dee2e6;text-decoration:underline}.calendar-event-link:hover{text-underline-offset:2px;background:#b11e2324;text-decoration:underline}.calendar-event-span{appearance:none;min-height:22px;color:var(--brand-primary);text-align:left;cursor:pointer;z-index:3;box-sizing:border-box;background:#b11e231f;border:0;border-radius:6px;grid-row:1;align-self:start;align-items:flex-start;margin:0;padding:.18rem .38rem;font-size:12px;font-weight:500;line-height:1.35;display:flex;overflow:hidden}.calendar-event-span.is-activity{color:#1d4ed8;background:#2563eb1a}.calendar-event-span.is-continuation{min-height:22px;padding-left:.28rem;padding-right:.28rem}.calendar-event-span.is-continuation:not(.is-past-event){background:#b11e231f}.calendar-event-span.is-continuation.is-activity:not(.is-past-event){background:#2563eb1f}.calendar-event-span-text{white-space:normal;word-break:break-word;overflow-wrap:anywhere;display:block}.calendar-event-span.is-past-event{color:#6c757d;background:#e9ecef}.calendar-event-span.is-past-event.is-activity{color:#64748b;background:#e2e8f0}.calendar-event-span:hover{filter:brightness(.97);text-underline-offset:2px;text-decoration:underline}.dashboard-grid-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:12px;display:grid}.dashboard-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px;box-shadow:0 5px 14px #0f172a09}.radar-top-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:.75rem;margin-bottom:.9rem;display:grid}.radar-kpi{background:linear-gradient(#fff 0%,#fbfcfe 100%);border:1px solid #e5e7eb;border-radius:8px;grid-template-columns:34px minmax(0,1fr) auto;align-items:center;gap:.65rem;min-height:76px;padding:.72rem;display:grid;box-shadow:0 5px 14px #0f172a09}.radar-kpi .kpi-icon{width:34px;height:34px;color:var(--brand-primary);background:#b11e2314;border-radius:8px;justify-content:center;align-items:center;font-size:16px;display:inline-flex}.radar-kpi span,.radar-kpi em{display:block}.radar-kpi span{color:#667085;font-size:var(--workbench-font-sm)}.radar-kpi em{color:#667085;font-size:var(--workbench-font-sm);margin-top:.12rem;font-style:normal}.radar-kpi strong{color:#1f2937;font-size:1.45rem;line-height:1}.radar-map-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;box-shadow:0 10px 24px #0f172a0e}.radar-map-toolbar{border-bottom:1px solid #edf1f5;justify-content:space-between;align-items:center;gap:.75rem;padding:.85rem 1rem;display:flex}.radar-map-toolbar h2{color:#1f2937;font-size:var(--workbench-font-h2);margin:0;font-weight:600}.radar-main{grid-template-columns:minmax(0,1.48fr) minmax(300px,.74fr);min-height:460px;display:grid}.radar-map-stage{background:#e8eef5;min-height:460px;position:relative}.radar-map-container{z-index:0;cursor:grab;background:#e8eef5;position:absolute;inset:0}.radar-map-container:active{cursor:grabbing}.radar-map-container .slake-map-school-marker{z-index:400;pointer-events:auto;cursor:pointer;background:0 0;border:0;align-items:center;gap:4px;margin:0;padding:0;line-height:1;display:inline-flex;position:absolute;transform:translate(-6px,-50%)}.radar-map-container .slake-map-school-marker.is-active{transform:translate(-7px,-50%)}.radar-map-container .slake-map-school-dot{box-sizing:border-box;background:#b11e23;border:2px solid #fff;border-radius:50%;flex-shrink:0;width:12px;height:12px;box-shadow:0 0 0 4px #b11e2329,0 6px 14px #0f172a24}.radar-map-container .slake-map-school-marker.is-active .slake-map-school-dot{background:#8a1418;width:13px;height:13px;box-shadow:0 0 0 6px #b11e232e,0 8px 18px #0f172a29}.radar-map-container .slake-map-school-label{color:#475569;white-space:nowrap;background:#fffffff0;border:1px solid #e2e8f0eb;border-radius:999px;padding:2px 6px;font-size:10.5px;font-weight:500;line-height:1.15;display:inline-block;box-shadow:0 5px 12px #0f172a12}.radar-map-container .slake-map-school-marker:hover .slake-map-school-label{color:#1f2937;border-color:#b11e2357}.radar-map-container .slake-map-school-marker.is-active .slake-map-school-label{color:#8a1418;border-color:#b11e238c;font-weight:600}.radar-map-placeholder{color:#667085;font-size:var(--workbench-font-sm);z-index:2;text-align:center;background:#f8fafceb;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:16px;display:flex;position:absolute;inset:0}.radar-side{background:#fff;border-left:1px solid #e5e7eb;flex-direction:column;min-width:0;display:flex}.radar-side-head{border-bottom:1px solid #edf1f5;justify-content:space-between;align-items:flex-start;gap:.75rem;padding:.92rem 1rem;display:flex}.radar-side-head h3{color:#1f2937;font-size:var(--workbench-font-base);margin:0;font-weight:600}.radar-side-count{color:var(--brand-primary);white-space:nowrap;font-size:var(--workbench-font-sm);background:#b11e2314;border-radius:999px;align-items:center;gap:.24rem;padding:.18rem .5rem;display:inline-flex}.radar-side-body{align-content:start;gap:.68rem;max-height:420px;padding:.85rem;display:grid;overflow-y:auto}.radar-empty-panel{color:#667085;text-align:center;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:8px;justify-items:center;gap:.35rem;min-height:132px;padding:1.1rem .9rem;display:grid}.radar-empty-panel strong{color:#1f2937;font-size:var(--workbench-font-base)}.radar-empty-panel span{max-width:230px;font-size:var(--workbench-font-sm);line-height:1.5}.radar-view-summary{font-size:var(--workbench-font-sm);background:#fff;border:1px solid #e5e7eb;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;gap:.5rem .75rem;padding:.72rem .82rem;display:grid}.radar-view-summary span{color:#667085}.radar-view-summary strong{color:#1f2937;text-align:right}.radar-teacher-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;grid-template-columns:34px minmax(0,1fr) auto;align-items:center;gap:.62rem;padding:.72rem;display:grid}.radar-teacher-avatar{width:34px;height:34px;color:var(--brand-primary);background:#b11e2314;border-radius:50%;justify-content:center;align-items:center;display:inline-flex}.radar-teacher-name{color:#1f2937;font-size:var(--workbench-font-base);text-align:left;cursor:pointer;background:0 0;border:0;padding:0;line-height:1.25;display:block}.radar-teacher-name:hover{color:var(--brand-primary);text-decoration:underline}.radar-teacher-card em{color:#667085;font-size:var(--workbench-font-sm);font-style:normal;display:block}.radar-teacher-card i.stars{color:#f0a800;font-size:var(--workbench-font-sm);margin-top:.12rem;font-style:normal;display:block}.radar-bottom-grid{grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);gap:.9rem;margin-top:.9rem;display:grid}.radar-info-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:.9rem;box-shadow:0 8px 20px #0f172a0b}.radar-info-card h2{color:#1f2937;font-size:var(--workbench-font-h2);margin:0 0 .75rem;padding-left:.62rem;font-weight:600;position:relative}.radar-info-card h2:before{content:"";background:#b11e23bf;border-radius:999px;width:3px;height:.72em;position:absolute;top:.36em;left:0}.radar-map-toolbar h2{padding-left:.62rem;position:relative}.radar-map-toolbar h2:before{content:"";background:#b11e23bf;border-radius:999px;width:3px;height:.72em;position:absolute;top:.36em;left:0}.radar-school-row,.radar-field-row{font-size:var(--workbench-font-sm);border-top:1px solid #f0f2f5;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:.75rem;padding-top:.56rem;display:grid}.radar-school-row:first-child,.radar-field-row:first-child{border-top:0;padding-top:0}.radar-school-row span,.radar-field-row span{color:#1f2937}.radar-school-row em,.radar-field-row em{color:#667085;font-size:var(--workbench-font-sm);font-style:normal;display:block}.radar-field-bar{background:#eef2f7;border-radius:999px;height:7px;margin-top:.3rem;overflow:hidden}.radar-field-bar i{border-radius:inherit;background:linear-gradient(90deg,#b11e23,#d65a5f);height:100%;display:block}@media (width<=991px){.dashboard-grid-row,.radar-top-grid,.radar-bottom-grid,.radar-main,.dashboard-event-list{grid-template-columns:1fr}.radar-side{border-top:1px solid #e5e7eb;border-left:0}}@media (width<=767px){.executive-metric-grid{grid-template-columns:1fr}}