  :root{
    --ink:#16282E;
    --teal:#0F6E6E;
    --teal-dk:#0A5252;
    --amber:#E08A2B;
    --bg:#EEF3F2;
    --surface:#FFFFFF;
    --muted:#67797F;
    --line:#D9E2E0;
    --soft:#F4F8F7;
    --ok:#1F8A5B;
    --absent:#C0492F;
    --pending:#B08415;
    --shadow:0 1px 2px rgba(20,40,46,.06),0 8px 24px rgba(20,40,46,.06);
    --disp:"Zen Kaku Gothic New",system-ui,"Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,sans-serif;
    --body:"Noto Sans JP",system-ui,"Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,sans-serif;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html,body{height:100%}
  body{font-family:var(--body);color:var(--ink);background:var(--bg);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased}
  button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
  h1,h2,h3,h4{font-family:var(--disp);font-weight:700;line-height:1.3}
  a{color:var(--teal);text-decoration:none}

  /* ---------- LOGIN ---------- */
  #login{position:fixed;inset:0;display:flex;z-index:50}
  .login-art{flex:1;background:linear-gradient(155deg,var(--teal-dk),var(--teal) 55%,#138a7e);color:#fff;padding:64px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
  .login-art .ring{position:absolute;border:1.5px solid rgba(255,255,255,.14);border-radius:50%}
  .r1{width:520px;height:520px;right:-180px;top:-120px}
  .r2{width:340px;height:340px;right:40px;bottom:-130px}
  .badge{font-family:var(--disp);font-weight:900;letter-spacing:.04em;font-size:15px;display:inline-flex;align-items:center;gap:10px;position:relative;z-index:1}
  .badge .dot{width:26px;height:26px;border-radius:8px;background:var(--amber);display:grid;place-items:center;color:#16282E;font-size:14px}
  .login-art h1{font-size:40px;font-weight:900;line-height:1.25;letter-spacing:-.01em;position:relative;z-index:1}
  .login-art p{opacity:.86;max-width:30ch;position:relative;z-index:1;margin-top:18px}
  .art-list{position:relative;z-index:1;display:flex;flex-direction:column;gap:14px}
  .art-list div{display:flex;gap:12px;align-items:center;font-weight:500}
  .art-list span.ic{width:30px;height:30px;border-radius:9px;background:rgba(255,255,255,.13);display:grid;place-items:center;flex:none}
  .login-form{width:440px;background:var(--surface);padding:64px 52px;display:flex;flex-direction:column;justify-content:center}
  .login-form h2{font-size:24px;margin-bottom:6px}
  .login-form .sub{color:var(--muted);margin-bottom:32px;font-size:13px}
  .fld{margin-bottom:18px}
  .fld label{display:block;font-size:12px;font-weight:700;color:var(--ink);margin-bottom:7px}
  .fld input{width:100%;padding:13px 14px;border:1.5px solid var(--line);border-radius:11px;font-family:inherit;font-size:14px;background:var(--soft)}
  .fld input:focus{outline:none;border-color:var(--teal);background:#fff}
  .btn-primary{width:100%;background:var(--teal);color:#fff;padding:14px;border-radius:11px;font-weight:700;font-size:15px;font-family:var(--disp);transition:background .15s}
  .btn-primary:hover{background:var(--teal-dk)}
  .nogoogle{margin-top:22px;padding:13px 14px;background:var(--soft);border:1px dashed var(--line);border-radius:11px;font-size:12px;color:var(--muted);display:flex;gap:10px;align-items:flex-start}
  .nogoogle b{color:var(--ink)}
  .admin-entry{margin-top:26px;padding-top:20px;border-top:1px solid var(--line);font-size:12.5px;color:var(--muted)}
  .admin-entry button{color:var(--teal);font-weight:700;font-family:var(--disp);font-size:12.5px}
  .admin-entry button:hover{text-decoration:underline}
  .door-tag{display:inline-block;font-size:11px;font-weight:700;font-family:var(--disp);padding:4px 11px;border-radius:20px;margin-bottom:16px}
  .door-s{background:var(--soft);color:var(--teal)}
  .door-a{background:#212f36;color:#e9c79a}
  .btn-admin{width:100%;background:var(--ink);color:#fff;padding:14px;border-radius:11px;font-weight:700;font-size:15px;font-family:var(--disp);transition:background .15s}
  .btn-admin:hover{background:#0c1a20}
  .admin-note{margin-top:22px;padding:13px 14px;background:#f3f6f5;border:1px solid var(--line);border-radius:11px;font-size:12px;color:var(--muted);border-left:3px solid var(--ink)}
  .admin-note b{color:var(--ink)}
  .door-c{background:#fbf0dd;color:#a86a18}
  .btn-company{width:100%;background:var(--amber);color:#16282E;padding:14px;border-radius:11px;font-weight:700;font-size:15px;font-family:var(--disp);transition:filter .15s}
  .btn-company:hover{filter:brightness(.95)}
  .company-note{margin-top:22px;padding:13px 14px;background:#fdf6ea;border:1px solid #f0e3cb;border-radius:11px;font-size:12px;color:#8a6a2e;border-left:3px solid var(--amber)}
  .syl{display:flex;flex-direction:column;gap:10px}
  .syl-row{display:flex;gap:16px;padding:16px 18px;background:var(--surface);border:1px solid var(--line);border-radius:14px}
  .syl-body{flex:1}
  .syl-body .t{font-weight:700;font-family:var(--disp);font-size:14px}
  .syl-obj{display:flex;flex-wrap:wrap;gap:6px;margin-top:9px}
  .syl-tag{font-size:11.5px;background:var(--soft);color:var(--ink);border:1px solid var(--line);padding:3px 9px;border-radius:7px}
  .role-pick{display:flex;gap:8px;margin-bottom:26px}
  .role-pick button{flex:1;padding:10px;border:1.5px solid var(--line);border-radius:10px;font-weight:700;font-size:13px;font-family:var(--disp);color:var(--muted);transition:.15s}
  .role-pick button.on{border-color:var(--teal);background:var(--soft);color:var(--teal)}

  /* ---------- APP SHELL ---------- */
  #app{display:none;min-height:100vh}
  #app.show{display:grid;grid-template-columns:248px 1fr}
  .sidebar{background:var(--ink);color:#cfe0de;min-height:100vh;padding:22px 16px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column}
  .sb-badge{font-family:var(--disp);font-weight:900;color:#fff;font-size:15px;display:flex;align-items:center;gap:10px;padding:0 8px 18px}
  .sb-badge .dot{width:26px;height:26px;border-radius:8px;background:var(--amber);display:grid;place-items:center;color:#16282E;font-size:14px;flex:none}
  .sb-section{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:#6f8b89;padding:16px 12px 8px;font-weight:700}
  .nav-item{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:10px;color:#cfe0de;font-weight:500;font-size:13.5px;transition:.12s;width:100%;text-align:left}
  .nav-item .ic{width:20px;text-align:center;flex:none;opacity:.85}
  .nav-item:hover{background:rgba(255,255,255,.06)}
  .nav-item.on{background:var(--teal);color:#fff}
  .nav-item .tag{margin-left:auto;background:var(--amber);color:#16282E;font-size:10px;font-weight:700;padding:1px 7px;border-radius:20px}
  .sb-foot{margin-top:auto;padding:14px 10px 4px;border-top:1px solid rgba(255,255,255,.08)}
  .sb-foot .who{font-size:12px;color:#9fb6b3}
  .sb-foot .nm{font-weight:700;color:#fff;font-family:var(--disp);font-size:13.5px}

  .main{min-height:100vh;display:flex;flex-direction:column}
  .topbar{background:var(--surface);border-bottom:1px solid var(--line);padding:14px 32px;display:flex;align-items:center;gap:16px;position:sticky;top:0;z-index:10}
  .topbar h2{font-size:17px}
  .crumb{color:var(--muted);font-size:12px}
  .demo-switch{margin-left:auto;display:flex;align-items:center;gap:9px}
  .demo-lab{font-size:10px;font-weight:700;letter-spacing:.08em;color:var(--muted);background:var(--bg);padding:3px 7px;border-radius:6px;font-family:var(--disp)}
  .logout{margin-left:auto;border:1.5px solid var(--line);border-radius:9px;padding:8px 14px;font-weight:700;font-size:12px;font-family:var(--disp);color:var(--muted)}
  .logout:hover{border-color:var(--absent);color:var(--absent)}
  .imp-banner{background:var(--ink);color:#fff;padding:10px 32px;font-size:13px;display:flex;align-items:center;gap:8px}
  .imp-banner span{font-family:var(--disp);font-weight:700;color:#e9c79a}
  .imp-banner b{font-family:var(--disp)}
  .imp-banner button{margin-left:auto;background:rgba(255,255,255,.14);color:#fff;font-weight:700;font-size:12px;font-family:var(--disp);padding:6px 13px;border-radius:8px}
  .imp-banner button:hover{background:rgba(255,255,255,.24)}
  .role-switch{display:flex;background:var(--bg);border-radius:10px;padding:3px}
  .role-switch button{padding:7px 14px;border-radius:8px;font-weight:700;font-size:12px;font-family:var(--disp);color:var(--muted)}
  .role-switch button.on{background:#fff;color:var(--teal);box-shadow:var(--shadow)}
  .avatar{width:36px;height:36px;border-radius:50%;background:var(--teal);color:#fff;display:grid;place-items:center;font-family:var(--disp);font-weight:700;font-size:14px}

  .content{padding:30px 32px;max-width:1080px;width:100%}
  .page{display:none}
  .page.show{display:block;animation:fade .25s ease}
  @keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

  .phead{margin-bottom:22px}
  .phead h1{font-size:24px;font-weight:900;letter-spacing:-.01em}
  .phead p{color:var(--muted);margin-top:4px}

  .card{background:var(--surface);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow)}
  .grid{display:grid;gap:16px}
  .g3{grid-template-columns:repeat(3,1fr)}
  .g2{grid-template-columns:1.6fr 1fr}

  /* profile strip */
  .profile{display:flex;gap:18px;align-items:center;padding:20px 22px;margin-bottom:18px}
  .profile .pa{width:58px;height:58px;border-radius:16px;background:linear-gradient(150deg,var(--teal),var(--teal-dk));color:#fff;display:grid;place-items:center;font-family:var(--disp);font-weight:900;font-size:22px;flex:none}
  .profile .nm{font-family:var(--disp);font-weight:700;font-size:18px}
  .profile .meta{color:var(--muted);font-size:13px;margin-top:2px}
  .profile .meta b{color:var(--ink);font-weight:500}
  .profile .edit{margin-left:auto;border:1.5px solid var(--line);border-radius:10px;padding:9px 14px;font-weight:700;font-size:12px;font-family:var(--disp);color:var(--ink)}
  .profile .edit:hover{border-color:var(--teal);color:var(--teal)}
  .wsacct{padding:20px 22px;margin-bottom:18px}
  .ws-head{font-family:var(--disp);font-weight:700;font-size:14px;display:flex;align-items:center;gap:9px;margin-bottom:16px}
  .ws-g{width:24px;height:24px;border-radius:7px;background:linear-gradient(150deg,var(--teal),var(--teal-dk));color:#fff;display:grid;place-items:center;font-weight:900;font-size:13px}
  .ws-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 24px}
  .ws-k{font-size:11px;color:var(--muted);font-weight:700;margin-bottom:3px}
  .ws-v{font-size:13.5px;font-weight:500;font-family:var(--disp);word-break:break-all}
  .ws-reveal{font-size:11px;font-weight:700;color:var(--teal);border:1px solid var(--line);border-radius:6px;padding:2px 8px;margin-left:6px;font-family:var(--disp)}
  .ws-reveal:hover{background:var(--soft)}
  .ws-link{margin-top:18px;display:inline-flex;background:var(--soft);color:var(--teal);border:1.5px solid var(--line);padding:10px 16px;border-radius:10px;font-weight:700;font-size:13px;font-family:var(--disp)}
  .ws-link:hover{border-color:var(--teal)}
  .pf-fld{margin-top:16px}
  .pf-fld label{display:block;font-size:12px;font-weight:700;margin-bottom:7px}
  .pf-fld input{width:100%;padding:13px 14px;border:1.5px solid var(--line);border-radius:11px;font-family:inherit;background:var(--soft);font-size:14px}
  .pf-fld input:focus{outline:none;border-color:var(--teal);background:#fff}
  .pf-fld input:disabled{color:var(--muted);cursor:not-allowed;background:#eef2f1}
  .pf-note{font-size:11.5px;color:var(--muted);margin-top:7px;line-height:1.5}

  .stat{padding:18px 20px}
  .stat .lab{font-size:12px;color:var(--muted);font-weight:700}
  .stat .big{font-family:var(--disp);font-weight:900;font-size:32px;margin-top:4px;line-height:1}
  .stat .bar{height:7px;border-radius:20px;background:var(--bg);margin-top:14px;overflow:hidden}
  .stat .bar span{display:block;height:100%;background:var(--teal);border-radius:20px}
  .stat .note{font-size:11.5px;color:var(--muted);margin-top:8px}

  /* session list */
  .sec-h{display:flex;align-items:center;margin:26px 0 12px}
  .sec-h h3{font-size:15px;font-weight:700}
  .sec-h .more{margin-left:auto;font-size:12px;font-weight:700;color:var(--teal)}
  .slist{display:flex;flex-direction:column;gap:10px}
  .srow{display:flex;align-items:center;gap:16px;padding:14px 18px;background:var(--surface);border:1px solid var(--line);border-radius:14px;cursor:pointer;transition:.12s}
  .srow:hover{border-color:var(--teal);box-shadow:var(--shadow)}
  .srow.sel{border-color:var(--teal);background:var(--soft)}
  .snum{width:42px;height:42px;border-radius:12px;background:var(--soft);color:var(--teal);font-family:var(--disp);font-weight:900;display:grid;place-items:center;flex:none;border:1px solid var(--line)}
  .srow.done .snum{background:var(--teal);color:#fff;border-color:var(--teal)}
  .sinfo{flex:1;min-width:0}
  .sinfo .t{font-weight:700;font-family:var(--disp);font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .sinfo .d{font-size:12px;color:var(--muted)}
  .mats{display:flex;gap:6px;flex:none}
  .mtag{font-size:10.5px;font-weight:700;padding:3px 8px;border-radius:7px;display:inline-flex;gap:4px;align-items:center}
  .m-pdf{background:#fdeceb;color:#c0492f}
  .m-yt{background:#fdeaea;color:#cc3333}
  .m-vid{background:#eef1fb;color:#3a55b5}
  .m-ws{background:#e7f3ee;color:#1f8a5b}
  .pill{font-size:11px;font-weight:700;padding:4px 11px;border-radius:20px;flex:none;font-family:var(--disp)}
  .p-ok{background:#e7f3ee;color:var(--ok)}
  .p-absent{background:#fbeae6;color:var(--absent)}
  .p-pending{background:#fbf3e0;color:var(--pending)}
  .p-up{background:var(--soft);color:var(--muted)}

  /* detail drawer */
  .detail{padding:24px;margin-top:16px}
  .detail .dh{display:flex;align-items:flex-start;gap:14px;margin-bottom:18px}
  .detail .dh .snum{width:48px;height:48px}
  .detail h3{font-size:18px}
  .detail .dh .d{color:var(--muted);font-size:13px;margin-top:3px}
  .reslist{display:flex;flex-direction:column;gap:9px}
  .resrow{display:flex;align-items:center;gap:13px;padding:13px 15px;border:1px solid var(--line);border-radius:12px;transition:.12s}
  .resrow:hover{border-color:var(--teal);background:var(--soft)}
  .resrow .ric{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;flex:none;font-size:16px}
  .ric.pdf{background:#fdeceb;color:#c0492f}
  .ric.yt{background:#fdeaea;color:#cc3333}
  .ric.vid{background:#eef1fb;color:#3a55b5}
  .ric.ws{background:#e7f3ee;color:#1f8a5b}
  .resrow .rt{font-weight:700;font-size:13px;font-family:var(--disp)}
  .resrow .rd{font-size:11.5px;color:var(--muted)}
  .resrow .go{margin-left:auto;color:var(--teal);font-weight:700;font-size:12px}
  .subh{font-family:var(--disp);font-weight:700;font-size:13px;margin:20px 0 10px;color:var(--ink)}

  textarea{width:100%;border:1.5px solid var(--line);border-radius:12px;padding:13px;font-family:inherit;font-size:13.5px;resize:vertical;min-height:90px;background:var(--soft)}
  textarea:focus{outline:none;border-color:var(--teal);background:#fff}
  .essay-foot{display:flex;align-items:center;margin-top:12px;gap:12px}
  .essay-foot .cnt{font-size:12px;color:var(--muted)}
  .btn-sm{background:var(--teal);color:#fff;padding:10px 18px;border-radius:10px;font-weight:700;font-size:13px;font-family:var(--disp)}
  .btn-sm:hover{background:var(--teal-dk)}
  .btn-ghost{border:1.5px solid var(--line);color:var(--ink);padding:9px 16px;border-radius:10px;font-weight:700;font-size:12.5px;font-family:var(--disp)}

  /* video archive */
  .vgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
  .vcard{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--surface);cursor:pointer;transition:.12s}
  .vcard:hover{border-color:var(--teal);box-shadow:var(--shadow)}
  .vthumb{aspect-ratio:16/9;background:linear-gradient(135deg,#21424a,#0F6E6E);position:relative;display:grid;place-items:center}
  .vthumb .play{width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.92);display:grid;place-items:center;color:var(--teal);font-size:15px}
  .vthumb .dur{position:absolute;right:8px;bottom:8px;background:rgba(0,0,0,.6);color:#fff;font-size:10.5px;font-weight:700;padding:2px 7px;border-radius:6px}
  .vcard .vb{padding:12px 14px}
  .vcard .vt{font-weight:700;font-family:var(--disp);font-size:13px;line-height:1.4}
  .vcard .vm{font-size:11.5px;color:var(--muted);margin-top:4px}

  /* ---- instructor ---- */
  .tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:20px}
  .tab{padding:11px 16px;font-weight:700;font-size:13px;font-family:var(--disp);color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px}
  .tab.on{color:var(--teal);border-color:var(--teal)}
  .tabpane{display:none}
  .tabpane.show{display:block}
  table{width:100%;border-collapse:collapse;font-size:13px}
  th{text-align:left;font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);font-weight:700;padding:11px 14px;border-bottom:1px solid var(--line)}
  td{padding:13px 14px;border-bottom:1px solid var(--line)}
  tr:last-child td{border-bottom:none}
  tbody tr:hover{background:var(--soft)}
  .uname{display:flex;align-items:center;gap:11px}
  .uname .ua{width:34px;height:34px;border-radius:50%;background:var(--soft);color:var(--teal);display:grid;place-items:center;font-family:var(--disp);font-weight:700;font-size:13px;border:1px solid var(--line)}
  .uname .un{font-weight:700;font-family:var(--disp)}
  .uname .uc{font-size:11.5px;color:var(--muted)}
  .rate{font-family:var(--disp);font-weight:900}
  .view-as{border:1.5px solid var(--line);border-radius:9px;padding:7px 12px;font-weight:700;font-size:12px;font-family:var(--disp);color:var(--teal);white-space:nowrap}
  .view-as:hover{border-color:var(--teal);background:var(--soft)}
  /* permission badges */
  .perm{font-size:11px;font-weight:700;padding:3px 10px;border-radius:7px;font-family:var(--disp);white-space:nowrap;display:inline-block}
  .perm-rep{background:#fdecef;color:#b3325a}
  .perm-mgr{background:#fbf0dd;color:#a86a18}
  .perm-mem{background:var(--soft);color:var(--teal)}
  /* settings sections */
  .setsec{margin-bottom:24px}
  .setsec .sh{font-family:var(--disp);font-weight:700;font-size:15px;margin-bottom:14px;display:flex;align-items:center;gap:9px}
  .setsec .sh .n{width:24px;height:24px;border-radius:7px;background:var(--ink);color:#fff;display:grid;place-items:center;font-size:12px;flex:none}
  .fgrid{display:grid;grid-template-columns:1fr 1fr;gap:15px 18px}
  .fgrid .full{grid-column:1/-1}
  .cred{display:flex;align-items:center;gap:7px}
  .cred .pw{letter-spacing:1px;color:var(--muted)}
  .mono{font-family:ui-monospace,Menlo,monospace;font-size:12px}
  .mini-reveal{font-size:10.5px;font-weight:700;color:var(--teal);border:1px solid var(--line);border-radius:6px;padding:1px 7px;font-family:var(--disp)}
  .mini-reveal:hover{background:var(--soft)}
  .addrow{margin-top:12px;border:1.5px dashed var(--line);border-radius:11px;padding:13px;text-align:center;color:var(--teal);font-weight:700;font-size:13px;font-family:var(--disp)}
  .addrow:hover{background:var(--soft)}
  /* client list */
  .client-row{display:flex;align-items:center;gap:16px;padding:16px 18px;border:1px solid var(--line);border-radius:14px;background:var(--surface);cursor:pointer;transition:.12s;margin-bottom:10px;box-shadow:var(--shadow)}
  .client-row:hover{border-color:var(--teal)}
  .clogo{width:46px;height:46px;border-radius:12px;background:linear-gradient(150deg,var(--teal),var(--teal-dk));color:#fff;display:grid;place-items:center;font-family:var(--disp);font-weight:900;font-size:18px;flex:none}
  .client-row .ci{flex:1;min-width:0}
  .client-row .cn{font-family:var(--disp);font-weight:700;font-size:15px}
  .client-row .cm{font-size:12px;color:var(--muted);margin-top:3px}
  .cstat{font-size:11px;font-weight:700;padding:4px 11px;border-radius:20px;font-family:var(--disp);flex:none}
  .back-link{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;font-weight:700;color:var(--teal);font-family:var(--disp);margin-bottom:14px}
  /* toolbar: search + csv */
  .toolbar{display:flex;gap:10px;align-items:center;margin-bottom:16px;flex-wrap:wrap}
  .search{flex:1;min-width:220px;display:flex;align-items:center;gap:8px;background:var(--surface);border:1.5px solid var(--line);border-radius:11px;padding:0 12px}
  .search:focus-within{border-color:var(--teal)}
  .search input{flex:1;border:none;background:none;padding:11px 0;font-family:inherit;font-size:13.5px;outline:none;color:var(--ink)}
  .search .si{color:var(--muted)}
  .btn-csv{display:inline-flex;align-items:center;gap:7px;border:1.5px solid var(--line);border-radius:10px;padding:10px 14px;font-weight:700;font-size:12.5px;font-family:var(--disp);color:var(--ink);white-space:nowrap}
  .btn-csv:hover{border-color:var(--teal);color:var(--teal)}
  /* attachments */
  .attach-list{display:flex;flex-direction:column;gap:9px}
  .attach-row{display:flex;align-items:center;gap:13px;padding:12px 14px;border:1px solid var(--line);border-radius:12px}
  .attach-row .aic{width:36px;height:36px;border-radius:9px;background:#fdeceb;color:#c0492f;display:grid;place-items:center;flex:none;font-size:15px}
  .attach-row .aic.empty{background:var(--bg);color:var(--muted)}
  .akind{font-size:11px;color:var(--muted);font-weight:700}
  .afile{font-family:var(--disp);font-weight:700;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:360px}
  .afile.aempty{color:var(--muted);font-weight:500}
  .aact{margin-left:auto;display:flex;gap:7px;flex:none;align-items:center}
  .abtn{border:1.5px solid var(--line);border-radius:8px;padding:6px 11px;font-weight:700;font-size:11.5px;font-family:var(--disp);color:var(--teal)}
  .abtn:hover{background:var(--soft)}

  /* attendance grid */
  .att-scroll{overflow-x:auto}
  .att-grid{border-collapse:separate;border-spacing:0;min-width:760px}
  .att-grid th,.att-grid td{padding:9px 6px;text-align:center;border-bottom:1px solid var(--line)}
  .att-grid th.stick,.att-grid td.stick{text-align:left;position:sticky;left:0;background:var(--surface);min-width:150px;z-index:1}
  .att-grid tbody tr:hover td.stick{background:var(--soft)}
  .acell{width:26px;height:26px;border-radius:8px;display:inline-grid;place-items:center;font-size:11px;font-weight:700;cursor:pointer;font-family:var(--disp)}
  .a-1{background:#e7f3ee;color:var(--ok)}
  .a-0{background:#fbeae6;color:var(--absent)}
  .a-n{background:var(--bg);color:var(--muted)}

  .ecard{border:1px solid var(--line);border-radius:14px;padding:16px 18px;margin-bottom:12px}
  .ecard .eh{display:flex;align-items:center;gap:11px;margin-bottom:9px}
  .ecard .eh .ua{width:32px;height:32px;border-radius:50%;background:var(--soft);color:var(--teal);display:grid;place-items:center;font-family:var(--disp);font-weight:700;font-size:12px;border:1px solid var(--line)}
  .ecard .eh .un{font-weight:700;font-family:var(--disp);font-size:13px}
  .ecard .eh .ed{font-size:11.5px;color:var(--muted)}
  .ecard .eh .stag{margin-left:auto;font-size:10.5px;font-weight:700;color:var(--teal);background:var(--soft);padding:3px 9px;border-radius:7px}
  .ecard .etxt{font-size:13px;color:#324349}

  .up-zone{border:1.5px dashed var(--line);border-radius:14px;padding:26px;text-align:center;color:var(--muted);background:var(--soft);margin-bottom:16px}
  .up-zone .ico{font-size:26px;margin-bottom:6px}
  .up-zone b{color:var(--ink);font-family:var(--disp)}

  .toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;padding:13px 22px;border-radius:12px;font-weight:700;font-size:13px;font-family:var(--disp);opacity:0;transition:.3s;z-index:80;box-shadow:0 10px 30px rgba(0,0,0,.25)}
  .toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

  /* course context bar */
  .course-bar{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:12px 16px;margin-bottom:20px;box-shadow:var(--shadow);position:relative}
  .course-bar .cb-ic{width:38px;height:38px;border-radius:11px;background:linear-gradient(150deg,var(--teal),var(--teal-dk));color:#fff;display:grid;place-items:center;font-family:var(--disp);font-weight:900;flex:none}
  .course-bar .cb-lab{font-size:11px;color:var(--muted);font-weight:700}
  .course-bar .cb-t{font-family:var(--disp);font-weight:700;font-size:14px}
  .course-bar .cb-act{margin-left:auto;border:1.5px solid var(--line);border-radius:9px;padding:8px 13px;font-weight:700;font-size:12px;font-family:var(--disp);color:var(--teal)}
  .course-bar .cb-act:hover{border-color:var(--teal);background:var(--soft)}
  .course-menu{position:absolute;top:100%;right:16px;margin-top:6px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 30px rgba(20,40,46,.14);padding:6px;min-width:280px;z-index:20;display:none}
  .course-menu.show{display:block}
  .course-menu .cm-h{font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:700;padding:8px 12px 4px}
  .cm-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:9px;cursor:pointer;width:100%;text-align:left}
  .cm-item:hover{background:var(--soft)}
  .cm-item.on{background:var(--soft)}
  .cm-item .cm-t{font-family:var(--disp);font-weight:700;font-size:13px}
  .cm-item .cm-d{font-size:11px;color:var(--muted)}
  .cm-item .cm-chk{margin-left:auto;color:var(--teal);font-weight:900}

  /* editor avatar stack */
  .editors{display:flex;align-items:center}
  .editors .ea{width:26px;height:26px;border-radius:50%;background:var(--soft);border:2px solid #fff;color:var(--teal);display:grid;place-items:center;font-family:var(--disp);font-weight:700;font-size:11px;margin-left:-7px}
  .editors .ea:first-child{margin-left:0}

  /* course cards */
  .ccards{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
  .ccard{border:1px solid var(--line);border-radius:16px;background:var(--surface);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column}
  .ccard .cc-top{padding:18px 20px;border-bottom:1px solid var(--line)}
  .cc-term{font-size:11px;font-weight:700;color:var(--teal);background:var(--soft);padding:3px 9px;border-radius:7px;display:inline-block}
  .cc-term.done{color:var(--muted);background:var(--bg)}
  .ccard h3{font-size:16px;margin-top:10px}
  .cc-meta{display:flex;gap:18px;margin-top:12px;font-size:12px;color:var(--muted)}
  .cc-meta b{color:var(--ink);font-family:var(--disp)}
  .cc-bar{height:6px;border-radius:20px;background:var(--bg);margin-top:14px;overflow:hidden}
  .cc-bar span{display:block;height:100%;background:var(--teal);border-radius:20px}
  .cc-foot{padding:14px 20px;display:flex;align-items:center;gap:12px}
  .cc-foot .lab{font-size:11px;color:var(--muted);font-weight:700}
  .cc-manage{margin-left:auto;background:var(--teal);color:#fff;padding:9px 16px;border-radius:10px;font-weight:700;font-size:12.5px;font-family:var(--disp)}
  .cc-manage:hover{background:var(--teal-dk)}
  .cc-actions{margin-left:auto;display:flex;gap:8px;align-items:center}
  .cc-actions .cc-manage{margin-left:0}
  .cc-dup{border:1.5px solid var(--line);border-radius:10px;padding:9px 13px;font-weight:700;font-size:12.5px;font-family:var(--disp);color:var(--ink)}
  .cc-dup:hover{border-color:var(--teal);color:var(--teal)}

  @media(max-width:880px){
    .ccards{grid-template-columns:1fr}
    .login-art{display:none}
    .login-form{width:100%}
    #app.show{grid-template-columns:1fr}
    .sidebar{display:none}
    .g3,.vgrid{grid-template-columns:1fr}
    .g2{grid-template-columns:1fr}
    .content{padding:18px}
  }

/* ---------- admin: card head + details/summary toggle (lms-mock のカードトーンに揃える) ---------- */
.card-head{display:flex;align-items:center;gap:14px;padding:4px 0}
.card-head .titles{flex:1;min-width:0}
.card-head .t{font-family:var(--disp);font-weight:700;font-size:15px;line-height:1.4;color:var(--ink)}
.card-head .meta{font-size:12.5px;color:var(--muted);margin-top:4px;line-height:1.5}
.card-head .right{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.card-head .pill-sm{font-size:10.5px;font-weight:700;padding:3px 8px;border-radius:7px;font-family:var(--disp)}
details > summary.toggle{list-style:none;cursor:pointer;display:inline-block;border:1.5px solid var(--line);color:var(--ink);padding:9px 16px;border-radius:10px;font-weight:700;font-size:12.5px;font-family:var(--disp);transition:.15s;background:#fff}
details > summary.toggle::-webkit-details-marker{display:none}
details > summary.toggle::marker{content:""}
details > summary.toggle:hover{border-color:var(--teal);color:var(--teal)}
details[open] > summary.toggle{border-color:var(--teal);color:var(--teal);background:var(--soft)}
.edit-panel{margin-top:14px;background:var(--soft);padding:18px;border-radius:12px;border:1px solid var(--line)}
.edit-actions{display:flex;gap:8px;margin-top:16px;align-items:center;flex-wrap:wrap}
.btn-add{display:block;width:100%;background:var(--teal);color:#fff;padding:14px 18px;border-radius:12px;font-weight:700;font-size:14px;font-family:var(--disp);transition:.15s;cursor:pointer;border:none;text-align:center}
.btn-add:hover{background:var(--teal-dk)}
.btn-add.ghost{background:#fff;color:var(--teal);border:1.5px solid var(--line)}
.btn-add.ghost:hover{border-color:var(--teal);background:var(--soft)}
.empty-note{color:var(--muted);font-size:12.5px;padding:18px;text-align:center;background:var(--soft);border-radius:10px}
.btn-danger{border:1.5px solid var(--absent);color:var(--absent);background:#fff;padding:9px 16px;border-radius:10px;font-weight:700;font-size:12.5px;font-family:var(--disp);cursor:pointer;text-decoration:none;display:inline-block;transition:.15s}
.btn-danger:hover{background:#fbeae6}
.flash{background:#e7f3ee;color:var(--ok);padding:12px 16px;border-radius:11px;font-size:13px;margin-bottom:16px;font-family:var(--disp);font-weight:700}
.alert{background:#fbeae6;color:var(--absent);padding:12px 16px;border-radius:11px;font-size:13px;margin-bottom:16px}

/* ---------- student: support links + hero + materials button grid ---------- */
.link-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
.link-btn{display:flex;align-items:center;gap:11px;padding:13px 14px;background:var(--surface);border:1px solid var(--line);border-radius:12px;text-decoration:none;color:var(--ink);transition:.12s;min-width:0}
.link-btn:hover{border-color:var(--teal);box-shadow:var(--shadow);transform:translateY(-1px)}
.link-btn .ico{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;flex:none;font-size:16px}
.link-btn .lbl{flex:1;min-width:0;font-family:var(--disp);font-weight:700;font-size:13px;line-height:1.3;overflow:hidden;text-overflow:ellipsis}
.link-btn .ext{font-size:11px;color:var(--muted);flex:none}
.lk-drive{background:#e7f3ee;color:#1f8a5b}
.lk-chat{background:#eef1fb;color:#3a55b5}
.lk-meet{background:#e6f1f2;color:var(--teal)}
.lk-spreadsheet{background:#e7f3ee;color:#1f8a5b}
.lk-site{background:#eef2f1;color:var(--ink)}
.lk-contact{background:#fbf0dd;color:#a86a18}
.lk-other{background:var(--soft);color:var(--muted)}
.support-newforce{margin-top:18px;padding:16px;background:linear-gradient(135deg,var(--soft),#fff);border:1px solid var(--line);border-radius:12px}
.support-newforce .h{font-family:var(--disp);font-weight:700;font-size:13px;margin-bottom:8px;display:flex;align-items:center;gap:8px}
.support-newforce .l{display:flex;flex-wrap:wrap;gap:8px}
.support-newforce .l a{display:inline-flex;align-items:center;gap:7px;padding:9px 13px;background:#fff;border:1px solid var(--line);border-radius:10px;text-decoration:none;color:var(--ink);font-size:12.5px;font-weight:700;font-family:var(--disp);transition:.12s}
.support-newforce .l a:hover{border-color:var(--teal);color:var(--teal)}

/* ---------- student: session detail hero + materials grid ---------- */
.hero{padding:32px 28px;margin-bottom:18px;background:linear-gradient(150deg,#fff,var(--soft));border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow)}
.hero .hd{display:flex;gap:18px;align-items:flex-start;margin-bottom:20px}
.hero .hd .snum{width:54px;height:54px;border-radius:14px;font-size:18px;background:linear-gradient(150deg,var(--teal),var(--teal-dk));color:#fff;border:none}
.hero .hd .no{font-family:var(--disp);font-weight:700;font-size:13px;color:var(--muted);letter-spacing:.08em;margin-bottom:4px}
.hero .hd .h1{font-family:var(--disp);font-weight:900;font-size:30px;line-height:1.3;letter-spacing:-.01em;color:var(--ink)}
.hero .meta-row{display:flex;flex-wrap:wrap;gap:14px;font-size:13.5px;color:var(--muted);margin-bottom:22px}
.hero .meta-row b{color:var(--ink);font-weight:500}
.hero .body-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px 22px}
.hero .body-card .lbl{font-family:var(--disp);font-weight:700;font-size:12.5px;color:var(--teal);letter-spacing:.06em;margin-bottom:10px;display:flex;align-items:center;gap:7px}
.hero .body-card .text{font-size:14.5px;line-height:1.85;color:var(--ink);white-space:pre-wrap}
.hero .body-card .obj{margin-top:18px;padding-top:16px;border-top:1px dashed var(--line)}
.hero .body-card .obj .lbl{color:var(--amber)}
.meet-cta{display:flex;align-items:center;gap:14px;padding:18px 22px;background:linear-gradient(135deg,var(--teal),var(--teal-dk));color:#fff;border-radius:14px;margin-bottom:18px;text-decoration:none;box-shadow:var(--shadow);transition:.15s}
.meet-cta:hover{transform:translateY(-1px);box-shadow:0 12px 30px rgba(15,110,110,.25)}
.meet-cta .ic{width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,.18);display:grid;place-items:center;font-size:22px;flex:none}
.meet-cta .t{font-family:var(--disp);font-weight:700;font-size:16px}
.meet-cta .s{font-size:12px;opacity:.85;margin-top:2px}
.meet-cta .arrow{margin-left:auto;font-size:20px;opacity:.8}
.mat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.mat-btn{display:flex;flex-direction:column;gap:12px;padding:18px;background:var(--surface);border:1px solid var(--line);border-radius:14px;text-decoration:none;color:var(--ink);transition:.15s;min-height:130px}
.mat-btn:hover{border-color:var(--teal);box-shadow:var(--shadow);transform:translateY(-1px)}
.mat-btn .top{display:flex;align-items:center;gap:10px}
.mat-btn .ic-big{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;font-size:22px;flex:none}
.mat-btn .ic-big.pdf{background:#fdeceb;color:#c0492f}
.mat-btn .ic-big.yt{background:#fdeaea;color:#cc3333}
.mat-btn .ic-big.vid{background:#eef1fb;color:#3a55b5}
.mat-btn .ic-big.ws{background:#e7f3ee;color:#1f8a5b}
.mat-btn .type-tag{font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:7px;font-family:var(--disp);align-self:flex-start}
.mat-btn .title{flex:1;font-family:var(--disp);font-weight:700;font-size:14px;line-height:1.4;word-break:break-word}
.mat-btn .meta{font-size:11.5px;color:var(--muted);display:flex;justify-content:space-between;align-items:center}
.mat-btn .meta .ext{color:var(--teal);font-weight:700;font-family:var(--disp)}
.essay-cta{margin-top:22px;padding:24px;background:linear-gradient(135deg,#fdf6ea,#fff);border:1px solid #f0e3cb;border-left:4px solid var(--amber);border-radius:14px;display:flex;gap:18px;align-items:center}
.essay-cta .ic{width:54px;height:54px;border-radius:14px;background:var(--amber);color:#fff;display:grid;place-items:center;font-size:22px;flex:none}
.essay-cta .t{font-family:var(--disp);font-weight:700;font-size:15px;color:var(--ink)}
.essay-cta .s{font-size:12.5px;color:#8a6a2e;margin-top:3px}
.essay-cta .go{margin-left:auto;background:var(--amber);color:#16282E;padding:11px 18px;border-radius:11px;font-weight:700;font-size:13px;font-family:var(--disp);text-decoration:none;transition:.15s}
.essay-cta .go:hover{filter:brightness(.95)}
.essay-cta.done{background:linear-gradient(135deg,#e7f3ee,#fff);border-color:#cae3d5;border-left-color:var(--ok)}
.essay-cta.done .ic{background:var(--ok)}
.essay-cta.done .go{background:var(--ok);color:#fff}
