:root{color:#0f172a;background:#f8fafc;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{background:linear-gradient(#f8fafc 0%,#eef6f2 100%)}:is(html:has(.stellenbosch-home),body:has(.stellenbosch-home)){overflow:hidden}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}code{overflow-wrap:anywhere;background:#f8fafc;border:1px solid #dbe4ee;border-radius:12px;padding:10px 12px;display:block}.app-shell{min-height:100vh}.shell-loading{background:#072d63}.topbar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:20;background:#ffffffd9;border-bottom:1px solid #dbe4ee;justify-content:space-between;align-items:center;gap:16px;padding:20px 24px;display:flex;position:sticky;top:0}.topbar h1{margin:0;font-size:1.2rem}.eyebrow{text-transform:uppercase;letter-spacing:.08em;color:#047857;font-size:.75rem;font-weight:700}.nav-links{align-items:center;gap:12px;display:flex}.topbar-stellenbosch{color:#fff;background:#072d63;border-bottom:4px solid #d8bc70;box-shadow:0 12px 30px #072d6338}.topbar-stellenbosch .eyebrow{color:#d8bc70}.topbar-stellenbosch h1,.topbar-stellenbosch a{color:#fff}.topbar-stellenbosch .ghost-btn{color:#fff;background:#a51433;border:1px solid #ffffff47}.topbar-stellenbosch .ghost-btn:hover{background:#b5576b}.page-wrap{width:min(1160px,100% - 32px);margin:24px auto 48px}.page-wrap-stellenbosch{width:100%;margin:24px 0 48px}.stack-lg{gap:20px;display:grid}.center-screen,.auth-screen{place-items:center;min-height:100vh;padding:24px;display:grid}.auth-card,.hero-card,.panel,.report-card,.embed-placeholder{background:#fff;border:1px solid #dbe4ee;border-radius:24px;box-shadow:0 10px 30px #0f172a0f}.auth-card{width:min(460px,100%);padding:28px}.hero-card,.panel,.embed-placeholder{padding:24px}.hero-card h2,.panel h3,.auth-card h1,.report-card h4{margin-top:0}.muted{color:#475569}.message-box{color:#065f46;background:#ecfdf5;border:1px solid #a7f3d0;border-radius:14px;padding:12px 14px}.form-grid{gap:14px;display:grid}.form-grid label,.inline-form{gap:6px;display:grid}input,textarea,select{background:#fff;border:1px solid #cbd5e1;border-radius:14px;width:100%;padding:12px 14px}textarea{resize:vertical;min-height:96px}.primary-btn,.ghost-btn,.link-btn{cursor:pointer;border:0;border-radius:14px;padding:12px 16px}.primary-btn{color:#fff;background:#059669;font-weight:700}.ghost-btn{color:#065f46;background:#ecfdf5}.link-btn{color:#065f46;background:0 0;padding-left:0}.card-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;display:grid}.report-card{padding:20px;transition:transform .15s,box-shadow .15s;display:block}.report-card:hover{transform:translateY(-2px);box-shadow:0 14px 34px #0f172a1a}.admin-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;display:grid}.inline-form{grid-template-columns:1fr 1fr auto;align-items:end;gap:12px}.simple-list{gap:10px;display:grid}.list-row{background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:12px 14px}.detail-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.label{color:#475569;margin-bottom:8px;font-size:.8rem;font-weight:700;display:block}.embed-placeholder{text-align:center;background:linear-gradient(#fff 0%,#f0fdf4 100%);place-items:center;min-height:300px;display:grid}.error{color:#991b1b;background:#fef2f2;border-color:#fecaca}.section-head{justify-content:space-between;align-items:center;display:flex}.stellenbosch-home{background-color:#0000;background-image:linear-gradient(#072d6300 0 192px,#284c95 192px 100%),linear-gradient(90deg,#d8bc708f,#b58d2880,#a514336b),url(https://images.unsplash.com/photo-1500530855697-b586d89ba3ee?auto=format&fit=crop&w=1800&q=80);background-position:top;background-repeat:repeat,repeat,repeat;background-size:auto,auto,cover;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;gap:20px;min-height:calc(100vh - 88px);margin:-24px 0 -48px;padding:0 clamp(16px,4vw,72px) 48px;display:grid;overflow-x:hidden}.stellenbosch-hero{width:min(1390px,100%);margin:0 auto;padding-top:18px}.stellenbosch-brand-block{background:#fffffff5;grid-template-columns:230px 1fr;min-height:128px;display:grid;box-shadow:0 18px 42px #0f172a2e}.stellenbosch-logo{background:#072d63;place-items:center;padding:14px;display:grid}.stellenbosch-logo img{object-fit:contain;width:min(170px,100%);max-height:122px;display:block}.stellenbosch-brand-block>div:last-child{align-self:center;padding:24px 30px}.stellenbosch-kicker{color:#a51433;letter-spacing:.1em;text-transform:uppercase;font-size:.88rem;font-weight:900}.stellenbosch-brand-block h2{color:#111827;margin:4px 0 2px;font-size:clamp(1.45rem,3vw,2.35rem);line-height:1.05}.stellenbosch-brand-block p{color:#4b5563;margin:0;font-weight:600}.stellenbosch-report-section{color:#fff;width:min(1390px,100%);margin:18px auto 0}.stellenbosch-welcome{color:#fff;overflow-wrap:anywhere;background:#ffffff29;border-left:4px solid #d8bc70;width:fit-content;max-width:100%;margin:0 0 20px;padding:10px 16px;font-size:clamp(1rem,1.8vw,1.35rem);font-weight:800;line-height:1.2;box-shadow:0 14px 30px #072d6333}.stellenbosch-welcome p{color:#fff;margin:0;font-size:1rem;font-weight:800}.stellenbosch-report-section .section-head h3{color:#fff;margin:0 0 4px;font-size:1.35rem}.stellenbosch-report-section .section-head{margin-bottom:20px}.stellenbosch-report-carousel{padding:0 72px;position:relative;overflow:visible}.stellenbosch-report-viewport{width:100%;overflow:hidden}.stellenbosch-report-grid{scroll-behavior:smooth;scrollbar-width:none;-webkit-overflow-scrolling:touch;width:100%;padding:14px 0 34px;display:flex;overflow:auto visible}.stellenbosch-report-grid::-webkit-scrollbar{display:none}.stellenbosch-report-card{background:var(--card-accent);color:#fff;transform-origin:50%;flex:0 0 20%;align-content:start;min-height:330px;padding:34px clamp(24px,3vw,40px);transition:transform .22s,filter .22s,box-shadow .22s;display:grid;position:relative}.stellenbosch-report-card:hover{z-index:2;filter:brightness(1.08);transform:scale(1.055);box-shadow:0 34px 64px #072d635c}.stellenbosch-report-arrow{z-index:4;color:#fff;cursor:pointer;background:#072d63d1;border:2px solid #ffffffbd;border-radius:50%;place-items:center;width:54px;height:54px;line-height:1;transition:transform .18s,background .18s,box-shadow .18s;display:grid;position:absolute;top:calc(50% - 10px);transform:translateY(-50%);box-shadow:0 18px 38px #072d635c}.stellenbosch-report-arrow svg{stroke:currentColor;stroke-width:3px;stroke-linecap:round;stroke-linejoin:round;fill:none;width:28px;height:28px}.stellenbosch-report-arrow:hover{background:#a51433;transform:translateY(-50%)scale(1.08);box-shadow:0 22px 46px #072d6370}.stellenbosch-report-arrow-left{left:0}.stellenbosch-report-arrow-right{right:0}.stellenbosch-card-icon{color:#fff;border:2px solid #ffffffd9;border-radius:50%;place-items:center;width:53px;height:53px;margin-bottom:18px;font-size:.9rem;font-weight:900;display:grid}.stellenbosch-card-label{color:#ffffffdb;letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px;font-size:.78rem;font-weight:900}.stellenbosch-report-card h4{margin:0 0 16px;font-size:clamp(1.35rem,2vw,1.8rem);line-height:1.12}.stellenbosch-report-card p{color:#fffffff0;margin:0;font-size:1rem}.stellenbosch-panel{color:#0f172a;background:#fffffff5;padding:22px 24px;font-weight:700}@media (width<=760px){:is(html:has(.stellenbosch-home),body:has(.stellenbosch-home)){overflow-y:auto}.topbar{flex-direction:column;align-items:flex-start}.topbar-stellenbosch{gap:14px;padding:18px 20px}.topbar-stellenbosch .nav-links{justify-content:flex-start;gap:14px;width:100%}.topbar-stellenbosch .ghost-btn{border-radius:12px;padding:9px 13px}.admin-grid,.detail-grid,.inline-form{grid-template-columns:1fr}.page-wrap{width:min(100% - 20px,1160px);margin-top:16px}.page-wrap-stellenbosch{width:100%;margin:16px 0 48px}.auth-card,.hero-card,.panel,.report-card,.embed-placeholder{border-radius:20px}.stellenbosch-home{background-color:#0000;background-image:linear-gradient(#072d6300 0 300px,#284c95 300px 100%),linear-gradient(90deg,#d8bc708f,#a514336b),url(https://images.unsplash.com/photo-1500530855697-b586d89ba3ee?auto=format&fit=crop&w=1200&q=80);background-position:top;background-repeat:repeat,repeat,repeat;background-size:auto,auto,cover;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;width:100%;max-width:100%;min-height:calc(100vh - 136px);margin-top:-16px;padding:0 16px 48px;overflow-x:hidden}.stellenbosch-hero,.stellenbosch-report-section{width:100%;min-width:0;max-width:100%;margin-left:0;margin-right:0;overflow:hidden}.stellenbosch-brand-block{grid-template-columns:1fr;width:100%;min-height:0;display:block;overflow:hidden}.stellenbosch-logo{min-height:96px}.stellenbosch-logo img{width:min(160px,100%)}.stellenbosch-brand-block>div:last-child{min-width:0;padding:20px}.stellenbosch-brand-block h2{overflow-wrap:anywhere;font-size:1.65rem}.stellenbosch-brand-block p{font-size:.98rem}.stellenbosch-report-section{margin-top:20px}.stellenbosch-welcome{width:100%;padding:12px 14px;font-size:1.15rem}.stellenbosch-welcome p{font-size:.94rem}.stellenbosch-report-grid{gap:16px;width:100%;padding:10px 0 24px;display:grid;overflow:visible}.stellenbosch-report-carousel{width:100%;max-width:100%;padding:0;overflow:visible}.stellenbosch-report-viewport{width:100%;overflow:visible}.stellenbosch-report-card{width:100%;max-width:100%;min-height:260px;padding:28px 24px}.stellenbosch-report-arrow{display:none}}
