:root{--bg:#020617;--panel:#0f172a;--panel-soft:#0b1220;--border:#94a3b838;--text:#e2e8f0;--text-muted:#94a3b8;--text-subtle:#64748b;--primary:#3b82f6;--primary-soft:#3b82f62e;--danger:#dc2626;--success:#22c55e;--radius-sm:10px;--radius-md:14px;--radius-lg:18px;--shadow-soft:0 14px 34px #02061773;--shadow-card:0 18px 40px #0206177a}*{box-sizing:border-box}#root,body,html{min-height:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#020617;background-color:var(--bg);color:#e2e8f0;color:var(--text);font-family:Inter,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;margin:0;overflow-x:hidden}a{color:inherit}button,input,select,textarea{font:inherit}code{font-family:Fira Code,Consolas,Monaco,monospace}.home{background:radial-gradient(circle at top,#1e293b73,#0000 50%),#020617;min-height:100vh}.home-main{margin:0 auto;padding:56px 0 32px;width:min(1180px,100% - 48px)}.home-hero{text-align:center}.hero-tag{align-items:center;background:#3b82f61f;border:1px solid #3b82f659;border-radius:999px;color:#93c5fd;display:inline-flex;font-size:12px;margin:0;padding:6px 12px}.home-hero h1{color:#f8fafc;font-size:clamp(2.1rem,5vw,3.2rem);letter-spacing:-.02em;margin:18px 0 10px}.subtitle{color:#94a3b8;font-size:1.05rem;line-height:1.65;margin:0 auto;max-width:660px}.roles{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(4,minmax(0,1fr));margin-top:48px}.about-section{background:#0f172ab8;border:1px solid #94a3b838;border-radius:16px;color:#e2e8f0;margin-top:72px;padding:34px}.about-section h2{color:#f8fafc;font-size:clamp(1.4rem,2.8vw,2rem);margin:0}.about-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(2,minmax(0,1fr));margin-top:24px}.about-grid div{background:#0f172ad9;border:1px solid #64748b59;border-radius:12px;padding:18px}.about-grid h3{color:#e2e8f0;font-size:1rem;margin:0 0 8px}.about-title{align-items:center;display:inline-flex;gap:8px}.about-title svg{color:#7dd3fc;height:15px;width:15px}.about-grid p{color:#94a3b8;font-size:.92rem;line-height:1.6;margin:0}.about-note{color:#94a3b8;font-size:.9rem;margin:24px 0 0}footer{color:#64748b;font-size:.88rem;margin-top:28px;padding:22px 0 8px;text-align:center}@media (max-width:1100px){.roles{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:700px){.home-main{padding-top:34px;width:min(1180px,100% - 28px)}.about-grid,.roles{grid-template-columns:1fr}.about-section{margin-top:48px;padding:24px}}.navbar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172ae6;border-bottom:1px solid #94a3b838;box-sizing:border-box;justify-content:space-between;max-width:100%;min-height:50px;padding:4px clamp(10px,2.2vw,18px);position:sticky;top:0;width:100%;z-index:1100}.navbar,.navbar-center{align-items:center;display:flex;gap:8px}.navbar-center{flex:1 1;min-width:0}.navbar-branding{display:flex;flex-direction:column;gap:1px;min-width:0}.navbar-logo{height:auto;width:clamp(46px,4.6vw,62px)}.navbar-title{color:#f8fafc;font-size:clamp(.78rem,1.05vw,.9rem);line-height:1.15}.navbar-subtitle,.navbar-title{margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.navbar-subtitle{color:#94a3b8;font-size:.64rem}.navbar-actions{align-items:center;display:flex;flex:0 0 auto}.back-home-btn{align-items:center;background:#0ea5e924;border:1px solid #0ea5e959;border-radius:8px;color:#e0f2fe;cursor:pointer;display:inline-flex;font-size:.74rem;font-weight:600;gap:5px;padding:5px 9px;transition:all .2s ease}.back-home-btn svg{height:12px;width:12px}.back-home-btn:hover{background:#0ea5e93d;border-color:#38bdf88c}@media (max-width:900px){.navbar-subtitle{display:none}}@media (max-width:640px){.navbar{gap:6px;min-height:44px;padding:3px 8px}.navbar-logo{width:clamp(40px,12vw,54px)}.navbar-title{font-size:.74rem}.back-home-btn{font-size:.68rem;padding:4px 7px}.back-home-label{display:none}}@media (max-width:460px){.navbar{align-items:center;flex-wrap:wrap}.navbar-center{width:100%}.navbar-actions{justify-content:flex-end;width:100%}}.role-card-shell{display:flex;position:relative}.role-card{background:#0f172ab8;border:1px solid #64748b59;border-radius:14px;cursor:pointer;min-height:232px;overflow:hidden;position:relative;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease;width:100%}.role-card:before{background:var(--role-accent);border-radius:50%;content:"";filter:blur(36px);height:180px;left:50%;opacity:.26;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);width:180px}.role-card:hover{border-color:#60a5fa66;box-shadow:0 14px 28px #02061773;transform:translateY(-4px)}.role-card:focus-visible{border-color:#60a5fa99;outline:2px solid #60a5faa6;outline-offset:2px}.role-content{color:#e2e8f0;display:flex;flex-direction:column;min-height:232px;padding:14px 16px;position:relative;text-align:center;z-index:1}.role-badge,.role-content{align-items:center;justify-content:center}.role-badge{color:#dbeafe;display:inline-flex;margin-inline:auto;margin-bottom:6px;width:100%}.role-badge svg{height:34px;width:34px}.role-content h3{color:#f8fafc;font-size:1rem;margin:0}.role-content p{color:#94a3b8;font-size:.85rem;line-height:1.5;margin:5px 0 0;min-height:0}.login-wrapper{background:radial-gradient(circle at 20% 0,#1e40af1a,#0000 34%),#020617;min-height:100vh}.login-page{display:grid;min-height:calc(100vh - 84px);padding:36px 16px 42px;place-items:center;position:relative}.login-card{background:#0f172a;border:1px solid #64748b6b;border-radius:16px;box-shadow:0 18px 40px #02061773;color:#f8fafc;padding:28px;width:min(440px,100%)}.login-icon{align-items:center;background:#0ea5e924;border:1px solid #38bdf859;border-radius:12px;color:#bae6fd;display:flex;height:54px;justify-content:center;margin:0 auto 16px;width:54px}.login-icon svg{height:24px;width:24px}.login-card h2{font-size:1.55rem;letter-spacing:-.02em;margin:0;text-align:center}.login-desc{color:#94a3b8;font-size:.95rem;line-height:1.55;margin:10px auto 0;max-width:320px;text-align:center}.login-card form{margin-top:22px}.login-card label{color:#cbd5e1;display:block;font-size:.86rem;font-weight:500;margin-top:14px}.login-card input{background:#0b1220;border:1px solid #475569e6;border-radius:10px;box-sizing:border-box;color:#f8fafc;font-size:.95rem;margin-top:7px;padding:11px 12px;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.login-card input::placeholder{color:#94a3b8}.login-card input:-webkit-autofill,.login-card input:-webkit-autofill:active,.login-card input:-webkit-autofill:focus,.login-card input:-webkit-autofill:hover{-webkit-text-fill-color:#f8fafc;box-shadow:inset 0 0 0 1000px #0b1220;-webkit-transition:background-color 9999s ease-in-out 0s;transition:background-color 9999s ease-in-out 0s}.login-card input:focus{border-color:#38bdf8b3;box-shadow:0 0 0 3px #0ea5e924;outline:none}.login-card button{background:#2563eb38;border:1px solid #2563eb80;border-radius:10px;box-sizing:border-box;color:#dbeafe;cursor:pointer;font-size:.95rem;font-weight:600;margin-top:20px;padding:11px 12px;transition:all .2s ease;width:100%}.login-card button:hover{background:#2563eb52;border-color:#60a5fabf}.login-top-error-message{background:#7f1d1d59;border:1px solid #f8717199;border-radius:10px;color:#fee2e2;line-height:1.35;margin:0 0 14px;padding:12px 14px;width:min(560px,100%)}.login-top-error-title{font-size:.75rem;font-weight:700;letter-spacing:.04em;margin:0;text-transform:uppercase}.login-top-error-text{font-size:.9rem;margin:4px 0 0}.login-help{color:#94a3b8;font-size:.88rem;margin-top:18px;text-align:center}.login-help span{color:#7dd3fc}@media (max-width:560px){.login-page{padding-top:22px}.login-card{border-radius:14px;padding:22px 18px}}.student-page{--navbar-offset:58px;--sidebar-top-gap:24px;--sidebar-bottom-gap:8px;--sidebar-width:290px;--layout-gap:32px;color:var(--text);min-height:100vh;overflow-x:hidden}.student-page .navbar{left:0;position:fixed;right:0;top:0;z-index:1300}.student-container{margin:0;max-width:none;padding:calc(var(--navbar-offset) + 10px) 12px 14px;width:100%}.student-sidebar{background:linear-gradient(180deg,#0f172afa,#0b1220f5);border:1px solid #94a3b833;border-radius:var(--radius-md);box-shadow:var(--shadow-soft);height:calc(100dvh - var(--navbar-offset) - var(--sidebar-top-gap) - var(--sidebar-bottom-gap));left:12px;margin-bottom:0;max-height:calc(100dvh - var(--navbar-offset) - var(--sidebar-top-gap) - var(--sidebar-bottom-gap));min-height:0;overflow-x:hidden;overflow-y:auto;padding:12px 10px;position:fixed;scrollbar-gutter:stable;top:calc(var(--navbar-offset) + var(--sidebar-top-gap));width:var(--sidebar-width)}.sidebar-title-wrap{border-bottom:1px solid #94a3b833}.student-main-content{margin-left:calc(var(--sidebar-width) + var(--layout-gap));min-width:0;overflow-x:hidden;width:auto}.student-layout{display:block;margin-top:10px;min-width:0;width:100%}.dashboard-cards{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:16px}.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-soft);padding:20px;transition:transform .18s ease,border-color .18s ease}.card h3{color:#f8fafc;font-size:1.05rem;margin:0}.card p{color:var(--text-muted);font-size:.9rem;line-height:1.55;margin:8px 0 0}.dashboard-cards .card[onClick]{cursor:pointer}.dashboard-cards .card[onClick]:hover{border-color:#60a5fa80;transform:translateY(-2px)}.dashboard-page{background:radial-gradient(circle at top,#1e40af14,#0000 42%),var(--bg);min-height:100vh}.dashboard-container{grid-gap:20px;display:grid;gap:20px;grid-template-columns:250px minmax(0,1fr);margin:0 auto;padding:24px 0 34px;width:min(1240px,100% - 40px)}.dashboard-content{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-soft);color:var(--text);min-width:0;padding:24px}.dashboard-content h1{color:#f8fafc;font-size:clamp(1.6rem,2.8vw,2.2rem);letter-spacing:-.02em;margin:0}@media (max-width:980px){.student-sidebar{height:auto;margin-bottom:20px;max-height:none;position:static;width:100%}.student-main-content{margin-left:0;width:100%}.dashboard-container{grid-template-columns:1fr;width:min(1240px,100% - 24px)}}.parent-dashboard{color:var(--text);min-height:100vh;padding:6px 0 10px}.parent-header{align-items:flex-start;display:flex;gap:20px;justify-content:space-between;margin-bottom:18px}.parent-header h1{color:#f8fafc;font-size:clamp(1.55rem,2.8vw,2.1rem);margin:0}.parent-subtitle{color:var(--text-muted);font-size:.92rem;line-height:1.55;margin-top:8px}.parent-header-right,.parent-summary{display:flex;gap:10px}.parent-header-right{align-items:flex-start}.parent-logout-btn{background:#dc26262e;border:1px solid #f87171a8;border-radius:10px;color:#fee2e2;cursor:pointer;font-size:.86rem;font-weight:600;padding:10px 13px;transition:.18s ease}.parent-logout-btn:hover{background:#dc26264d}.summary-item{background:var(--panel-soft);border:1px solid #94a3b852;border-radius:10px;color:var(--text);min-width:110px;padding:10px 12px}.summary-label{color:var(--text-muted);display:block;font-size:.7rem;letter-spacing:.03em;text-transform:uppercase}.summary-value{display:block;font-size:1.15rem;font-weight:700;margin-top:4px}.card-section{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-soft);margin-top:16px;padding:18px}.card-section+.card-section{margin-top:20px}.section-header h2{color:#f8fafc;font-size:1.1rem;margin:0}.section-header p{color:var(--text-subtle);font-size:.83rem;margin:5px 0 12px}.empty-state{color:var(--text-muted);font-size:.88rem;padding:16px 12px;text-align:center}.requests-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.request-card{background:var(--panel-soft);border:1px solid #94a3b847;border-radius:12px;padding:14px}.request-top{align-items:flex-start;display:flex;gap:10px;justify-content:space-between;margin-bottom:10px}.request-top h3{font-size:.98rem;margin:0}.student-label{color:#cbd5e1;font-size:.78rem;margin-top:4px}.student-label span{font-weight:600}.pill{align-items:center;border-radius:999px;display:inline-flex;font-size:.67rem;font-weight:700;letter-spacing:.04em;padding:4px 8px;text-transform:uppercase}.pill-outing{background:#3b82f633;color:#bfdbfe}.pill-home{background:#10b98133;color:#6ee7b7}.pill-xs{font-size:.62rem;padding:3px 7px}.request-meta{grid-gap:10px;display:grid;font-size:.78rem;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr));margin-bottom:10px}.meta-label{color:var(--text-subtle);display:block}.meta-value{color:#cbd5e1;display:block;margin-top:2px}.request-actions{display:flex;gap:8px;justify-content:flex-end}.btn{border:1px solid #0000;border-radius:999px;cursor:pointer;font-size:.78rem;padding:7px 12px;transition:.18s ease}.btn-primary{background:#2563eb47;border-color:#60a5fa85;color:#dbeafe}.btn-primary:hover{background:#2563eb6b}.btn-outline{background:#0000;border-color:#f87171b8;color:#fecaca}.btn-outline:hover{background:#ef44441f}.requests-table-wrapper{margin-top:6px;overflow-x:auto}.requests-table{border-collapse:collapse;font-size:.8rem;min-width:680px;width:100%}.requests-table td,.requests-table th{border-bottom:1px solid #94a3b82e;padding:10px 8px}.requests-table th{font-size:.72rem}.table-main{align-items:center;display:flex;gap:8px}.table-title{font-weight:500}.status-pill{align-items:center;border-radius:999px;display:inline-flex;font-size:.7rem;font-weight:600;padding:4px 9px}.status-pending_parent{background:#eab3082e;color:#fcd34d}.status-pending_warden{background:#6366f12e;color:#c7d2fe}.status-cancelled{background:#94a3b833;color:#cbd5e1}.status-approved{background:#22c55e33;color:#86efac}.status-rejected_by_parent,.status-rejected_by_warden{background:#ef44442e;color:#fecaca}.loading-state{align-items:center;color:var(--text-subtle);display:flex;flex-direction:column;gap:12px;justify-content:center;min-height:220px}.spinner{animation:spin .8s linear infinite;border:3px solid #334155;border-radius:50%;border-top:3px solid var(--primary);height:26px;width:26px}@keyframes spin{to{transform:rotate(1turn)}}@media (max-width:840px){.parent-header{flex-direction:column}.parent-header-right{align-items:center;justify-content:space-between;width:100%}}.warden-page{--navbar-offset:58px;--sidebar-top-gap:24px;--sidebar-bottom-gap:8px;--sidebar-width:290px;--layout-gap:32px;color:var(--text);min-height:100vh;overflow-x:hidden}.warden-page .navbar{left:0;position:fixed;right:0;top:0;z-index:1300}.warden-container{margin:0;max-width:none;padding:calc(var(--navbar-offset) + 10px) 12px 14px;width:100%}.status-banner-wrapper{display:flex;justify-content:center;margin-top:12px}.status-banner{border-radius:10px;display:inline-flex;font-size:.86rem;font-weight:600;max-width:100%;padding:9px 14px;width:auto}.status-banner.success{background:#22c55e29;border:1px solid #44e07d73;color:#80f2aa}.status-banner.error{background:#ef444424;border:1px solid #f96c6c73;color:#fca5a5}.warden-layout{display:block;margin-top:10px;min-width:0;width:100%}.warden-sidebar{background:linear-gradient(180deg,#0f172afa,#0b1220f5);border:1px solid #94a3b833;border-radius:var(--radius-md);box-shadow:var(--shadow-soft);height:calc(100dvh - var(--navbar-offset) - var(--sidebar-top-gap) - var(--sidebar-bottom-gap));left:12px;margin-bottom:0;max-height:calc(100dvh - var(--navbar-offset) - var(--sidebar-top-gap) - var(--sidebar-bottom-gap));min-height:0;overflow-x:hidden;overflow-y:auto;padding:12px 10px;position:fixed;scrollbar-gutter:stable;top:calc(var(--navbar-offset) + var(--sidebar-top-gap));width:var(--sidebar-width)}.sidebar-title-wrap{border-bottom:1px solid #8b9aae33;margin-bottom:8px;padding:4px 8px 10px}.sidebar-title{color:#f8fafc;font-size:1.2rem;letter-spacing:-.01em;line-height:1.25;margin:0}.sidebar-btn{background:#0000;border:1px solid #0000;border-radius:9px;color:var(--text-soft);cursor:pointer;font-size:.84rem;font-weight:600;margin-bottom:7px;padding:10px 11px;text-align:left;transition:background .18s ease,border-color .18s ease,color .18s ease;width:100%}.sidebar-btn-content{align-items:center;display:inline-flex;gap:8px}.sidebar-btn-content svg{height:14px;opacity:.95;width:14px}.sidebar-btn:last-child{margin-bottom:0}.sidebar-btn:hover{background:#2563eb24;border-color:#60a5fa5c;color:var(--text)}.sidebar-btn.active{background:#2563eb38;border-color:#60a5fa73;color:#eff6ff}.sidebar-today-btn{align-items:center;display:flex;gap:8px;justify-content:space-between}.sidebar-count-badge{background:#ef4444;border:1px solid #f87171f2;border-radius:999px;color:#fff;font-size:.68rem;font-weight:700;height:20px;line-height:20px;margin-left:auto;min-width:20px;padding:0 6px;text-align:center}.sidebar-logout-btn{background:#dc262633!important;border-color:#f8717194!important;color:#fee2e2!important;margin-top:6px}.sidebar-logout-content{justify-content:center;width:100%}.sidebar-logout-btn:hover{background:#dc26264d!important}.warden-main-content{margin-left:calc(var(--sidebar-width) + var(--layout-gap));min-width:0;overflow-x:hidden;width:auto}.main-content-header{background:#0000;border:none;border-radius:0;margin-bottom:12px;padding:2px 0 6px}.main-content-breadcrumb{color:var(--text-subtle);font-size:.72rem;font-weight:600;letter-spacing:.05em;margin:0;text-transform:uppercase}.main-content-title{color:#f8fafc;font-size:1.32rem;line-height:1.25;margin:5px 0 0}.registration-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:0}.staff-grid{grid-template-columns:minmax(280px,540px)}.registration-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-soft);padding:16px}.registration-card h2{color:#f8fafc;font-size:1.05rem;margin:0}.search-card{margin-bottom:12px}.search-form{display:flex;flex-direction:column;gap:9px;margin-top:10px}.registration-form label,.search-form label{color:var(--text-soft);font-size:.82rem;font-weight:600}.search-input-row{align-items:stretch;display:flex;gap:10px}.registration-form input,.reset-password-fields input,.search-input-row input{background:#0f172a;border:1px solid #475569db;border-radius:9px;color:var(--text);padding:10px 11px;width:100%}.registration-form input[type=date]::-webkit-calendar-picker-indicator,.reset-password-fields input[type=date]::-webkit-calendar-picker-indicator,.search-input-row input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;filter:invert(1) brightness(1.3);opacity:.9}.registration-form input:focus,.reset-password-fields input:focus,.search-input-row input:focus{border-color:#3b82f6b8;box-shadow:0 0 0 3px #3b82f62e;outline:none}.registration-form input::placeholder,.reset-password-fields input::placeholder,.search-input-row input::placeholder{color:var(--text-subtle)}.search-input-row .primary-btn{margin-top:0;min-width:120px}.search-result-grid,.staff-search-results{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:12px}.search-result-card{background:var(--panel-soft);border:1px solid #94a3b83d;border-radius:10px;padding:12px}.search-result-card h3{color:#f8fafc;font-size:.95rem;margin:0 0 8px}.search-result-card ul{color:#dbe7f8;display:flex;flex-direction:column;font-size:.82rem;gap:6px;margin:0;padding-left:16px}.search-empty,.staff-search-empty,.today-empty{color:var(--text-muted);font-size:.84rem;margin:0}.remove-student-section,.staff-search-empty{margin-top:12px}.reset-password-fields{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:10px}.primary-btn,.remove-confirm-no,.remove-confirm-yes,.remove-student-btn,.reset-password-btn,.staff-reset-btn{border:1px solid #0000;border-radius:9px;cursor:pointer;font-size:.8rem;font-weight:700;padding:9px 12px;transition:.18s ease}.primary-btn{background:var(--primary);border-color:#60a5fa8c;color:#fff;margin-top:8px}.primary-btn:hover{background:#2563eb}.reset-password-btn,.staff-reset-btn{background:#f59e0beb;border-color:#fbbf24d9;color:#1f2937;margin-bottom:10px}.reset-password-btn:hover,.staff-reset-btn:hover{background:#d97706;color:#fff}.remove-confirm-yes,.remove-student-btn{background:#dc2626e0;border-color:#f87171cc;color:#fff}.remove-confirm-yes:hover,.remove-student-btn:hover{background:#b91c1c}.remove-confirm-no{background:#334155cc;color:#e2e8f0}.remove-confirm-no:hover{background:#475569}.primary-btn:disabled,.remove-confirm-no:disabled,.remove-confirm-yes:disabled,.reset-password-btn:disabled,.staff-reset-btn:disabled{cursor:not-allowed;opacity:.65}.reset-credentials-box{background:#f59e0b1f;border:1px solid #fbbf2470;border-radius:9px;margin-bottom:10px;padding:10px}.reset-credentials-box p{color:#fde68a;font-size:.8rem;margin:0 0 6px}.reset-credentials-box p:last-child{margin-bottom:0}.remove-student-confirmation{background:#7f1d1d33;border:1px solid #ef444480;border-radius:9px;padding:10px}.remove-student-confirmation p{color:#fecaca;font-size:.82rem;font-weight:600;margin:0}.remove-student-actions{display:flex;gap:8px;justify-content:flex-start;margin-top:8px}.registration-form{display:flex;flex-direction:column;gap:9px;margin-top:10px}.today-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(2,minmax(0,1fr));margin-top:0}.today-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-soft);min-width:0;overflow-x:auto;padding:14px}.today-card h2{color:#f8fafc;font-size:1rem;margin:0 0 10px}.past-summaries-grid .past-search-card,.today-movements-grid .returned-students-card{grid-column:1/-1}.today-table{border-collapse:collapse;font-size:.78rem;width:100%}.today-table td,.today-table th{border-bottom:1px solid #334155b3;padding:7px 6px;text-align:left;vertical-align:top}.today-table th{color:var(--text-subtle);font-size:.67rem;letter-spacing:.03em;text-transform:uppercase}.today-table td:last-child,.today-table th:last-child{width:126px}.warden-table-actions{display:flex;flex-wrap:wrap;gap:5px}.warden-action-btn{border:1px solid #0000;border-radius:999px;cursor:pointer;font-size:.68rem;font-weight:700;padding:4px 9px}.warden-action-btn.approve{background:#22c55ee6;color:#052e16}.warden-action-btn.approve:hover{background:#16a34a}.warden-action-btn.reject{background:#0000;border-color:#f87171d1;color:#fecaca}.warden-action-btn.reject:hover{background:#f8717126}.today-status-pill{align-items:center;border-radius:999px;display:inline-flex;font-size:.68rem;font-weight:700;padding:3px 8px}.today-status-approved,.today-status-student_returned{background:#22c55e24;color:#4ade80}.today-status-pending_warden{background:#eab30824;color:#fde047}.today-status-rejected_by_parent,.today-status-rejected_by_warden{background:#ef444424;color:#fecaca}.main-summary-section{margin-top:14px}.main-summary-section h2{font-size:1.02rem;margin:0 0 10px}.main-summary-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.main-summary-card{background:var(--panel-soft);border:1px solid #94a3b83d;border-radius:10px;padding:12px}.main-summary-label{color:var(--text-soft);font-size:.76rem;margin:0}.main-summary-value{color:#f8fafc;font-size:1.65rem;font-weight:700;margin:6px 0 0}.warden-empty-state{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:180px;text-align:center}.warden-empty-state p{color:var(--text-muted);margin:6px 0 0}@media (max-width:1080px){.warden-page .navbar{position:sticky}.warden-container{padding-top:10px}.warden-layout{grid-gap:12px;align-items:start;display:grid;gap:12px;grid-template-columns:1fr}.warden-sidebar{height:auto;left:auto;margin-bottom:0;max-height:none;min-height:auto;overflow:visible;position:static;width:100%}.warden-main-content{margin-left:0}.staff-grid,.today-grid{grid-template-columns:1fr}.past-summaries-grid .past-search-card,.today-movements-grid .returned-students-card{grid-column:auto}}@media (max-width:760px){.warden-container{padding:10px 12px 18px}.search-input-row{flex-direction:column}.search-input-row .primary-btn{width:100%}.reset-password-fields{grid-template-columns:1fr}}.security-dashboard{color:var(--text);min-height:100vh;padding:6px 0 14px}.security-dashboard h1{color:#f8fafc;font-size:clamp(1.55rem,2.7vw,2.1rem);margin:0}.security-logout-btn{background:#dc262633;border:1px solid #f87171b3;border-radius:10px;color:#fee2e2;cursor:pointer;font-size:.84rem;font-weight:600;padding:9px 14px;transition:.18s ease;width:fit-content}.security-logout-btn:hover{background:#dc26264d}.security-bottom-actions{display:flex;justify-content:flex-end;margin-top:16px}.security-top{grid-gap:14px;align-items:start;display:grid;gap:14px;grid-template-columns:minmax(0,1fr) auto minmax(260px,320px);margin-bottom:16px}.security-summary{display:flex;gap:10px}.security-summary-card{background:var(--panel-soft);border:1px solid #94a3b852;border-radius:10px;min-width:112px;padding:10px 12px}.security-summary-card h3{color:var(--text-muted);font-size:.68rem;letter-spacing:.03em;margin:0;text-transform:uppercase}.security-summary-card p{font-size:1.28rem;font-weight:700;margin:5px 0 0}.search-section h2{font-size:.86rem;margin:0 0 6px}.search-section input{background:#0f172a;border:1px solid #475569e6;border-radius:10px;color:var(--text);padding:10px 12px;width:100%}.search-section input:focus{border-color:#3b82f6b8;box-shadow:0 0 0 3px #3b82f62e;outline:none}.search-feedback{color:#fb923c;font-size:.75rem;margin-top:6px}.security-content{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(2,minmax(0,1fr))}.security-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-soft);padding:16px}.security-card h2{color:#f8fafc;font-size:1.02rem;margin:0}.security-empty{color:var(--text-muted);font-size:.88rem}.outings-list{display:flex;flex-direction:column;gap:10px;margin-top:12px}.outing-card{border:1px solid #94a3b847;border-radius:12px;padding:12px}.outing-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.outing-header h3{font-size:1rem;font-weight:600;margin:0}.student-id{color:var(--text-subtle);font-size:.72rem}.outing-details{color:#cbd5e1;font-size:.82rem}.outing-details p{margin:3px 0}.checkin-btn,.checkout-btn{border:none;border-radius:999px;cursor:pointer;font-size:.76rem;font-weight:700;margin-top:8px;padding:8px 12px;transition:.18s ease}.checkout-btn{background:#ea580ceb;color:#fff}.checkout-btn:hover{background:#c6410c}.checkin-btn{background:#22c55ee6;color:#052e16}.checkin-btn:hover{background:#16a34a}@media (max-width:1080px){.security-content,.security-top{grid-template-columns:1fr}}.outing-card{background:var(--panel-soft);border:1px solid #64748b57;border-radius:var(--radius-md);box-shadow:var(--shadow-soft);margin:22px auto 0;padding:24px;width:min(660px,100%)}.outing-status-banner{border-radius:10px;font-size:.9rem;font-weight:600;margin:14px auto 0;padding:10px 14px;text-align:center;width:min(660px,100%)}.outing-status-banner.success{background:#22c55e2e;border:1px solid #22c55e73;color:#86efac}.outing-status-banner.error{background:#ef44442e;border:1px solid #ef444473;color:#fca5a5}.outing-card form{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr}.outing-card label{color:#cbd5e1;font-size:.88rem;font-weight:500}.outing-card input,.outing-card select{background:#0f172a;border:1px solid #475569e6;border-radius:10px;color:#f8fafc;padding:10px 12px}.outing-card input:focus,.outing-card select:focus{border-color:#38bdf8b3;box-shadow:0 0 0 3px #0ea5e924;outline:none}.type-options{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr))}.type-option{background:#0f172a;border:1px solid #475569e6;border-radius:10px;color:#cbd5e1;cursor:pointer;padding:10px 12px;transition:.18s ease}.type-option:hover{border-color:#60a5faad;color:#e2e8f0}.type-option.active{background:#2563eb3d;border-color:#60a5fac7;color:#dbeafe}.outing-card input::placeholder{color:#94a3b8}.checkbox-row{align-items:center;color:#cbd5e1;display:flex;gap:10px;margin-top:2px}.outing-card .submit-btn{background:#2563eb42;border:1px solid #2563eb8f;border-radius:10px;color:#dbeafe;cursor:pointer;font-weight:600;margin-top:4px;padding:11px 12px;transition:.18s ease}.outing-card .submit-btn:hover{background:#2563eb57}@media (max-width:720px){.outing-card{padding:18px}}.requests-table{background:var(--panel-soft);border:1px solid #64748b57;border-radius:var(--radius-md);box-shadow:var(--shadow-soft);margin-top:22px;overflow-x:auto;padding:16px}.request-status-banner{border-radius:10px;font-size:.86rem;font-weight:600;margin-top:14px;padding:10px 14px}.request-status-banner.success{background:#22c55e29;border:1px solid #4ade8073;color:#86efac}.request-status-banner.error{background:#ef444424;border:1px solid #f8717173;color:#fca5a5}.cancel-confirm-box{align-items:center;background:var(--panel-soft);border:1px solid #94a3b852;border-radius:10px;display:flex;gap:12px;justify-content:space-between;margin-top:14px;padding:12px 14px}.cancel-confirm-box p{color:var(--text);font-size:.86rem;font-weight:600;margin:0}.cancel-confirm-actions{align-items:center;display:flex;gap:8px}.cancel-confirm-btn{background:#0000;border:1px solid #94a3b885;border-radius:8px;color:#cbd5e1;cursor:pointer;font-size:.76rem;font-weight:600;padding:6px 10px}.cancel-confirm-btn-danger{background:#dc262633;border-color:#f8717185;color:#fecaca}.cancel-confirm-btn:disabled{cursor:not-allowed;opacity:.7}.requests-table table{border-collapse:collapse;color:var(--text);min-width:720px;width:100%}.requests-table td,.requests-table th{border-bottom:1px solid #94a3b824;padding:11px 10px;text-align:left}.requests-table th{color:var(--text-muted);font-size:.78rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase}.status{align-items:center;border-radius:999px;display:inline-flex;font-size:.75rem;font-weight:600;padding:5px 10px}.status.pending_parent{background:#f59e0b2e;color:#fcd34d}.status.pending_warden{background:#6366f133;color:#c7d2fe}.status.approved{background:#22c55e2e;color:#86efac}.status.rejected_by_parent,.status.rejected_by_warden{background:#ef444433;color:#fecaca}.status.student_left{background:#06b6d433;color:#67e8f9}.status.student_returned{background:#a855f733;color:#d8b4fe}.status.cancelled{background:#94a3b833;color:#cbd5e1}.cancel-request-btn{background:#dc262633;border:1px solid #f8717185;border-radius:8px;color:#fecaca;cursor:pointer;font-size:.76rem;font-weight:600;padding:6px 10px;transition:background .18s ease,border-color .18s ease}.cancel-request-btn:hover:not(:disabled){background:#dc262647;border-color:#f87171b8}.cancel-request-btn:disabled{cursor:not-allowed;opacity:.7}.action-muted{color:var(--text-subtle)}.timeline-card{background:var(--panel-soft);border:1px solid #64748b59;border-radius:var(--radius-md);box-shadow:var(--shadow-soft);margin-top:18px;padding:18px}.timeline-card h3{color:#f8fafc;font-size:1.05rem;margin:0}.timeline{border-left:2px solid #60a5fa73;margin-top:18px;padding-left:28px;position:relative}.timeline-item{margin-bottom:16px;position:relative}.timeline-item:last-child{margin-bottom:0}.timeline-dot{background:#3b82f6;border-radius:50%;box-shadow:0 0 0 4px #3b82f629;height:14px;left:-8px;position:absolute;top:6px;width:14px}.timeline-content{background:var(--panel);border:1px solid #94a3b833;border-radius:10px;padding:12px 14px}.timeline-content h4{color:#f8fafc;font-size:.95rem;margin:0}.timeline-content p{color:var(--text-muted);font-size:.85rem;line-height:1.5;margin:6px 0}.timeline-content span{color:var(--text-subtle);font-size:.76rem}.App{background:radial-gradient(circle at top,#1e40af14,#0000 40%),var(--bg)}.App,.layout{min-height:100vh}.layout{display:flex;flex-direction:column}.main-content{flex:1 1;padding:24px 0 30px}.footer,.main-content{margin:0 auto;width:min(1220px,100% - 40px)}.footer{border-top:1px solid var(--border);padding:18px 0 28px}.footer p{color:var(--text-subtle);font-size:.85rem;margin:0;text-align:center}.loading{color:var(--text-muted);display:grid;min-height:calc(100vh - 84px);place-items:center}@media (max-width:720px){.footer,.main-content{width:min(1220px,100% - 24px)}}
/*# sourceMappingURL=main.8b30a9b6.css.map*/