@import"https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@500;600;700;800&family=Inter:wght@300;400;500;600&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f4f2ee;--surf:#fff;--surf2:#f9f8f6;--surf3:#f0ede8;--red:#c41e1e;--red-b:#e02424;--red-pale:#fdf0f0;--red-glow:rgba(196,30,30,.12);--white:#fff;--muted:#7a7570;--muted2:#a09890;--border:#e4e0da;--border2:#d4cfc8;--text:#1c1917;--text2:#44403c;--green:#16a34a;--green-pale:#f0fdf4;--amber:#d97706;--amber-pale:#fffbeb;--sh-s:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);--sh-m:0 4px 12px rgba(0,0,0,.08),0 2px 4px rgba(0,0,0,.04);--sh-l:0 8px 24px rgba(0,0,0,.1),0 3px 8px rgba(0,0,0,.06);--font-h:"Barlow Condensed",sans-serif;--font-b:"Inter",sans-serif}body{background:var(--bg);color:var(--text);font-family:var(--font-b)}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse 100% 50% at 50% 0%,rgba(196,30,30,.06) 0%,transparent 60%),var(--bg);padding:1.5rem}.login-card{background:var(--surf);border:1px solid var(--border);border-radius:12px;padding:2.5rem 2rem;width:100%;max-width:420px;box-shadow:var(--sh-l)}.login-logo{text-align:center;margin-bottom:2rem}.login-logo h1{font-family:var(--font-h);font-size:1.6rem;font-weight:800;letter-spacing:.04em;color:var(--text);text-transform:uppercase;margin-top:.75rem}.login-logo p{font-size:.72rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-top:.25rem}.login-divider{height:1px;background:var(--border);margin:1.5rem 0}.lbl{font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:.4rem;display:block}.login-select,.login-input{width:100%;background:var(--surf2);border:1px solid var(--border2);border-radius:8px;color:var(--text);font-family:var(--font-b);font-size:.9rem;padding:.7rem .9rem;margin-bottom:1rem;outline:none;transition:border-color .2s,box-shadow .2s}.login-select:focus,.login-input:focus{border-color:var(--red);box-shadow:0 0 0 3px var(--red-glow)}.login-btn{width:100%;background:var(--red);color:#fff;border:none;border-radius:8px;padding:.85rem;font-family:var(--font-h);font-size:1.1rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;box-shadow:0 2px 8px #c41e1e4d;transition:all .2s}.login-btn:hover:not(:disabled){background:var(--red-b);box-shadow:0 4px 16px #c41e1e59}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{background:var(--red-pale);border:1px solid rgba(196,30,30,.25);border-radius:8px;padding:.7rem .9rem;font-size:.84rem;color:#9b1c1c;margin-bottom:1rem}.login-footer{text-align:center;margin-top:1.5rem;font-size:.74rem;color:var(--muted2);line-height:1.7}.app{display:flex;min-height:100vh;background:var(--bg)}.sidebar{width:248px;flex-shrink:0;background:var(--surf);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100;box-shadow:var(--sh-s)}.sb-logo{padding:1.5rem 1.25rem 1.25rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.85rem;background:linear-gradient(180deg,var(--surf2) 0%,var(--surf) 100%)}.sb-mark{width:46px;height:46px;border-radius:12px;background:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid var(--border);box-shadow:var(--sh-s);padding:5px}.sb-mark svg,.sb-mark img{display:block;width:100%;height:100%;object-fit:contain}.sb-title h2{font-family:var(--font-h);font-size:1.15rem;font-weight:800;letter-spacing:.06em;color:var(--text);text-transform:uppercase;line-height:1}.sb-title p{font-size:.58rem;color:var(--red);letter-spacing:.18em;text-transform:uppercase;margin-top:.3rem;font-weight:600}.sb-school{margin:.75rem .9rem;background:var(--red-pale);border:1px solid rgba(196,30,30,.15);border-left:3px solid var(--red);border-radius:8px;padding:.6rem .75rem}.sb-school .slbl{font-size:.6rem;text-transform:uppercase;letter-spacing:.1em;color:var(--red);font-weight:600;margin-bottom:.2rem}.sb-school .sname{font-size:.82rem;font-weight:600;color:var(--text);line-height:1.3}.sb-nav{flex:1;padding:.5rem 0;overflow-y:auto}.nav-section{font-size:.6rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted2);font-weight:600;padding:.75rem 1.25rem .25rem}.nav-item{display:flex;align-items:center;gap:.7rem;padding:.6rem 1.25rem;cursor:pointer;border:none;background:none;width:100%;text-align:left;color:var(--muted);font-family:var(--font-b);font-size:.84rem;font-weight:500;transition:all .15s;border-left:3px solid transparent}.nav-item:hover{color:var(--text2);background:var(--surf2)}.nav-item.active{color:var(--red);background:var(--red-pale);border-left-color:var(--red);font-weight:600}.nav-icon{font-size:.95rem;width:20px;text-align:center}.sb-footer{padding:.9rem 1.25rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.sb-footer .dpo{font-size:.67rem;color:var(--muted)}.sb-footer .dpo strong{color:var(--red);display:block;font-size:.7rem;font-weight:600}.logout-btn{background:none;border:1px solid var(--border2);border-radius:6px;color:var(--muted);font-size:.72rem;padding:.3rem .65rem;cursor:pointer;transition:all .2s;font-family:var(--font-b)}.logout-btn:hover{border-color:var(--red);color:var(--red);background:var(--red-pale)}.main{margin-left:248px;flex:1;min-height:100vh}.topbar{height:58px;border-bottom:1px solid var(--border);background:var(--surf);display:flex;align-items:center;padding:0 2rem;gap:1rem;position:sticky;top:0;z-index:50;box-shadow:var(--sh-s)}.topbar h1{font-family:var(--font-h);font-size:1.35rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text)}.topbar-spacer{flex:1}.topbar-badge{font-size:.67rem;background:#dcfce7;color:#15803d;border:1px solid #bbf7d0;padding:.25rem .65rem;border-radius:20px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.page{padding:2rem;max-width:960px}.sec-hdr{margin-bottom:1.5rem}.sec-hdr h2{font-family:var(--font-h);font-size:1.55rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text)}.sec-hdr p{color:var(--muted);font-size:.85rem;margin-top:.35rem;line-height:1.65}.card{background:var(--surf);border:1px solid var(--border);border-radius:10px;padding:1.25rem;box-shadow:var(--sh-s)}.card-title{font-family:var(--font-h);font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text);margin-bottom:1.1rem;padding-bottom:.65rem;border-bottom:1px solid var(--border)}.alert-box{background:var(--red-pale);border:1px solid rgba(196,30,30,.2);border-left:3px solid var(--red);border-radius:10px;padding:1rem 1.25rem;margin-bottom:1.5rem}.alert-box h4{font-family:var(--font-h);font-size:.95rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--red);margin-bottom:.3rem}.alert-box p{font-size:.82rem;color:var(--text2);line-height:1.65}.info-box{background:var(--surf);border:1px solid var(--border);border-radius:10px;padding:1.25rem;margin-bottom:1rem;box-shadow:var(--sh-s)}.info-box h4{font-family:var(--font-h);font-size:.95rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text);margin-bottom:.5rem}.info-box p{font-size:.82rem;color:var(--muted);line-height:1.7}.dash-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:1rem;margin-bottom:1.5rem}.dash-card{background:var(--surf);border:1px solid var(--border);border-radius:10px;padding:1.25rem 1.25rem 1rem;cursor:pointer;transition:all .2s;box-shadow:var(--sh-s)}.dash-card:hover{border-color:#c41e1e4d;box-shadow:var(--sh-m);transform:translateY(-1px)}.dash-card .dc-icon{font-size:1.7rem;margin-bottom:.7rem}.dash-card .dc-lbl{font-size:.62rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted2);margin-bottom:.25rem;font-weight:500}.dash-card .dc-title{font-family:var(--font-h);font-size:1rem;font-weight:700;text-transform:uppercase;color:var(--text)}.dash-card .dc-desc{font-size:.76rem;color:var(--muted);margin-top:.4rem;line-height:1.55}.filter-row{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:1.5rem}.filter-btn{background:var(--surf);border:1px solid var(--border);border-radius:20px;color:var(--muted);font-family:var(--font-b);font-size:.78rem;padding:.35rem .9rem;cursor:pointer;transition:all .2s;font-weight:500}.filter-btn:hover{color:var(--text2)}.filter-btn.active{background:var(--red);border-color:var(--red);color:#fff;font-weight:600;box-shadow:0 2px 6px #c41e1e40}.doc-list{display:flex;flex-direction:column;gap:.45rem}.doc-row{background:var(--surf);border:1px solid var(--border);border-radius:10px;padding:.9rem 1.1rem;display:flex;align-items:center;gap:1rem;transition:all .2s;box-shadow:var(--sh-s)}.doc-row:hover{border-color:#c41e1e40;box-shadow:var(--sh-m)}.doc-info{flex:1}.doc-title{font-size:.87rem;font-weight:500;color:var(--text)}.doc-meta{font-size:.71rem;color:var(--muted);margin-top:.2rem}.doc-cat{font-size:.62rem;background:var(--surf3);border:1px solid var(--border);color:var(--muted);padding:.12rem .42rem;border-radius:4px;text-transform:uppercase;letter-spacing:.06em;font-weight:500}.dl-btn{background:none;border:1px solid var(--border2);border-radius:7px;color:var(--muted);font-family:var(--font-b);font-size:.74rem;padding:.35rem .75rem;cursor:pointer;display:flex;align-items:center;gap:.3rem;flex-shrink:0;transition:all .2s;white-space:nowrap}.dl-btn:hover{border-color:var(--red);color:var(--red);background:var(--red-pale)}.dl-btn:disabled{opacity:.5;cursor:not-allowed}.empty-state{text-align:center;padding:3rem 1rem;color:var(--muted);font-size:.875rem}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.fg{margin-bottom:1.1rem}.fg.span2{grid-column:1/-1}.fg label{font-size:.7rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);margin-bottom:.4rem;display:block}.fg label span{color:var(--red)}.fi,.fs,.fta{width:100%;background:var(--surf2);border:1px solid var(--border2);border-radius:8px;color:var(--text);font-family:var(--font-b);font-size:.875rem;padding:.65rem .85rem;outline:none;transition:border-color .2s,box-shadow .2s}.fi:focus,.fs:focus,.fta:focus{border-color:var(--red);box-shadow:0 0 0 3px var(--red-glow);background:var(--surf)}.fta{resize:vertical;min-height:90px}.submit-btn{background:var(--red);color:#fff;border:none;border-radius:8px;padding:.85rem 2.25rem;font-family:var(--font-h);font-size:1.1rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #c41e1e4d}.submit-btn:hover:not(:disabled){background:var(--red-b);box-shadow:0 4px 16px #c41e1e59}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.success-box{background:var(--green-pale);border:1px solid #bbf7d0;border-radius:12px;padding:2rem;text-align:center;box-shadow:var(--sh-s)}.success-box h3{font-family:var(--font-h);font-size:1.4rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--green);margin-bottom:.5rem}.success-box p{font-size:.84rem;color:var(--text2);line-height:1.7}.ref-code{background:var(--surf);border:1px solid var(--border);border-radius:6px;display:inline-block;padding:.3rem .85rem;font-size:.8rem;font-weight:600;color:var(--text2);margin-top:.75rem;letter-spacing:.06em;font-family:monospace}.wf-progress{display:flex;gap:.4rem;margin-bottom:1.5rem}.wf-step{height:5px;flex:1;border-radius:3px;background:var(--border);transition:background .3s}.wf-step.done{background:var(--red)}.wf-card{background:var(--surf);border:1px solid var(--border);border-radius:12px;padding:1.75rem;max-width:640px;box-shadow:var(--sh-s)}.wf-label{font-size:.63rem;text-transform:uppercase;letter-spacing:.12em;color:var(--red);font-weight:700;margin-bottom:.5rem}.wf-q{font-family:var(--font-h);font-size:1.45rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--text);line-height:1.25;margin-bottom:1rem}.wf-hint{background:var(--surf2);border:1px solid var(--border);border-left:3px solid var(--border2);border-radius:0 8px 8px 0;padding:.75rem 1rem;font-size:.81rem;color:var(--muted);line-height:1.65;margin-bottom:1.5rem}.wf-btns{display:flex;gap:.75rem}.wf-yes,.wf-no{flex:1;border:none;border-radius:8px;padding:.8rem;font-family:var(--font-h);font-size:1.1rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:all .2s}.wf-yes{background:var(--red);color:#fff;box-shadow:0 2px 8px #c41e1e40}.wf-yes:hover{background:var(--red-b)}.wf-no{background:var(--surf2);color:var(--text2);border:1px solid var(--border2)}.wf-no:hover{background:var(--surf3)}.wf-reset{background:none;border:1px solid var(--border);border-radius:7px;color:var(--muted);font-family:var(--font-b);font-size:.78rem;padding:.4rem .9rem;cursor:pointer;transition:all .2s;margin-top:1rem}.wf-reset:hover{color:var(--text2);background:var(--surf2)}.outcome-card{border-radius:12px;padding:1.75rem;max-width:640px;border:1px solid;box-shadow:var(--sh-m)}.oc-level{font-size:.63rem;text-transform:uppercase;letter-spacing:.12em;font-weight:700;margin-bottom:.4rem}.oc-title{font-family:var(--font-h);font-size:1.55rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--text);margin-bottom:.75rem}.oc-desc{font-size:.87rem;color:var(--text2);line-height:1.7;margin-bottom:1.25rem}.action-list{list-style:none;display:flex;flex-direction:column;gap:.45rem}.action-list li{font-size:.84rem;color:var(--text2);padding:.55rem .8rem;background:#ffffffb3;border:1px solid var(--border);border-radius:7px;line-height:1.55}.urgent-banner{background:var(--red-pale);border:1px solid rgba(196,30,30,.25);border-radius:8px;padding:.75rem 1rem;font-size:.82rem;font-weight:600;color:var(--red);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.dpo-box{background:#fffc;border:1px solid var(--border);border-radius:8px;padding:1rem;margin-top:1.25rem}.dpo-box .dlbl{font-size:.63rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:600;margin-bottom:.4rem}.dpo-box a{color:var(--red);text-decoration:none;font-weight:600;font-size:.9rem}.drop-zone{border:2px dashed var(--border2);border-radius:12px;padding:2.5rem 1.5rem;text-align:center;cursor:pointer;transition:all .2s;background:var(--surf2)}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--red);background:var(--red-pale)}.drop-zone .dz-icon{font-size:2.5rem;margin-bottom:.75rem}.drop-zone p{font-size:.875rem;color:var(--muted)}.drop-zone strong{color:var(--red)}.progress-bar-wrap{background:var(--surf3);border-radius:4px;height:6px;overflow:hidden;margin-top:.75rem}.progress-bar{height:100%;background:var(--red);border-radius:4px;transition:width .2s}.file-chip{display:flex;align-items:center;gap:.6rem;background:var(--surf2);border:1px solid var(--border2);border-radius:8px;padding:.6rem .9rem;margin-bottom:1rem}.file-chip .fc-name{flex:1;font-size:.84rem;font-weight:500;color:var(--text)}.file-chip .fc-size{font-size:.72rem;color:var(--muted)}.file-chip .fc-rm{background:none;border:none;cursor:pointer;color:var(--muted);font-size:1rem;line-height:1;padding:.1rem}.file-chip .fc-rm:hover{color:var(--red)}.data-table{width:100%;border-collapse:collapse}.data-table th{font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600;padding:.6rem .9rem;text-align:left;border-bottom:2px solid var(--border)}.data-table td{font-size:.84rem;padding:.7rem .9rem;border-bottom:1px solid var(--border);color:var(--text2);vertical-align:middle}.data-table tr:hover td{background:var(--surf2)}.status-badge{display:inline-block;font-size:.65rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:.2rem .55rem;border-radius:20px}.badge-received{background:#fef3c7;color:#92400e}.badge-in_progress{background:#dbeafe;color:#1e40af}.badge-completed,.badge-active{background:#dcfce7;color:#15803d}.badge-inactive{background:var(--surf3);color:var(--muted)}.icon-btn{background:none;border:1px solid var(--border);border-radius:6px;color:var(--muted);font-size:.75rem;padding:.3rem .65rem;cursor:pointer;transition:all .2s;font-family:var(--font-b)}.icon-btn:hover{border-color:var(--border2);color:var(--text2)}.icon-btn.danger:hover{border-color:var(--red);color:var(--red);background:var(--red-pale)}.panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000040;z-index:200;display:flex;align-items:stretch;justify-content:flex-end}.panel{background:var(--surf);width:400px;max-width:100vw;box-shadow:var(--sh-l);display:flex;flex-direction:column;overflow-y:auto}.panel-head{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.panel-head h3{font-family:var(--font-h);font-size:1.1rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.panel-close{background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--muted);line-height:1}.panel-body{padding:1.5rem;flex:1}.panel-foot{padding:1rem 1.5rem;border-top:1px solid var(--border);display:flex;gap:.75rem}.btn-secondary{background:none;border:1px solid var(--border2);border-radius:8px;color:var(--text2);font-family:var(--font-b);font-size:.875rem;padding:.65rem 1.25rem;cursor:pointer;transition:all .2s}.btn-secondary:hover{border-color:var(--border2);background:var(--surf2)}.report-iframe{width:100%;height:calc(100vh - 120px);border:none;border-radius:10px;box-shadow:var(--sh-m)}.report-placeholder{background:var(--surf);border:1px solid var(--border);border-radius:10px;padding:3rem;text-align:center;box-shadow:var(--sh-s)}.spinner{display:inline-block;width:16px;height:16px;border:2px solid var(--border2);border-top-color:var(--red);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-page{display:flex;align-items:center;justify-content:center;min-height:200px;gap:.75rem;color:var(--muted);font-size:.875rem}.bottom-nav{display:none}.bn-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;padding:.55rem .25rem;background:none;border:none;cursor:pointer;color:var(--muted2);font-family:var(--font-b);transition:color .15s}.bn-item.active{color:var(--red)}.bn-icon{font-size:1.15rem;line-height:1}.bn-lbl{font-size:.58rem;text-transform:uppercase;letter-spacing:.07em;font-weight:600}@media (max-width:700px){.sidebar{display:none}.main{margin-left:0;padding-bottom:72px}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--surf);border-top:1px solid var(--border);z-index:200;padding-bottom:env(safe-area-inset-bottom,0);box-shadow:0 -2px 12px #0000000f}.form-grid{grid-template-columns:1fr}.fg.span2{grid-column:1}.dash-grid{grid-template-columns:1fr 1fr}.page{padding:1.25rem}.topbar{padding:0 1.25rem}.wf-card,.outcome-card{padding:1.25rem}.panel{width:100vw}}.sar-layout{display:grid;grid-template-columns:1fr 340px;gap:2.5rem;align-items:start}.sar-sidebar{position:sticky;top:74px}.todo-card{background:var(--surf);border:1px solid var(--border);border-radius:12px;padding:1.25rem;box-shadow:var(--sh-s);border-top:3px solid var(--red)}.todo-card h4{font-family:var(--font-h);font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text);margin-bottom:.6rem}.todo-intro{font-size:.8rem;color:var(--muted);line-height:1.55;margin-bottom:1rem}.todo-list{list-style:none;counter-reset:todo;display:flex;flex-direction:column;gap:.7rem}.todo-list li{font-size:.8rem;color:var(--text2);line-height:1.5;padding-left:1.9rem;position:relative;counter-increment:todo}.todo-list li:before{content:counter(todo);position:absolute;left:0;top:0;width:1.35rem;height:1.35rem;background:var(--red-pale);color:var(--red);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;font-family:var(--font-b)}.todo-list li strong{color:var(--text);font-weight:600}.todo-help{margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border);font-size:.78rem;color:var(--muted);line-height:1.7}.todo-help a{color:var(--red);text-decoration:none;font-weight:600}.todo-help a:hover{text-decoration:underline}@media (max-width:860px){.sar-layout{grid-template-columns:1fr}.sar-sidebar{position:static}}
