*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--clr-primary: #2563eb;--clr-primary-hover: #1d4ed8;--clr-danger: #dc2626;--clr-danger-hover: #b91c1c;--clr-bg: #f8fafc;--clr-surface: #ffffff;--clr-border: #e2e8f0;--clr-text: #1e293b;--clr-muted: #94a3b8;--radius: 8px}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--clr-bg);color:var(--clr-text);line-height:1.6}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh}.login-card{background:var(--clr-surface);padding:2.5rem;border-radius:var(--radius);box-shadow:0 4px 24px #00000014;width:100%;max-width:400px}.login-card h1{font-size:1.75rem;margin-bottom:.25rem}.login-card .subtitle{color:var(--clr-muted);margin-bottom:1.5rem}.demo-cta-btn{width:100%;padding:.75rem 1rem;background:var(--clr-primary);color:#fff;font-size:1rem;font-weight:700;border:none;border-radius:var(--radius);cursor:pointer;margin-bottom:1rem;transition:background .15s,transform .1s}.demo-cta-btn:hover{background:#1d4ed8;transform:translateY(-1px)}.demo-role-picker{background:#eff6ff;border:1px solid #bfdbfe;border-radius:var(--radius);padding:1rem 1.25rem;margin-bottom:1rem}.demo-role-title{font-size:.85rem;font-weight:600;color:#1e40af;margin:0 0 .75rem;text-align:center}.demo-role-cards{display:flex;flex-direction:column;gap:.6rem}.demo-role-card{display:flex;flex-direction:column;align-items:flex-start;gap:.2rem;background:#fff;border:1px solid #93c5fd;border-radius:var(--radius);padding:.65rem .9rem;cursor:pointer;text-align:left;transition:background .15s,border-color .15s,transform .1s}.demo-role-card:hover{background:#dbeafe;border-color:var(--clr-primary);transform:translate(2px)}.demo-role-icon{font-size:1.25rem}.demo-role-card strong{font-size:.88rem;color:#1e40af}.demo-role-desc{font-size:.75rem;color:var(--clr-muted);line-height:1.4}.demo-back-btn{background:none;border:none;font-size:.78rem;color:var(--clr-muted);cursor:pointer;padding:.4rem 0;margin-top:.5rem}.demo-back-btn:hover{color:var(--clr-primary)}.demo-loading{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.25rem 0;color:var(--clr-muted);font-size:.85rem}.demo-spinner{width:28px;height:28px;border:3px solid #bfdbfe;border-top-color:var(--clr-primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.demo-switcher-bar{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;background:#fefce8;border-bottom:1px solid #fde047;padding:.45rem 1.25rem;font-size:.8rem}.demo-switcher-label{font-weight:700;color:#854d0e;margin-right:.25rem}.demo-switcher-hint{color:#a16207;margin-right:.1rem}.demo-switcher-btn{background:#fff;color:#854d0e;border:1px solid #fde047;padding:.2rem .65rem;border-radius:999px;font-size:.78rem;cursor:pointer;transition:background .15s,border-color .15s}.demo-switcher-btn:hover{background:#fef9c3;border-color:#facc15}.demo-switcher-btn.active{background:#fde047;border-color:#eab308;font-weight:700}.login-divider{display:flex;align-items:center;gap:.75rem;margin:1.25rem 0;color:var(--clr-muted);font-size:.8rem}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--clr-border)}label{display:flex;flex-direction:column;gap:.25rem;font-size:.875rem;font-weight:500;margin-bottom:1rem}input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],input[type=time],select,textarea{padding:.55rem .75rem;border:1px solid var(--clr-border);border-radius:var(--radius);font-size:.95rem;width:100%;transition:border-color .15s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--clr-primary);box-shadow:0 0 0 3px #2563eb26}button{padding:.6rem 1.25rem;border:none;border-radius:var(--radius);font-size:.95rem;font-weight:600;cursor:pointer;background:var(--clr-primary);color:#fff;transition:background .15s}button:hover{background:var(--clr-primary-hover)}button:disabled{opacity:.6;cursor:not-allowed}.btn-danger{background:var(--clr-danger);padding:.35rem .75rem;font-size:.8rem}.btn-danger:hover{background:var(--clr-danger-hover)}.btn-link{background:none;color:var(--clr-primary);padding:0;font-weight:500}.btn-link:hover{text-decoration:underline;background:none}.error{color:var(--clr-danger);font-size:.875rem}.success{color:#16a34a;font-size:.875rem}.muted{color:var(--clr-muted)}.topbar{display:flex;align-items:center;justify-content:space-between;background:var(--clr-surface);padding:.75rem 1.5rem;border-bottom:1px solid var(--clr-border)}.topbar-left{display:flex;align-items:center;gap:1rem}.topbar-left h2{font-size:1.15rem}.topbar-nav{display:flex;gap:.75rem;margin-left:1rem}.topbar-nav a{padding:.35rem .5rem;border-radius:var(--radius);min-height:36px;display:inline-flex;align-items:center}.hamburger{background:none;border:none;font-size:1.5rem;padding:.25rem .5rem;cursor:pointer;color:var(--clr-text);margin-left:auto}.hamburger:hover{background:#f1f5f9}.mobile-menu{display:flex;flex-direction:column;background:var(--clr-surface);border-bottom:1px solid var(--clr-border);box-shadow:0 4px 12px #00000014}.mobile-menu a{display:flex;align-items:center;padding:.85rem 1.25rem;text-decoration:none;font-size:1rem;font-weight:500;color:var(--clr-muted);border-bottom:1px solid var(--clr-border);min-height:48px}.mobile-menu a.active{color:var(--clr-primary);background:#eff6ff;font-weight:600}.mobile-menu a:hover{background:#f8fafc}.mobile-menu-footer{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;font-size:.9rem;color:var(--clr-muted)}.role-badge{font-size:.8rem;padding:.2rem .6rem;background:#eff6ff;border-radius:12px;color:var(--clr-primary)}.topbar-right{display:flex;align-items:center;gap:1rem;font-size:.9rem}.main-content{max-width:960px;margin:2rem auto;padding:0 1.5rem}table{width:100%;border-collapse:collapse;margin-top:1rem;background:var(--clr-surface);border-radius:var(--radius);overflow:hidden;box-shadow:0 1px 4px #0000000a}section{overflow-x:auto}th,td{text-align:left;padding:.6rem .75rem;border-bottom:1px solid var(--clr-border);font-size:.9rem}th{background:#f1f5f9;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.03em}.tabs{display:flex;gap:.25rem;margin-bottom:1.5rem;border-bottom:2px solid var(--clr-border)}.tabs button{background:none;color:var(--clr-muted);padding:.6rem 1rem;border-radius:0;border-bottom:2px solid transparent;margin-bottom:-2px;font-size:.9rem}.tabs button.active{color:var(--clr-primary);border-bottom-color:var(--clr-primary)}.tabs button:hover{color:var(--clr-text);background:none}.form-row{display:flex;gap:1rem}.form-row>label{flex:1}.checkbox-label{flex-direction:row!important;align-items:center;gap:.5rem}.checkbox-label input{width:auto}.inline-form{display:flex;gap:.5rem;margin-bottom:1rem}.inline-form input{flex:1}.pref-form{background:var(--clr-surface);padding:1.5rem;border-radius:var(--radius);box-shadow:0 1px 4px #0000000a;margin-bottom:2rem}.loading{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--clr-muted)}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--clr-surface);padding:2rem;border-radius:var(--radius);box-shadow:0 8px 32px #00000026;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-content h3{margin-bottom:1rem}.fc{font-family:inherit}.fc .fc-button{font-size:.85rem;padding:.35rem .75rem}.fc .fc-toolbar-title{font-size:1.15rem}.fc .fc-event{cursor:pointer;border-radius:4px;font-size:.8rem;padding:1px 4px}.empty{padding:2rem;text-align:center;color:var(--clr-muted)}.mobile-tab-select{width:100%;padding:.75rem 1rem;font-size:1rem;font-weight:600;border:2px solid var(--clr-primary);border-radius:var(--radius);background:var(--clr-surface);color:var(--clr-primary);appearance:auto;margin-bottom:1rem;min-height:48px}@media(max-width:768px){.topbar{flex-direction:row;align-items:center;padding:.75rem 1rem}.topbar-left{flex:1;display:flex;align-items:center;gap:.5rem}.main-content{padding:0 .75rem;margin:1rem auto}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:0;padding-bottom:0}.tabs button{white-space:nowrap;flex-shrink:0;padding:.6rem .9rem;font-size:.9rem;min-height:44px}.form-row{flex-direction:column;gap:0}.inline-form{flex-direction:column}.pref-form{padding:1rem}th,td{padding:.4rem .5rem;font-size:.8rem}th{font-size:.7rem}.login-card{margin:1rem;padding:1.5rem}.modal-content{margin:1rem;padding:1.25rem;max-height:85vh}button{padding:.5rem 1rem;font-size:.85rem}.fc .fc-toolbar{flex-direction:column;gap:.5rem}.fc .fc-toolbar-title{font-size:1rem}.fc .fc-button{font-size:.75rem;padding:.25rem .5rem}}@media(max-width:480px){.main-content{padding:0 .5rem}.topbar-left h2{font-size:1rem}th,td{padding:.3rem .35rem;font-size:.75rem}.tabs button{font-size:.85rem;padding:.55rem .75rem;min-height:44px}}
