/* ============================================================
   Desktop frame - browser window chrome (.winbar + URL pill),
   left sidebar (~236px), scrolling .main. macOS-like web app.
   Desktop darkens a few tokens for crisp text on white.
   ============================================================ */
.page-desktop{
  --label2:#6e6e73;--label3:#aeaeb2;--sep:#e3e3e6;--fill:#ececed;--fill2:#e0e0e2;
}
.win{width:1240px;height:830px;background:var(--bg);border-radius:12px;overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.32),0 0 0 .5px rgba(0,0,0,.12);display:flex;flex-direction:column;
  flex:none}

/* window title bar */
.winbar{height:44px;flex:none;display:flex;align-items:center;gap:8px;padding:0 16px;
  background:#f6f6f7;border-bottom:.5px solid var(--sep);position:relative}
.winbar .dots{display:flex;gap:8px}
.winbar .dots i{width:12px;height:12px;border-radius:50%;display:block}
.winbar .dots i:nth-child(1){background:#ff5f57}
.winbar .dots i:nth-child(2){background:#febc2e}
.winbar .dots i:nth-child(3){background:#28c840}
.winbar .urlpill{position:absolute;left:50%;transform:translateX(-50%);min-width:300px;max-width:60%;
  height:28px;background:var(--bg);border:.5px solid var(--sep);border-radius:8px;display:flex;
  align-items:center;justify-content:center;gap:7px;font-size:13px;color:var(--label2)}
.winbar .urlpill svg{width:13px;height:13px;color:var(--tint)}

/* app body */
.deskbody{flex:1;display:flex;min-height:0}
.sidebar{width:240px;flex:none;background:#f6f6f7;border-right:.5px solid var(--sep);
  display:flex;flex-direction:column;padding:14px 12px}
.sidebar .brandrow{display:flex;align-items:center;gap:10px;padding:4px 8px 18px}
.sidebar .brandrow img{height:26px;width:auto}
.sidebar .brandrow .role{font-size:12px;color:var(--label2);margin-top:1px}
.sidenav{display:flex;flex-direction:column;gap:2px}
.sidenav .sect{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;
  color:var(--label3);padding:14px 10px 5px}
.sidenav a{display:flex;align-items:center;gap:11px;min-height:38px;padding:0 10px;border-radius:8px;
  font-size:14px;font-weight:500;color:var(--label)}
.sidenav a svg{width:19px;height:19px;color:var(--label2)}
.sidenav a:hover{background:var(--fill)}
.sidenav a.on{background:var(--tint);color:#fff}
.sidenav a.on svg{color:#fff}
.sidenav a .tcount{margin-left:auto;background:var(--red);color:#fff;font-size:11px;font-weight:700;
  min-width:18px;height:18px;border-radius:9px;display:grid;place-items:center;padding:0 5px;
  font-variant-numeric:tabular-nums}
.sidenav a.on .tcount{background:rgba(255,255,255,.25)}
.sidebar .userchip{margin-top:auto;display:flex;align-items:center;gap:10px;padding:10px 8px 4px;
  border-top:.5px solid var(--sep)}
.sidebar .userchip b{font-size:13px;font-weight:600;display:block}
.sidebar .userchip small{font-size:12px;color:var(--label2)}

/* main content */
.main{flex:1;min-width:0;background:var(--bg);display:flex;flex-direction:column;overflow:hidden}
.main > .screen-view{overflow:hidden;display:flex;flex-direction:column;flex:1;min-height:0}
.mainhead{flex:none;padding:22px 28px 0;border-bottom:.5px solid var(--sep)}
.mainhead .htop{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.mainhead h1{font-size:26px;font-weight:700;letter-spacing:-.02em}
.mainhead .hsub{color:var(--label2);font-size:14px;margin-top:3px}
.mainhead .htabs{display:flex;gap:22px;margin-top:18px}
.mainhead .htabs button{padding:0 1px 12px;font-size:14px;font-weight:500;color:var(--label2);
  border-bottom:2px solid transparent;margin-bottom:-1px}
.mainhead .htabs button.on{color:var(--label);border-color:var(--tint);font-weight:600}
.mainscroll{flex:1;overflow-y:auto;padding:24px 28px 40px}
.mainscroll.narrow{max-width:900px}

/* KPI header tiles */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.kpi{background:var(--bg);border:.5px solid var(--sep);border-radius:14px;padding:16px 18px}
.kpi .k{font-size:13px;color:var(--label2);display:flex;align-items:center;gap:7px}
.kpi .k svg{width:16px;height:16px;color:var(--label2)}
.kpi .n{font-size:32px;font-weight:700;letter-spacing:-.03em;margin-top:8px;font-variant-numeric:tabular-nums}
.kpi.alert .n{color:var(--red)}
.kpi.tint .n{color:var(--tint)}
.kpi .d{font-size:12px;color:var(--label2);margin-top:2px}

/* section blocks in console */
.block{margin-bottom:26px}
.block > h2{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;
  color:var(--label2);margin-bottom:11px}
.cardgrid{display:grid;gap:14px}
.cardgrid.two{grid-template-columns:1fr 1fr}

/* enrollment request cards (the office hero) */
.reqcard{background:var(--bg);border:.5px solid var(--sep);border-radius:14px;padding:16px 18px;
  display:flex;gap:14px;align-items:flex-start}
.reqcard.fresh{border-color:var(--tint-bd);box-shadow:0 0 0 3px var(--tint-l)}
.reqcard .meta{flex:1;min-width:0}
.reqcard .nm{font-size:16px;font-weight:600;display:flex;align-items:center;gap:8px}
.reqcard .sub{color:var(--label2);font-size:13px;margin-top:3px}
.reqcard .tags{display:flex;gap:7px;margin-top:11px;flex-wrap:wrap}
.reqcard .note{margin-top:10px;font-size:13px;color:var(--label2);font-style:italic}
.reqcard .acts{display:flex;flex-direction:column;gap:8px;flex:none;width:130px}
.emptybox{text-align:center;padding:48px 20px;color:var(--label2)}
.emptybox svg{width:40px;height:40px;margin:0 auto 12px;color:var(--label3)}

/* modal form rows */
.mrow{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.mrow label{font-size:13px;color:var(--label2);font-weight:500}
.codechip{font-family:var(--mono);font-size:18px;font-weight:600;letter-spacing:.06em;
  background:var(--tint-l);color:var(--tint-d);border-radius:10px;padding:12px 14px;text-align:center}

/* content rows in console lists */
.consolerow{display:flex;align-items:center;gap:13px;padding:13px 16px;border-bottom:.5px solid var(--sep)}
.consolerow:last-child{border-bottom:0}
.consolerow .grow{flex:1;min-width:0}
.consolerow .grow b{font-size:15px;font-weight:600;display:block}
.consolerow .grow small{font-size:13px;color:var(--label2)}

/* desktop sizing for the student/teacher app (sidebar app, narrower content) */
.page-desktop .video{max-width:none}
.page-desktop .cap{max-width:1240px}
.page-desktop .stage{padding-top:30px}
