*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:#f0f1f1;color:#1a1a1a;font-size:13px}
.app{display:flex;height:100vh;overflow:hidden}
.main{flex:1;display:flex;flex-direction:column;overflow:hidden}
.scroll{flex:1;overflow-y:auto;padding:14px 16px}
.view{display:none}.view.on{display:block}
.sb{width:220px;min-width:220px;background:#f0f0f0;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;overflow-y:auto}
.sb-top{background:#ce0e2d;padding:11px 13px 9px}
.sb-title{font-size:13px;font-weight:700;color:#fff}
.sb-sub{font-size:9px;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:.07em;margin-top:1px}
.save-row{padding:3px 13px 5px;background:rgba(0,0,0,.18);font-size:9px;color:rgba(255,255,255,.7);display:flex;align-items:center;gap:4px;cursor:pointer}
.save-dot{width:5px;height:5px;border-radius:50%;background:#4ade80;flex-shrink:0}
.prog-box{padding:9px 11px 7px;border-bottom:1px solid #e0e0e0}
.prog-label{font-size:9px;text-transform:uppercase;letter-spacing:.06em;color:#999;margin-bottom:4px}
.prog-sel{width:100%;font-size:12px;padding:4px 6px;border-radius:5px;border:1px solid #e0e0e0;background:#fff;color:#1a1a1a;cursor:pointer}
.nav-lbl{font-size:9px;text-transform:uppercase;letter-spacing:.07em;color:#bbb;font-weight:600;padding:9px 11px 3px}
.nav-hr{border:none;border-top:1px solid #e0e0e0;margin:3px 0}
.nav a{display:flex;align-items:center;gap:7px;padding:7px 11px;font-size:12px;cursor:pointer;color:#555;border-left:3px solid transparent;text-decoration:none;user-select:none;position:relative}
.nav a:hover{background:#fff;color:#1a1a1a}
.nav a.on{border-left-color:#ce0e2d;background:#fff;color:#1a1a1a;font-weight:500}
.nav-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.nav-badge{position:absolute;right:10px;min-width:16px;height:16px;border-radius:8px;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px}
.sb-bot{margin-top:auto;border-top:1px solid #e0e0e0;padding:5px}
.sb-btn{width:100%;padding:6px 9px;font-size:11px;display:flex;align-items:center;gap:5px;cursor:pointer;border-radius:4px;color:#555;background:none;border:none;text-align:left}
.sb-btn:hover{background:#fff;color:#1a1a1a}
.sb-admin{border-top:1px solid #e8e8e8;margin-top:3px;padding-top:3px}
.sb-admin-toggle{width:100%;padding:5px 9px;font-size:10px;display:flex;align-items:center;gap:4px;cursor:pointer;border-radius:4px;color:#bbb;background:none;border:none;text-align:left;letter-spacing:.03em}
.sb-admin-toggle:hover{color:#777;background:#f5f5f5}
.ar-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:11px 13px;cursor:pointer;transition:border-color .15s,box-shadow .15s}
.ar-card:hover{border-color:#ce0e2d;box-shadow:0 2px 8px rgba(196,18,48,.1)}
.ar-card-title{font-size:11px;font-weight:600;color:#1a1a1a;margin-bottom:4px}
.ar-card-desc{font-size:10px;color:#666;line-height:1.4}
.ar-output h3{font-size:14px;font-weight:600;color:#1a1a1a;margin:14px 0 6px}
.ar-output h4{font-size:12px;font-weight:600;color:#444;margin:10px 0 4px}
.ar-output table{width:100%;border-collapse:collapse;font-size:11px;margin:8px 0}
.ar-output th{background:#ce0e2d;color:#fff;padding:5px 8px;text-align:left;font-weight:600}
.ar-output td{padding:5px 8px;border-bottom:1px solid #eee}
.ar-output tr:nth-child(even) td{background:#fafafa}
.ar-output ul{padding-left:20px;margin:4px 0}
.ar-output li{margin-bottom:3px}
.ai-banner{border:1px solid #f0d0d4;border-radius:8px;margin-bottom:14px;overflow:hidden}
.ai-banner-hd{display:flex;align-items:center;gap:7px;padding:7px 12px;cursor:pointer;background:#FFF5F6;user-select:none}
.ai-banner-hd:hover{background:#FDECEE}
.ai-banner-label{font-size:11px;font-weight:600;color:#ce0e2d;flex:1}
.ai-banner-arrow{font-size:9px;color:#bbb;transition:transform .15s}
.ai-banner-body{display:none;padding:12px 14px;border-top:1px solid #f0d0d4;font-size:11px;line-height:1.6;color:#333;background:#fff}
.ai-banner-body.open{display:block}
.ai-banner-body h4{font-size:11px;font-weight:600;color:#ce0e2d;margin:10px 0 3px}
.ai-banner-body h4:first-child{margin-top:0}
.ai-banner-body ul{padding-left:16px;margin:3px 0}
.ai-banner-body li{margin-bottom:2px}
.ai-banner-body p{margin:3px 0}
.ai-banner-foot{display:flex;justify-content:flex-end;margin-top:8px;padding-top:6px;border-top:1px solid #f5e0e3}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:7px 15px;background:#ce0e2d;flex-shrink:0}
.topbar-left{font-size:13px;font-weight:600;color:#fff}
.topbar-right{display:flex;gap:7px;align-items:center}
.term-pills{display:flex;border:1px solid rgba(255,255,255,.4);border-radius:20px;overflow:hidden}
.tp{padding:3px 9px;font-size:11px;cursor:pointer;color:rgba(255,255,255,.75);border-right:1px solid rgba(255,255,255,.2);user-select:none}
.tp:last-child{border-right:none}
.tp.on{background:rgba(255,255,255,.25);color:#fff;font-weight:600}
.yr-sel{font-size:11px;padding:3px 10px;border-radius:20px;border:1.5px solid rgba(255,255,255,.7);background:rgba(255,255,255,.22);color:#fff;font-weight:600;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23fff'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:22px}
.yr-sel option{background:#1a1a2e;color:#fff}
.card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:11px 13px;margin-bottom:8px}
.card-hd{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.card-title{font-size:12px;font-weight:600}
.card-meta{font-size:11px;color:#666;margin-top:2px}
.btn-add{background:none;border:1px dashed #ccc;border-radius:5px;padding:5px 10px;cursor:pointer;font-size:11px;color:#999;margin-top:4px}
.btn-add:hover{background:#f7f7f7;border-style:solid;color:#333}
.btn-add.green{border-color:#1D9E75;color:#065F46}
.btn-add.green:hover{background:#E1F5EE}
.btn-pri{background:#ce0e2d;color:#fff;border:none;border-radius:6px;padding:6px 14px;font-size:12px;cursor:pointer;font-weight:500}
.btn-pri:hover{background:#a50b24}
.btn-sec{background:#fff;color:#444;border:1px solid #ddd;border-radius:6px;padding:6px 12px;font-size:12px;cursor:pointer}
.btn-sec:hover{background:#f5f5f5}
.btn-del{font-size:11px;color:#bbb;background:none;border:none;cursor:pointer;padding:2px 5px;border-radius:3px;flex-shrink:0}
.btn-del:hover{color:#e53e3e;background:#fff0f0}
.btn-edit{font-size:10px;height:22px;padding:2px 8px;border-radius:4px;border:1px solid #e0e0e0;background:none;color:#444;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:3px;white-space:nowrap}
.btn-edit:hover{background:#f0f0f0;color:#333}
.tag{display:inline-flex;align-items:center;gap:3px;font-size:10px;padding:2px 7px;border-radius:20px;border:1px solid;white-space:nowrap;margin:1px}
.tag-x{cursor:pointer;opacity:.6;font-size:9px;margin-left:1px}.tag-x:hover{opacity:1}
.tag-area{display:flex;flex-wrap:wrap;gap:3px;align-items:center;margin-top:4px}
.tag-lbl{font-size:10px;color:#aaa;margin-bottom:2px}
.td1{background:#FDECEE;color:#6B0A18;border-color:#ce0e2d}.td2{background:#E1F5EE;color:#04342C;border-color:#1D9E75}
.td3{background:#FAECE7;color:#4A1B0C;border-color:#D85A30}.td4{background:#FAEEDA;color:#412402;border-color:#BA7517}
.td5{background:#E6F1FB;color:#042C53;border-color:#378ADD}.td6{background:#FBEAF0;color:#4B1528;border-color:#D4537E}
.td7{background:#EAF3DE;color:#173404;border-color:#639922}.td8{background:#F1EFE8;color:#2C2C2A;border-color:#888780}
.td9{background:#FCEBEB;color:#501313;border-color:#E24B4A}.td10{background:#E1F5EE;color:#04342C;border-color:#5DCAA5}
.tpo{background:#EEF;color:#33b;border-color:#aac}
.t-spring{background:#E1F5EE;color:#04342C;border-color:#5DCAA5}.t-fall{background:#FAEEDA;color:#412402;border-color:#EF9F27}
.t-winter{background:#E6F1FB;color:#042C53;border-color:#85B7EB}.t-summer{background:#FAECE7;color:#4A1B0C;border-color:#F0997B}
.dd-wrap{position:relative;display:inline-block}
.dd-btn{font-size:10px;padding:2px 8px;border-radius:20px;border:1px dashed #ccc;background:none;color:#999;cursor:pointer;white-space:nowrap}
.dd-btn:hover{border-color:#ce0e2d;color:#ce0e2d}
.dd-menu{display:none;position:fixed;z-index:9999;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,.15);min-width:260px;max-height:320px;overflow-y:auto}
.dd-menu.open{display:block}
.dd-search{padding:7px 10px;border-bottom:1px solid #eee}
.dd-search input{width:100%;font-size:11px;padding:4px 7px;border-radius:4px;border:1px solid #e0e0e0;background:#f7f7f7;outline:none}
.dd-sec{padding:4px 10px 2px;font-size:9px;text-transform:uppercase;letter-spacing:.06em;color:#aaa;font-weight:600}
.dd-item{display:flex;align-items:flex-start;gap:7px;padding:5px 10px;cursor:pointer;font-size:11px}
.dd-item:hover{background:#f5f5f5}
.dd-item input{flex-shrink:0;margin-top:2px;accent-color:#ce0e2d}
.dd-done{padding:6px 10px;border-top:1px solid #eee}
.dd-done button{width:100%;padding:4px;background:#ce0e2d;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:11px}
.oc-row{border-top:1px solid #f0f0f0;padding:8px 0 4px;margin-top:6px}
.card-section{border-top:1px solid #f0f0f0;margin-top:6px}
.card-section>summary{font-size:10px;font-weight:600;color:#777;cursor:pointer;padding:5px 0 3px;display:flex;align-items:center;gap:5px;list-style:none;user-select:none;letter-spacing:.02em;text-transform:uppercase}
.card-section>summary::-webkit-details-marker,.card-section>summary::marker{display:none}
.card-section>summary .cs-arrow{font-size:8px;color:#bbb;transition:transform .15s}
.card-section[open]>summary .cs-arrow{transform:rotate(90deg)}
.card-section[open]>summary{padding-bottom:5px;border-bottom:1px solid #f5f5f5;margin-bottom:6px}
.str-sel{font-size:10px;padding:2px 5px;border-radius:4px;border:1px solid #e0e0e0;background:#f7f7f7;color:#555;cursor:pointer}
.str-bar{height:3px;border-radius:2px;background:#e0e0e0;margin-top:2px;overflow:hidden}
.str-fill{height:100%;border-radius:2px}
.group-hd{display:flex;align-items:center;justify-content:space-between;cursor:pointer;padding:7px 11px;background:#f7f7f7;border:1px solid #e0e0e0;border-radius:7px;user-select:none;margin-bottom:2px}
.group-hd.open{border-radius:7px 7px 0 0;margin-bottom:0}
.group-body{border:1px solid #e0e0e0;border-top:none;border-radius:0 0 7px 7px;padding:9px;display:flex;flex-direction:column;gap:7px;margin-bottom:10px}
.atype{display:inline-flex;align-items:center;gap:3px;font-size:10px;padding:2px 6px;border-radius:20px;border:1px solid;white-space:nowrap}
.at-project{background:#FDECEE;color:#6B0A18;border-color:#ce0e2d}.at-article{background:#E1F5EE;color:#085041;border-color:#5DCAA5}
.at-review{background:#E6F1FB;color:#042C53;border-color:#85B7EB}.at-casestudy{background:#FAEEDA;color:#633806;border-color:#EF9F27}
.at-exam{background:#FBEAF0;color:#4B1528;border-color:#ED93B1}.at-quiz{background:#FFF3E0;color:#7A3E08;border-color:#F4A95C}.at-exercise{background:#F0F4FF;color:#1E3A8A;border-color:#A5B4FC}.at-paper{background:#F5F3FF;color:#5B21B6;border-color:#C4B5FD}.at-litreview{background:#FCE7F3;color:#9D174D;border-color:#F9A8D4}.at-simulation{background:#EAF3DE;color:#27500A;border-color:#97C459}
.at-clinical{background:#FCEBEB;color:#791F1F;border-color:#F09595}.at-discussion{background:#EEF1FB;color:#1E3A8A;border-color:#93A9E8}.at-other{background:#F1EFE8;color:#2C2C2A;border-color:#B4B2A9}
.status-met{background:#EAF3DE;color:#27500A;border:1px solid #97C459;border-radius:20px;padding:1px 8px;display:inline-block;font-size:10px;margin:1px}
.status-miss{background:#FDECEE;color:#6B0A18;border:1px solid #ce0e2d;border-radius:20px;padding:1px 8px;display:inline-block;font-size:10px}
.amtable{border-collapse:collapse;width:100%;font-size:11px}
.amtable th,.amtable td{border:1px solid #e0e0e0;padding:7px 9px;vertical-align:top}
.amtable th{background:#f7f7f7;font-size:10px;font-weight:600;color:#555}
.mx-table{border-collapse:collapse;font-size:11px;min-width:100%}
.mx-table th,.mx-table td{border:1px solid #e0e0e0;padding:4px 7px}
.mx-table th{background:#f7f7f7;font-weight:500;color:#555;font-size:10px}
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:1000;align-items:center;justify-content:center}
.modal-overlay.open{display:flex}
.modal-box{background:#fff;border-radius:10px;width:780px;max-width:95vw;max-height:92vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 16px 50px rgba(0,0,0,.25)}
.modal-hd{background:#ce0e2d;padding:13px 16px;flex-shrink:0;display:flex;align-items:center;justify-content:space-between}
.modal-hd-title{font-size:13px;font-weight:600;color:#fff}
.modal-close{background:none;border:none;color:rgba(255,255,255,.8);font-size:20px;cursor:pointer;line-height:1}
.modal-body{padding:15px 16px;overflow-y:auto;flex:1}
.modal-body label{font-size:11px;color:#555;display:block;margin-bottom:2px;margin-top:8px}
.modal-body label:first-child{margin-top:0}
.modal-body input,.modal-body select,.modal-body textarea{display:block;width:100%;font-size:12px;padding:6px 9px;border:1px solid #ddd;border-radius:5px;background:#fff;color:#1a1a1a;outline:none}
.modal-body input[type="checkbox"],.modal-body input[type="radio"]{display:inline-block;width:auto;padding:0;border:none;background:none;flex-shrink:0}
.modal-body input:focus,.modal-body select:focus,.modal-body textarea:focus{border-color:#ce0e2d}
.modal-body textarea{resize:vertical;min-height:60px}
.modal-row{display:flex;gap:9px}.modal-row>div{flex:1}
.modal-footer{display:flex;gap:7px;justify-content:flex-end;margin-top:14px}
.confirm-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:2000;align-items:center;justify-content:center}
.confirm-overlay.open{display:flex}
.confirm-box{background:#fff;border-radius:10px;padding:22px;max-width:320px;width:90%;box-shadow:0 8px 32px rgba(0,0,0,.2)}
.confirm-msg{font-size:13px;color:#1a1a1a;margin-bottom:16px;line-height:1.5}
.confirm-btns{display:flex;gap:7px;justify-content:flex-end}
.toast{position:fixed;bottom:20px;right:20px;z-index:9999;padding:10px 16px;border-radius:8px;font-size:12px;font-weight:500;box-shadow:0 4px 16px rgba(0,0,0,.2);display:flex;align-items:center;gap:8px;transform:translateY(60px);opacity:0;transition:all .3s;pointer-events:none}
.toast.show{transform:translateY(0);opacity:1}
.toast.success{background:#EAF3DE;color:#27500A;border:1px solid #97C459}
.toast.error{background:#FDECEE;color:#6B0A18;border:1px solid #ce0e2d}
.toast.warning{background:#FAEEDA;color:#633806;border:1px solid #EF9F27}
.empty{text-align:center;padding:22px;color:#aaa;font-size:11px}
.pill{display:inline-block;font-size:10px;padding:1px 8px;border-radius:20px;white-space:nowrap}
.section-label{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#aaa;margin-bottom:5px}
/* ── Course Load Estimator ───────────────────────────────────────────────── */
.wl-summary{border-top:1px solid #f0f0f0;margin-top:7px;padding:6px 0 2px;display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.wl-item{font-size:10px;color:#555}
.wl-item strong{color:#1a1a1a}
.wl-week-badge{font-size:10px;font-weight:600;padding:1px 8px;border-radius:20px;background:#E6F1FB;color:#042C53;border:1px solid #85B7EB;white-space:nowrap}
.wl-week-badge.over{background:#FDECEE;color:#6B0A18;border-color:#ce0e2d}
.wl-details{border-top:1px solid #f0f0f0;margin-top:7px;padding:0 0 4px}
.wl-details>summary{font-size:10px;cursor:pointer;padding:4px 0 2px;display:flex;align-items:center;gap:6px;list-style:none;color:#555;user-select:none}
.wl-details>summary::-webkit-details-marker{display:none}
.wl-details>summary::marker{display:none}
.wl-details[open]>summary{padding-bottom:5px;border-bottom:1px solid #f5f5f5;margin-bottom:4px}
.wl-details-body{display:flex;gap:12px;flex-wrap:wrap;padding:2px 0}
.wl-callout{background:#f0f9f4;border:1px solid #6EE7B7;border-radius:8px;padding:12px 14px;margin-top:14px}
.wl-callout>summary{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#065F46;display:flex;align-items:center;gap:5px;cursor:pointer;list-style:none;user-select:none}
.wl-callout>summary::-webkit-details-marker{display:none}
.wl-callout-hint{margin-left:auto;font-size:10px;font-weight:400;text-transform:none;letter-spacing:0;color:#34D399}
.wl-callout-collapse{display:none}
.wl-callout[open]>.summary .wl-callout-expand,.wl-callout[open]>summary .wl-callout-expand{display:none}
.wl-callout[open]>summary .wl-callout-collapse{display:inline}
.leq-pill{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;cursor:pointer;font-size:11px;font-weight:500;border:1.5px solid;user-select:none;transition:all .15s;background:none}
.leq-pill.off{opacity:.38}
.leq-week-row{display:flex;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid #f5f5f5}
.leq-bar-wrap{flex:1;height:20px;background:#efefef;border-radius:3px;overflow:hidden;display:flex;min-width:80px;position:relative}
.leq-bar-seg{display:inline-block;height:100%}
.leq-threshold{position:absolute;top:0;bottom:0;width:2px;background:rgba(0,0,0,.18);pointer-events:none}
.leq-stat-box{background:#f7f7f7;border:1px solid #e8e8e8;border-radius:7px;padding:10px 14px;flex:1;min-width:120px}
.leq-stat-val{font-size:18px;font-weight:700;color:#042C53;line-height:1.2}
.leq-stat-lbl{font-size:10px;color:#888;margin-top:2px}
.wl-hdr{padding:7px 0 5px;display:flex;flex-direction:column;gap:4px;border-bottom:1px solid #f0f0f0;margin-bottom:6px}
.wl-hdr-lbl{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#aaa;margin-bottom:2px}
.wl-week-row{display:flex;align-items:center;gap:8px;font-size:10px}
.wl-week-num{min-width:38px;color:#666}
.wl-bar-wrap{flex:1;height:5px;border-radius:3px;background:#e0e0e0;overflow:hidden;min-width:60px}
.wl-bar{height:100%;border-radius:3px;background:#378ADD;transition:width .2s}
.wl-bar.warn{background:#EF9F27}
.wl-bar.over{background:#E24B4A}
.wl-hrs{min-width:42px;text-align:right;color:#555;font-size:10px}
.wl-hrs.over{color:#9B1C1C;font-weight:600}
.wl-section{margin-top:10px;padding:10px 11px 8px;background:#f7f7f7;border-radius:6px;border:1px solid #e8e8e8}
.wl-section-lbl{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#aaa;margin-bottom:6px}

/* ── Mobile ──────────────────────────────────────────────────────────────── */
/* Hamburger button — hidden on desktop, shown via media query */
.mob-menu-btn{display:none;background:none;border:none;color:#fff;font-size:22px;cursor:pointer;padding:2px 6px;line-height:1;flex-shrink:0;align-items:center}
/* Backdrop behind the drawer — toggled via .on class */
.mob-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:198}

@media(max-width:768px){
  .mob-menu-btn{display:flex}
  .mob-backdrop.on{display:block}

  /* Sidebar: slide in from left as a fixed overlay */
  .sb{position:fixed;left:-248px;top:0;bottom:0;z-index:200;width:248px;min-width:248px;transition:left .22s ease}
  .sb.mob-open{left:0;box-shadow:6px 0 28px rgba(0,0,0,.28)}

  /* Topbar: compact; suppress items that don't fit */
  .topbar{padding:6px 10px;gap:6px}
  .topbar-right{gap:5px;overflow-x:auto;flex-shrink:1}
  #data-health,#btn-print{display:none}

  /* Larger tap targets */
  .nav a{padding:11px 11px;font-size:13px}
  .sb-btn{padding:10px 10px;font-size:12px}
  .tp{padding:5px 9px;font-size:11px}
  .btn-edit{height:30px;padding:4px 10px}
  .btn-del{padding:4px 7px}
  .btn-add{padding:8px 12px;font-size:12px}
  .btn-pri,.btn-sec{padding:7px 14px}

  /* Modal: full-width, taller, stacked rows */
  .modal-box{width:96vw;max-height:93vh;border-radius:8px}
  .modal-row{flex-direction:column}

  /* Content area */
  .scroll{padding:10px 10px}

  /* Toast: stretch across bottom instead of bottom-right corner */
  .toast{left:12px;right:12px;bottom:14px;max-width:none;width:auto}
}

/* ── Outcome Map 3-view ──────────────────────────────────────────────────── */
.map-po-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:10px 13px;margin-bottom:7px;transition:border-color .15s,background .15s}
.map-po-card:hover{border-color:#ce0e2d}
.map-po-card.open{border-color:#ce0e2d;background:#FFF5F6}
.map-clo-item{background:#fafafa;border:1px solid #e8e8e8;border-left:3px solid #ce0e2d;border-radius:0 5px 5px 0;padding:8px 10px;margin-bottom:5px;cursor:pointer;transition:border-left-color .15s,background .15s}
.map-clo-item:hover{background:#F5F3FF;border-left-color:#7C3AED}
.map-clo-item.open{border-left-color:#7C3AED;background:#F5F3FF}
.map-course-tab{padding:4px 12px;border-radius:20px;font-size:11px;cursor:pointer;border:1px solid #ddd;background:#fff;color:#555;white-space:nowrap;transition:all .15s}
.map-course-tab.on{background:#ce0e2d;color:#fff;border-color:#ce0e2d}
.map-cols{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.map-col{background:#fff;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden;display:flex;flex-direction:column}
.map-col-hd{padding:8px 11px;border-bottom:1px solid #f0f0f0;background:#f9f9f9;display:flex;align-items:center;justify-content:space-between}
.map-col-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#555}
.map-col-ct{font-size:10px;background:#efefef;color:#666;padding:1px 7px;border-radius:10px}
.map-col-body{overflow-y:auto;max-height:440px}
.map-col-body::-webkit-scrollbar{width:3px}
.map-col-body::-webkit-scrollbar-thumb{background:#e0e0e0;border-radius:2px}
.map-ci{padding:8px 11px;border-bottom:1px solid #f5f5f5;cursor:pointer;font-size:11px;transition:background .1s}
.map-ci:last-child{border-bottom:none}
.map-ci:hover{background:#f5f9ff}
.map-ci.lit{background:#EDE9FE;border-left:2px solid #7C3AED;padding-left:9px}
.map-ci.sel{background:#FFF5F6;border-left:2px solid #ce0e2d;padding-left:9px}
.map-ci.dim{opacity:.2;cursor:default;pointer-events:none}
.map-ci-id{font-size:9px;color:#888;letter-spacing:.04em;margin-bottom:2px}
.map-ci-name{font-size:11px;color:#1a1a1a;line-height:1.35}
.map-ci-sub{font-size:10px;color:#888;margin-top:2px;display:flex;align-items:center;gap:4px}
.map-note{font-size:11px;color:#888;margin-top:8px;font-style:italic;padding:0 2px}
@media(max-width:768px){.map-cols{grid-template-columns:1fr}.map-col-body{max-height:200px}}

/* ── How To Use view (phase-tile design) ─────────────────────────────────── */
.ht-outer{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(0,1fr);gap:16px;align-items:start}
.ht-wrap{background:#fff;border-radius:10px;border:1px solid #DCDDDE;padding:24px 24px 28px}
.ht-phase-hd{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.ht-spine-dot{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.ht-phase-badge{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:2px 9px;border-radius:100px}
.ht-phase-title{font-size:14px;font-weight:700;color:#000;margin-top:2px}
.ht-tile-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.ht-tile{border-radius:8px;padding:13px 12px;display:flex;flex-direction:column;gap:5px;cursor:pointer;transition:opacity .15s,transform .1s,box-shadow .1s}
.ht-tile:hover{opacity:.88;transform:translateY(-1px);box-shadow:0 3px 10px rgba(0,0,0,.1)}
.ht-tile-icon{width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:15px;margin-bottom:2px}
.ht-tile-name{font-size:11px;font-weight:700}
.ht-tile-hint{font-size:10px;font-weight:300;color:#6f7271}
.ht-connector{display:flex;align-items:center;gap:10px;padding:8px 0 8px 19px}
.ht-connector-line{width:2px;height:22px;border-radius:1px;flex-shrink:0}
.ht-connector-label{font-size:10px;font-weight:300;color:#6f7271}
.ht-dict{background:#fff;border-radius:10px;border:1px solid #DCDDDE;padding:20px}
.ht-dict-hdr{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#ce0e2d;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid #DCDDDE;display:flex;align-items:center;gap:6px}
.ht-de{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;padding:8px 0;border-bottom:1px solid #DCDDDE}
.ht-de:last-child{border-bottom:none;padding-bottom:0}
.ht-de-text{display:flex;flex-direction:column;gap:2px;flex:1}
.ht-da{font-size:11px;font-weight:700;color:#000}
.ht-df{font-size:10px;font-weight:300;color:#6f7271;line-height:1.4}
.ht-dt{display:inline-block;font-size:9px;font-weight:700;padding:2px 7px;border-radius:100px;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;flex-shrink:0;margin-top:2px}
@media(max-width:768px){.ht-outer{grid-template-columns:1fr}.ht-tile-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}

/* ── Inactive courses ────────────────────────────────────────────────────── */
.card.inactive{opacity:.5;border-style:dashed}
.card.inactive .card-title{text-decoration:line-through;color:#999}
.badge-inactive{display:inline-block;font-size:10px;padding:1px 7px;border-radius:20px;background:#FFF3CD;color:#856404;border:1px solid #FFC107;white-space:nowrap}
.course-cb{display:none;width:16px;height:16px;accent-color:#7C3AED;cursor:pointer;flex-shrink:0;margin-right:2px}
#course-list.sb-select .course-cb{display:inline-block}
#bulk-bar{display:none;position:sticky;top:0;z-index:10;background:#F0EBF8;border:1px solid #C4B5FD;border-radius:8px;padding:8px 12px;margin-bottom:8px;align-items:center;gap:8px;flex-wrap:wrap}
#bulk-bar.on{display:flex}
#bulk-bar .bulk-count{font-size:11px;font-weight:600;color:#5B21B6;flex:1}

@media print{
  .sb,.topbar,#modal-overlay,#login-wall,#bulk-bar{display:none!important}
  .app{display:block!important;height:auto!important;overflow:visible!important}
  .main{display:block!important;height:auto!important;overflow:visible!important}
  .scroll{overflow:visible!important;height:auto!important;padding:0!important}
  .view{display:none!important}
  .view.on{display:block!important}
}

/* ── Preview Site Banner ──────────────────────────────────────────────────── */
#preview-banner{display:none;background:#B45309;color:#fff;font-size:11px;padding:6px 16px;align-items:center;gap:10px;flex-shrink:0}
body.preview-site #preview-banner{display:flex!important}

/* ── Accreditor Mode ──────────────────────────────────────────────────────── */
#accreditor-banner{display:none;background:#1D4ED8;color:#fff;font-size:11px;padding:6px 16px;align-items:center;gap:10px;flex-shrink:0}
body.accreditor #accreditor-banner{display:flex!important}
body.accreditor .btn-edit,
body.accreditor .btn-del,
body.accreditor .btn-add,
body.accreditor #bulk-select-btn,
body.accreditor #btn-ai-import,
body.accreditor #btn-ai-report,
body.accreditor #btn-clone-term,
body.accreditor #btn-history,
body.accreditor #btn-admin-toggle,
body.accreditor #admin-panel,
body.accreditor #nav-home,
body.accreditor #nav-howto,
body.accreditor #nav-errorcheck,
body.accreditor #hide-inactive-cb,
body.accreditor label[for="hide-inactive-cb"],
body.accreditor #bulk-bar,
body.accreditor #btn-add-course,
body.accreditor #btn-clone-course,
body.accreditor #btn-add-po,
body.accreditor #btn-add-assess,
body.accreditor #assess-collapse-all-btn,
body.accreditor #assess-expand-all-btn,
body.accreditor #collapse-all-btn,
body.accreditor #expand-all-btn,
body.accreditor #save-row,
body.accreditor #po-welcome,
body.accreditor [data-acc-hide]{display:none!important}
body.accreditor .card.inactive{display:none!important}
#accreditor-welcome{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:9000;align-items:center;justify-content:center}
#accreditor-welcome.open{display:flex}
.acc-welcome-box{background:#fff;border-radius:12px;max-width:540px;width:90%;padding:32px;box-shadow:0 16px 50px rgba(0,0,0,.3)}
/* Reviewer Guide */
.tooltip-wrap{position:relative;display:inline-block}
.tooltip-trigger{font-weight:700;color:#fff;border-bottom:2px dotted rgba(255,255,255,.6);cursor:help}
.tooltip-box{display:none;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:#000;color:#fff;font-size:10px;font-weight:300;line-height:1.5;padding:8px 10px;border-radius:6px;width:180px;text-align:left;z-index:10;white-space:normal}
.tooltip-box::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:#000}
.tooltip-wrap:hover .tooltip-box{display:block}
#nav-reviewer-guide{display:none}
body.accreditor #nav-reviewer-guide{display:flex!important}
#reviewer-guide-sep{display:none}
body.accreditor #reviewer-guide-sep{display:block}
