@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap";:root{--ink: #111111;--ink2: #444444;--ink3: #888888;--surface: #FFFFFF;--bg: #F8F8F8;--border: #EBEBEB;--accent: #FF6B00;--accent-soft: #FFF3EB;--accent-dk: #D45A00;--green: #00B268;--green-bg: #EDFAF3;--red: #E5393D;--red-bg: #FDF1F1;--blue: #2563EB;--blue-bg: #EEF3FD;--purple: #7C3AED;--purple-bg: #F3EEFF;--sidebar-w: 230px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--ink);font-size:14px;-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit}a{text-decoration:none;color:inherit}.layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--ink);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.sidebar-logo{padding:22px 18px 18px;border-bottom:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:10px}.sidebar-logo-icon{width:32px;height:32px;border-radius:8px;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.sidebar-logo-text{font-size:13px;font-weight:700;color:#fff;letter-spacing:-.02em}.sidebar-logo-sub{font-size:9px;color:#ffffff59;text-transform:uppercase;letter-spacing:.08em;font-weight:600}.sidebar-nav{flex:1;padding:10px 8px;overflow-y:auto}.nav-section{font-size:9px;font-weight:700;color:#ffffff40;letter-spacing:.12em;text-transform:uppercase;padding:14px 10px 6px}.nav-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:7px;font-size:13px;font-weight:500;color:#ffffff80;cursor:pointer;border:none;background:none;width:100%;text-align:left;transition:all .12s;position:relative}.nav-item:hover{background:#ffffff0f;color:#fffc}.nav-item.active{background:#ff6b001f;color:#fff;font-weight:600}.nav-item.active:before{content:"";position:absolute;left:0;top:20%;bottom:20%;width:3px;background:var(--accent);border-radius:0 3px 3px 0}.nav-badge{margin-left:auto;background:var(--red);color:#fff;border-radius:10px;padding:1px 7px;font-size:10px;font-weight:700}.nav-badge.amber{background:var(--accent);color:#fff}.sidebar-footer{padding:14px;border-top:1px solid rgba(255,255,255,.07)}.sidebar-user{display:flex;align-items:center;gap:9px}.sidebar-avatar{width:30px;height:30px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}.sidebar-user-name{font-size:12px;font-weight:600;color:#fff}.sidebar-user-role{font-size:10px;color:#ffffff59}.signout-btn{margin-left:auto;background:none;border:none;color:#ffffff4d;font-size:16px;cursor:pointer;padding:4px;transition:color .12s}.signout-btn:hover{color:#ffffffb3}.main{margin-left:var(--sidebar-w);flex:1;min-height:100vh}.topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:0 28px;height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}.topbar-title{font-size:16px;font-weight:700;color:var(--ink);letter-spacing:-.02em}.topbar-right{display:flex;align-items:center;gap:12px}.page{padding:24px 28px}.card{background:var(--surface);border-radius:12px;border:1px solid var(--border);padding:18px 20px;margin-bottom:14px}.card-sm{background:var(--surface);border-radius:10px;border:1px solid var(--border);padding:14px 16px}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}.stat-card{background:var(--surface);border-radius:12px;border:1px solid var(--border);padding:16px 18px;transition:box-shadow .15s}.stat-card:hover{box-shadow:0 2px 8px #0000000a}.stat-label{font-size:11px;font-weight:600;color:var(--ink3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.stat-value{font-size:26px;font-weight:800;color:var(--ink);line-height:1;letter-spacing:-.03em}.stat-sub{font-size:11px;color:var(--ink3);margin-top:4px}.stat-card.amber .stat-value{color:var(--accent)}.stat-card.green .stat-value{color:var(--green)}.stat-card.red .stat-value{color:var(--red)}.stat-card.blue .stat-value{color:var(--blue)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:5px;font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}.badge.pending,.badge.pending_approval{background:var(--accent-soft);color:var(--accent-dk)}.badge.approved{background:var(--green-bg);color:var(--green)}.badge.rejected{background:var(--red-bg);color:var(--red)}.badge.suspended{background:#f3f3f3;color:var(--ink3)}.badge.student{background:var(--blue-bg);color:var(--blue)}.badge.liaison{background:var(--purple-bg);color:var(--purple)}.badge.open{background:var(--blue-bg);color:var(--blue)}.badge.accepted,.badge.in_progress{background:var(--accent-soft);color:var(--accent-dk)}.badge.report_submitted{background:#fff3eb;color:#d45a00}.badge.completed{background:var(--green-bg);color:var(--green)}.badge.cancelled{background:#f3f3f3;color:var(--ink3)}.badge.paid{background:var(--green-bg);color:var(--green)}.badge.unpaid{background:var(--red-bg);color:var(--red)}.badge.captured{background:var(--green-bg);color:var(--green)}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th{font-size:10px;font-weight:700;color:var(--ink3);text-transform:uppercase;letter-spacing:.08em;padding:10px 14px;text-align:left;border-bottom:1px solid var(--border);background:var(--bg)}td{padding:12px 14px;border-bottom:1px solid var(--border);font-size:13px;color:var(--ink);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:#fafafa}.td-name{font-weight:600;font-size:13px}.td-email{color:var(--ink3);font-size:11px}.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:7px;font-size:12px;font-weight:600;border:none;cursor:pointer;transition:all .12s;white-space:nowrap;letter-spacing:-.01em}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--ink);color:#fff}.btn-primary:hover{background:#222}.btn-amber{background:var(--accent);color:#fff}.btn-amber:hover{background:var(--accent-dk)}.btn-green{background:var(--green);color:#fff}.btn-green:hover{opacity:.9}.btn-red{background:var(--red);color:#fff}.btn-red:hover{opacity:.9}.btn-outline{background:transparent;border:1.5px solid var(--border);color:var(--ink)}.btn-outline:hover{background:var(--bg);border-color:var(--ink3)}.btn-ghost{background:transparent;color:var(--ink3)}.btn-ghost:hover{color:var(--ink);background:var(--bg)}.btn-sm{padding:4px 9px;font-size:11px;border-radius:5px}.btn-icon{padding:5px 7px;border-radius:6px}.action-row{display:flex;gap:5px;flex-wrap:wrap}.filter-bar{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap;align-items:center}.filter-chip{padding:5px 12px;border-radius:6px;border:1.5px solid var(--border);background:var(--surface);font-size:12px;font-weight:500;color:var(--ink2);cursor:pointer;transition:all .12s}.filter-chip:hover{border-color:var(--ink3)}.filter-chip.active{border-color:var(--accent);background:var(--accent);color:#fff}.search-input{padding:7px 12px;border-radius:7px;border:1.5px solid var(--border);font-size:12px;color:var(--ink);background:var(--surface);outline:none;min-width:200px;transition:border-color .12s}.search-input:focus{border-color:var(--accent)}.filter-bar-right{margin-left:auto}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:var(--surface);border-radius:14px;width:100%;max-width:480px;max-height:85vh;overflow-y:auto;box-shadow:0 24px 80px #0003}.modal-header{padding:20px 22px 0;display:flex;justify-content:space-between;align-items:flex-start}.modal-title{font-size:17px;font-weight:700;color:var(--ink);letter-spacing:-.02em}.modal-close{background:var(--bg);border:none;font-size:16px;color:var(--ink3);cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .12s}.modal-close:hover{background:var(--border);color:var(--ink)}.modal-body{padding:16px 22px 22px}.modal-footer{padding:0 22px 22px;display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}.form-group{margin-bottom:14px}.form-label{display:block;font-size:10px;font-weight:700;color:var(--ink3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}.form-input{width:100%;padding:9px 11px;border:1.5px solid var(--border);border-radius:7px;font-size:13px;color:var(--ink);background:#fafafa;outline:none;transition:border-color .12s}.form-input:focus{border-color:var(--accent);background:#fff}textarea.form-input{resize:vertical;min-height:80px}.detail-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px}.detail-row:last-child{border-bottom:none}.detail-label{color:var(--ink3);font-size:12px}.detail-value{font-weight:500;color:var(--ink);text-align:right;max-width:60%;word-break:break-all;font-size:12px}.empty{text-align:center;padding:60px 20px;color:var(--ink3)}.empty-icon{font-size:42px;margin-bottom:12px}.empty-title{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:6px}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--ink)}.login-card{background:var(--surface);border-radius:16px;padding:36px;width:100%;max-width:380px;box-shadow:0 24px 80px #0000004d}.login-logo{display:flex;align-items:center;gap:10px;margin-bottom:28px}.login-logo-icon{width:40px;height:40px;border-radius:10px;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:20px}.login-logo-text{font-size:17px;font-weight:800;color:var(--ink);letter-spacing:-.02em}.login-logo-sub{font-size:11px;color:var(--ink3)}.login-title{font-size:20px;font-weight:700;margin-bottom:6px;letter-spacing:-.02em}.login-sub{font-size:13px;color:var(--ink3);margin-bottom:24px}.login-error{background:var(--red-bg);border:1px solid var(--red);border-radius:7px;padding:9px 12px;font-size:12px;color:var(--red);margin-bottom:14px}.tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:18px;gap:0}.tab{padding:10px 16px;border:none;background:none;font-size:13px;font-weight:500;color:var(--ink3);border-bottom:2px solid transparent;cursor:pointer;transition:all .12s}.tab.active{color:var(--ink);font-weight:700;border-bottom-color:var(--accent)}.toast{position:fixed;bottom:20px;right:20px;background:var(--ink);color:#fff;padding:10px 18px;border-radius:8px;font-size:12px;font-weight:600;z-index:2000;box-shadow:0 8px 24px #0003;animation:slide-in .2s ease}.toast.success{background:var(--green)}.toast.error{background:var(--red)}@keyframes slide-in{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.section-title{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:12px;letter-spacing:-.02em}.text-muted{color:var(--ink3)}.text-sm{font-size:12px}.mt4{margin-top:4px}.mt8{margin-top:8px}.mt16{margin-top:16px}.row{display:flex;align-items:center;gap:8px}.row-sb{display:flex;align-items:center;justify-content:space-between}.flex-1{flex:1}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--ink3)}
