.filter-bar{display:flex;flex-wrap:wrap;gap:12px;margin:16px 0}.filter-bar input,.filter-bar select{padding:8px;font-size:14px;border:1px solid #ccc;border-radius:4px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;display:flex;justify-content:center;align-items:center;z-index:2000}.modal{background:#fff;border-radius:8px;padding:24px;max-width:400px;width:90%;box-shadow:0 4px 20px #0000001a}.skeleton{background:#f3f4f6;animation:pulse 1.5s infinite}.skeleton-title{height:20px;background:#e5e7eb;width:60%;margin-bottom:12px}.skeleton-line{height:14px;background:#e5e7eb;width:100%;margin-bottom:8px}.skeleton-button{height:32px;width:100px;background:#e5e7eb;margin-top:12px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.card-grid{display:flex;flex-wrap:wrap;gap:16px;justify-content:flex-start}.admin-card,.reviewer-card{flex:1 1 350px;max-width:400px}:root{--nsf-gold:#f5b400;--nsf-gold-700:#d99c00;--nsf-gray:#7a7a7a;--ink:#1f2937;--bg:#f7f8fb;--panel:#ffffff;--soft:0 12px 30px rgba(0,0,0,.08)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--ink)}body:before{background-image:url(/images/nsf-student1.jpg);animation-name:fade1}body:after{background-image:url(/images/nsf-student2.jpg);animation-name:fade2}.bg3{background-image:url(/images/nsf-student3.jpg);animation-name:fade3}.frame{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{background:#fff;border-right:1px solid #e9eef5;padding:18px;display:flex;flex-direction:column;gap:14px}.brand{display:flex;align-items:center;gap:10px;margin-bottom:6px}.brand img{height:28px;width:auto}.brand .title{font-weight:900;letter-spacing:.3px;color:var(--ink)}.side-group{display:grid;gap:6px}.side-link{display:block;padding:10px 12px;border-radius:10px;text-decoration:none;color:var(--ink)}.side-link:hover{background:#f2f5f9}.side-link-active{background:#fff6e0;outline:1px solid #ffe3a3}.as-button{background:none;border:0;text-align:left;width:100%;font:inherit;cursor:pointer}.side-footer{margin-top:auto;font-size:12px;color:#6b7280}.main{padding:24px}.container{max-width:1100px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center}.card{background:var(--panel);border-radius:16px;box-shadow:var(--soft);padding:24px}.btn{background:var(--nsf-gold);color:#111;border:0;border-radius:12px;padding:10px 16px;font-weight:700;cursor:pointer}.btn:hover{background:var(--nsf-gold-700)}.btn.ghost{background:#f2f5f9;color:var(--ink)}.link{color:var(--ink);text-decoration:underline;font-weight:600}label{display:block;font-weight:600;margin:10px 0 6px}input,select,textarea{width:100%;padding:10px;border-radius:10px;border:1px solid #e5e7eb;outline:none;background:#fff}.hero{min-height:calc(100vh - 48px);display:grid;place-items:center}.hero-card{max-width:820px;-webkit-backdrop-filter:saturate(120%) blur(2px);backdrop-filter:saturate(120%) blur(2px)}.center-page{min-height:calc(100vh - 48px);display:flex;align-items:center;justify-content:center}.pill{padding:4px 10px;border-radius:999px;background:#f2f5f9;font-weight:700;font-size:13px}.pill-approved{background:#dcfce7;color:#166534}.pill-review{background:#fff3c4;color:#8a5b00}.pill-submitted{background:#e5e7eb;color:#1f2937}.pill-rejected{background:#fee2e2;color:#991b1b}.row{display:flex;gap:12px;flex-wrap:wrap}.space{height:12px}.rec-title{font-weight:700;margin-bottom:6px}.rec-box{background:#f8fafc;border:1px solid #e5e7eb;border-left:4px solid #d1d5db;padding:10px 12px;border-radius:8px;white-space:pre-wrap}.rec-empty{color:#6b7280;font-style:italic}.side-footer .logout-link{display:block;width:100%;text-align:center;margin-top:12px;padding:12px 14px;border-radius:12px;background:var(--nsf-gold);color:#111;text-decoration:none;font-weight:800;box-shadow:0 6px 18px #0000001a}.side-footer .logout-link:hover{background:var(--nsf-gold-700)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:50}.modal{background:#fff;border-radius:16px;max-width:980px;width:calc(100% - 56px);max-height:85vh;overflow:auto;padding:20px;box-shadow:0 20px 60px #00000040}.details-grid{display:grid;grid-template-columns:240px 1fr;gap:10px 18px}.details-row{display:contents}.details-label{font-weight:700;color:#374151}.details-value{white-space:pre-wrap;word-break:break-word}.page-header{background:#fff;border-radius:16px;box-shadow:var(--soft);padding:18px 22px;margin-bottom:16px}.page-header h1{margin:0;color:var(--ink);font-weight:800;letter-spacing:.2px}.title-on-photo{color:#f5b400;text-shadow:0 2px 8px rgba(0,0,0,.45);font-weight:800}.clerk-center-wrapper{position:fixed;top:0;right:0;bottom:0;left:0;display:flex!important;justify-content:center!important;align-items:center!important;background:#0000000d;z-index:1000}body:before,body:after,.bg3{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-3;background-size:cover;background-position:center;background-repeat:no-repeat;animation-timing-function:ease-in-out;animation-iteration-count:infinite;animation-duration:30s;animation-fill-mode:both;opacity:0}body:before{background-image:url(/images/nsf-student1.jpg);animation-name:fade1}body:after{background-image:url(/images/nsf-student2.jpg);animation-name:fade2}.bg3{background-image:url(/images/nsf-student3.jpg);animation-name:fade3}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-2;background:#ffffff40;pointer-events:none}@keyframes fade1{0%,10%{opacity:1}27%{opacity:1}33%{opacity:0}93%,to{opacity:1}}@keyframes fade2{0%,30%{opacity:0}33%,60%{opacity:1}66%,to{opacity:0}}@keyframes fade3{0%,63%{opacity:0}66%,90%{opacity:1}93%,to{opacity:0}}
