@import "https://fonts.googleapis.com/css2?family=Sora:wght@500;600;700;800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&display=swap";:root{--ucb-blue:#063f77;--ucb-blue-700:#0a3559;--ucb-blue-500:#1260aa;--ucb-blue-deep:#041f3a;--ucb-gold:#f4c542;--ucb-gold-strong:#d89b00;--ucb-gold-light:#fef3c7;--ink-900:#0d223d;--ink-800:#19324f;--ink-700:#3d5676;--ink-500:#6580a0;--surface-100:#fff;--surface-200:#f5f8fc;--surface-300:#edf3f8;--line-300:#d8e2ee;--line-200:#e8eef6;--radius-xs:6px;--radius-sm:10px;--radius-md:16px;--radius-lg:22px;--radius-xl:32px;--shadow-soft:0 22px 52px #06305924;--shadow-subtle:0 10px 26px #0d223d14;--shadow-card:0 18px 42px #0d223d17;--shadow-gold:0 8px 24px #f4c5424d;--shadow-blue:0 8px 24px #063f7740;--font-body:"DM Sans", "Segoe UI", sans-serif;--font-display:"Sora", "DM Sans", sans-serif;--font-ui:"DM Sans", "Segoe UI", sans-serif;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.22s cubic-bezier(.4, 0, .2, 1);--transition-slow:.35s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box}html,body,#root{min-height:100svh}body{font-family:var(--font-body);color:var(--ink-900);letter-spacing:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(circle at 12% 8%,#f4c5422e,#0000 28%),radial-gradient(circle at 86% 0,#063f771f,#0000 26%),linear-gradient(135deg,#eef4f9 0%,#f8fbff 52%,#eef5fb 100%);margin:0;font-size:16px;line-height:1.58}h1,h2,h3,h4,p{margin:0}a{color:inherit}button,input,select,textarea{font-family:var(--font-body)}button{letter-spacing:0}:where(.infra-header h2,.profiles-header h2,.roles-header h2,.reservations-header h2,.tutorials-header h2,.home-modern-hero h1,.home-placeholder h2,.login-card h1){font-family:var(--font-ui);letter-spacing:-.015em!important;line-height:1.14!important}:where(.infra-kicker,.profiles-kicker,.roles-header-kicker,.reservations-kicker,.tutorials-kicker,.home-modern-kicker,.login-brand-kicker,.reservation-modal-kicker,.tutorial-detail-kicker,.reservation-user-card-kicker){font-family:var(--font-ui);letter-spacing:.07em!important}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline-offset:2px;outline:3px solid #f4c542cc}::selection{color:var(--ink-900);background:#f4c54273}.content-window>:is(.infra-page,.profiles-page,.roles-page,.reservations-page,.tutorials-page){min-height:100%;font-family:var(--font-ui);background:radial-gradient(circle at 88% 4%,#f4c54229,#0000 30%),radial-gradient(circle at 8% 12%,#063f771a,#0000 28%),linear-gradient(135deg,#f6f9fd 0%,#eef5fb 100%)}.infra-header,.profiles-header,.roles-header,.reservations-header,.tutorials-header{background:radial-gradient(circle at 88% 4%,#ffbc6e47,#0000 28%),radial-gradient(circle at 0 100%,#ffffff14,#0000 34%),linear-gradient(105deg,#082436 0%,#0d3d61 52%,#1b5f87 100%);border:1px solid #ffffff57;border-radius:clamp(28px,3vw,38px);margin:clamp(14px,2vw,24px);position:relative;overflow:hidden;box-shadow:0 28px 62px #061c3033}.infra-header:before,.profiles-header:before,.roles-header:before,.reservations-header:before,.tutorials-header:before{content:"";pointer-events:none;background:#ffffff12;border-radius:999px;width:260px;height:260px;position:absolute;top:-120px;right:-80px}.infra-header:after,.profiles-header:after,.roles-header:after,.reservations-header:after,.tutorials-header:after{content:"";pointer-events:none;background:#ffffff0b;border-radius:999px;width:180px;height:180px;position:absolute;bottom:-90px;left:-56px}.infra-header>*,.profiles-header>*,.roles-header>*,.reservations-header>*,.tutorials-header>*{z-index:1;position:relative}.infra-kicker,.profiles-kicker,.roles-header-kicker,.reservations-kicker,.tutorials-kicker{color:#ffbc6e;font-family:var(--font-ui);letter-spacing:.08em;font-weight:800}.infra-header h2,.profiles-header h2,.roles-header h2,.reservations-header h2,.tutorials-header h2{font-family:var(--font-ui);letter-spacing:-.02em;font-weight:800;line-height:1.12}.infra-summary div,.profiles-summary div,.reservations-summary div,.tutorials-summary div{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff1f;border:1px solid #fff3;border-radius:22px;box-shadow:0 18px 34px #0000001a}.infra-grid,.profiles-grid,.roles-body,.reservations-page,.tutorials-page{gap:clamp(18px,2.6vw,30px)}.ux-extra-toggle{background:linear-gradient(#ffffffeb,#f7fbfff0);border:1px solid #0a355924;border-radius:18px;box-shadow:0 12px 28px #0d223d14}.ux-extra-toggle>summary{cursor:pointer;color:var(--ink-900);justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;font-weight:700;list-style:none;display:flex}.ux-extra-toggle>summary::-webkit-details-marker{display:none}.ux-extra-toggle>summary:after{content:"Mostrar";color:var(--ink-700);font-size:.8rem;font-weight:600}.ux-extra-toggle[open]>summary:after{content:"Ocultar"}.ux-extra-toggle-content{border-top:1px solid #0a355914;padding:0 16px 16px}.infra-card,.profiles-card,.roles-form-card,.roles-permissions-panel,.roles-matrix-container,.reservations-panel,.tutorials-panel,.home-modern-section,.home-role-panel{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:radial-gradient(circle at 94% 0,#f4c5421a,#0000 28%),#ffffffeb;border:1px solid #e2edf2f5;border-radius:clamp(24px,2.4vw,34px);box-shadow:0 22px 48px #0d223d1a}.infra-card,.profiles-card,.roles-form-card,.reservations-panel,.tutorials-panel,.home-feature-card,.home-modern-labs article{transition:transform .18s,box-shadow .18s,border-color .18s}.infra-card:hover,.profiles-card:hover,.roles-form-card:hover,.reservations-panel:hover,.tutorials-panel:hover{border-color:#1f639238;box-shadow:0 30px 62px #0d223d21}.infra-form input,.infra-form select,.infra-form textarea,.profiles-form input,.profiles-form select,.roles-input,.reservations-controls input,.reservations-controls select,.reservations-form input,.reservations-form select,.reservations-form textarea,.reservation-modal-form input,.reservation-modal-form select,.reservation-modal-form textarea,.tutorials-form input,.tutorials-form select,.tutorials-form textarea,.login-form input{background:#ffffffe0;border:1.5px solid #d8e2eefa;border-radius:16px;min-height:46px;box-shadow:inset 0 1px #ffffffb3}.infra-form input:focus,.infra-form select:focus,.infra-form textarea:focus,.profiles-form input:focus,.profiles-form select:focus,.roles-input:focus,.reservations-controls input:focus,.reservations-controls select:focus,.reservations-form input:focus,.reservations-form select:focus,.reservations-form textarea:focus,.reservation-modal-form input:focus,.reservation-modal-form select:focus,.reservation-modal-form textarea:focus,.tutorials-form input:focus,.tutorials-form select:focus,.tutorials-form textarea:focus,.login-form input:focus{background:#fff;border-color:#1f639294;box-shadow:0 0 0 4px #1f63921a,inset 0 1px #fffc}.infra-primary,.profiles-primary,.roles-save-button,.reservations-primary,.reservation-modal-primary,.tutorials-primary,.login-button,.home-modern-primary{background:linear-gradient(135deg,#0a2b3e 0%,#1b4f6e 100%);border-radius:999px;box-shadow:0 14px 28px #0d3d6133}.infra-secondary,.profiles-secondary,.roles-tab-button,.reservations-secondary,.reservation-modal-secondary,.tutorials-secondary,.home-modern-secondary,.infra-danger,.profiles-danger,.reservations-danger,.tutorials-danger{border-radius:999px}.infra-primary:hover,.profiles-primary:hover,.roles-save-button:hover:not(:disabled),.reservations-primary:hover,.reservation-modal-primary:hover,.tutorials-primary:hover,.login-button:hover,.infra-secondary:hover,.profiles-secondary:hover,.reservations-secondary:hover,.reservation-modal-secondary:hover,.tutorials-secondary:hover{transform:translateY(-2px);box-shadow:0 20px 36px #0d223d29}.infra-table-wrap,.profiles-list,.roles-matrix-container,.reservations-table,.tutorials-grid{border-radius:22px}.infra-table th,.reservations-table th{color:#0e3b4f;background:linear-gradient(#0a2b3e14,#0a2b3e08)}.reservation-modal,.tutorial-detail-modal,.penalty-modal,.confirm-modal,.infra-workflow-modal,.loan-return-modal{background:radial-gradient(circle at 92% 0,#f4c54233,#0000 30%),linear-gradient(#fff 0%,#f8fbff 100%);border:1px solid #ffffff9e;border-radius:clamp(26px,3vw,40px);box-shadow:0 44px 92px #07132257}.reservation-modal-backdrop,.tutorial-detail-backdrop,.penalty-backdrop,.confirm-modal-backdrop,.infra-workflow-backdrop,.loan-return-backdrop{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:radial-gradient(circle at 50% 12%,#f4c54229,#0000 30%),#071322a8}.reservations-slot,.tutorial-slot,.cal-day,.profiles-item,.roles-role-card,.tutorial-card,.reservation-user-card,.penalty-card,.infra-action-card{border-radius:22px}.reservations-slot.tutorial,.tutorial-slot.tutorial{color:#0a2b3e;background:linear-gradient(90deg,#0a2b3e29,#1f63920f);border-left-color:#0a2b3e}@media (width<=760px){.infra-header,.profiles-header,.roles-header,.reservations-header,.tutorials-header{border-radius:26px;margin:12px}.infra-grid,.profiles-grid,.roles-body{padding:14px}.infra-summary,.profiles-summary,.reservations-summary,.tutorials-summary{justify-content:stretch;width:100%}.infra-summary div,.profiles-summary div,.reservations-summary div,.tutorials-summary div{flex:130px}}.field-invalid .field-wrap,.field-wrap.is-invalid{border-color:#b91c1c80!important;box-shadow:0 0 0 3px #b91c1c1a,inset 0 1px #ffffffb3!important}.field-valid .field-wrap,.field-wrap.is-valid{border-color:#16a34a73!important;box-shadow:0 0 0 3px #16a34a14,inset 0 1px #ffffffb3!important}.field-hint{transition:color var(--transition-fast);margin:3px 0 0 2px;font-size:.78rem;font-weight:500}.field-hint.is-muted{color:var(--ink-500)}button:disabled{opacity:.45;cursor:not-allowed;box-shadow:none!important;transform:none!important}@keyframes pageIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.animate-page-in{animation:pageIn .3s var(--transition-base) both}.badge{border-radius:999px;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 6px;font-size:.72rem;font-weight:700;line-height:1;display:inline-flex}.badge-gold{background:var(--ucb-gold);color:var(--ucb-blue-deep)}.badge-blue{background:var(--ucb-blue);color:#fff}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#063f7733 padding-box padding-box;border:2px solid #0000;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:#063f775c padding-box padding-box}.auth-screen{box-sizing:border-box;background:radial-gradient(at 14% 16%,#f4c5422e,#0000 28%),radial-gradient(at 90% 8%,#ffffff14,#0000 26%),radial-gradient(at 60% 90%,#063f773d,#0000 36%),linear-gradient(150deg,#040e1e 0%,#063f77 55%,#0a5ea8 100%);place-items:center;min-height:100dvh;padding:clamp(20px,4vw,40px);display:grid;position:relative;overflow:hidden}.auth-blob{pointer-events:none;border-radius:50%;animation:8s ease-in-out infinite blobFloat;position:absolute}.auth-blob--tl{background:radial-gradient(circle,#f4c5421a 0%,#0000 70%);width:420px;height:420px;animation-delay:0s;top:-160px;left:-120px}.auth-blob--br{background:radial-gradient(circle,#1260aa33 0%,#0000 70%);width:340px;height:340px;animation-delay:-3s;bottom:-120px;right:-80px}.auth-blob--center{background:radial-gradient(circle,#ffffff08 0%,#0000 70%);width:200px;height:200px;animation-delay:-1.5s;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes blobFloat{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-18px)scale(1.04)}}.login-card{-webkit-backdrop-filter:blur(20px);z-index:1;background:radial-gradient(circle at 94% 0,#f4c5421f,#0000 28%),#fffffff7;border:1px solid #ffffff24;border-radius:36px;flex-direction:column;gap:18px;width:100%;max-width:460px;padding:clamp(28px,5vw,44px);animation:.5s cubic-bezier(.34,1.56,.64,1) both cardIn;display:flex;position:relative;box-shadow:0 48px 96px #00000070,0 0 0 1px #ffffff1a,inset 0 1px #ffffffe6}@keyframes cardIn{0%{opacity:0;transform:translateY(32px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.login-brand{align-items:center;gap:16px;display:flex}.login-brand-logo-wrap{background:#fff;border-radius:20px;flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;padding:8px;display:flex;overflow:hidden;box-shadow:0 16px 32px #0d223d24,inset 0 1px #fffc}.login-brand-logo{object-fit:contain;width:100%;height:100%}.login-brand-text{flex-direction:column;gap:1px;display:flex}.login-brand-kicker{letter-spacing:.08em;text-transform:uppercase;color:var(--ucb-blue);font-size:.68rem;font-weight:700;font-family:var(--font-display);line-height:1.3;display:block}.login-brand-subtitle{color:var(--ink-700);font-size:.72rem;font-weight:500;line-height:1.3;display:block}.login-card h1{font-size:clamp(1.8rem,4vw,2.2rem);line-height:1.05;font-family:var(--font-display);color:var(--ink-900);letter-spacing:-.03em;margin:4px 0 0;font-weight:800}.login-subtitle{color:var(--ink-700);margin:-4px 0 0;font-size:.9rem;line-height:1.55}.login-mode-tabs{background:var(--surface-200);border:1px solid var(--line-200);border-radius:16px;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:4px;display:grid}.login-mode-tab{cursor:pointer;justify-content:center;align-items:center;gap:8px;display:flex;color:var(--ink-700)!important;box-shadow:none!important;transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast)!important;background:0 0!important;border:1px solid #0000!important;border-radius:12px!important;margin:0!important;padding:11px 16px!important;font-size:.875rem!important;font-weight:600!important}.login-mode-tab:hover:not(:disabled){color:var(--ink-900)!important;background:#fffc!important;transform:none!important}.login-mode-tab.is-active{color:var(--ucb-blue)!important;border-color:var(--line-300)!important;background:#fff!important;font-weight:700!important;box-shadow:0 2px 8px #0d223d1a!important}.login-mode-tab:disabled{opacity:.4;cursor:not-allowed}.credentials-form{gap:14px;display:grid}.form-field{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--ink-900);letter-spacing:.01em;font-size:.84rem;font-weight:600}.field-wrap{border:1.5px solid var(--line-300);width:100%;transition:border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);background:#fff;border-radius:14px;align-items:center;gap:10px;min-height:50px;padding:0 14px;display:flex}.field-wrap:focus-within{background:#fff;border-color:#063f778c;box-shadow:0 0 0 4px #063f771a,inset 0 1px #ffffffe6}.field-wrap.is-valid{border-color:#16a34a80;box-shadow:0 0 0 3px #16a34a14}.field-wrap.is-invalid{border-color:#b91c1c80;box-shadow:0 0 0 3px #b91c1c14}.field-wrap input{font:inherit;font-family:var(--font-body);color:var(--ink-900);background:0 0;border:none;flex:1;min-width:0;padding:14px 0;font-size:.9rem}.field-wrap input::placeholder{color:var(--ink-500);font-size:.85rem}.field-wrap input:focus{outline:none}.field-hint{transition:color var(--transition-fast);margin:0;padding-left:2px;font-size:.78rem;font-weight:500}.field-hint.is-error{color:#b91c1c}.field-hint.is-ok{color:#15803d}.password-toggle{cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;display:flex;color:var(--ink-700)!important;box-shadow:none!important;transition:color var(--transition-fast), background var(--transition-fast)!important;background:0 0!important;border:none!important;border-radius:6px!important;margin:0!important;padding:6px!important}.password-toggle:hover{color:var(--ucb-blue)!important;background:#063f7714!important;transform:none!important}.credentials-submit{letter-spacing:.02em;cursor:pointer;width:100%;min-height:50px;color:#fff!important;transition:opacity var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast)!important;background:linear-gradient(135deg,#041f3a 0%,#063f77 50%,#1260aa 100%)!important;border:none!important;border-radius:16px!important;justify-content:center!important;align-items:center!important;gap:8px!important;margin-top:4px!important;padding:14px 20px!important;font-size:.95rem!important;font-weight:700!important;display:flex!important;box-shadow:0 8px 24px #063f774d!important}.credentials-submit:hover:not(:disabled){transform:translateY(-2px)!important;box-shadow:0 16px 36px #063f7761!important}.credentials-submit:active:not(:disabled){transform:translateY(0)!important}.credentials-submit:disabled{opacity:.5!important;cursor:not-allowed!important;transform:none!important;box-shadow:0 4px 12px #063f7726!important}.submit-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:16px;height:16px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.auth-error{color:#7f1d1d;background:#b91c1c14;border:1px solid #b91c1c2e;border-radius:12px;margin:0;padding:11px 14px;font-size:.88rem;font-weight:500;line-height:1.45;animation:.2s both fadeUp}.google-login-block{flex-direction:column;gap:10px;display:flex}.google-button-host{border-radius:12px;justify-content:center;width:100%;min-height:44px;display:flex;overflow:hidden}.google-helper{color:var(--ink-700);text-align:center;margin:0;font-size:.83rem;line-height:1.5}.google-local-warning{background:#f4c5421a;border:1px solid #f4c5424d;border-radius:14px;gap:8px;padding:14px 16px;display:grid}.google-loading{justify-content:center;align-items:center;gap:6px;padding:18px;display:flex}.google-loading-dot{background:var(--ucb-blue);opacity:.3;border-radius:50%;width:8px;height:8px;animation:1.2s ease-in-out infinite dotPulse}.google-loading-dot:nth-child(2){animation-delay:.2s}.google-loading-dot:nth-child(3){animation-delay:.4s}@keyframes dotPulse{0%,to{opacity:.25;transform:scale(.9)}50%{opacity:1;transform:scale(1.1)}}.login-footer-note{text-align:center;color:var(--ink-500);border-top:1px solid var(--line-200);margin:0;padding-top:4px;font-size:.75rem}@media (width<=480px){.login-card{border-radius:24px;gap:14px;padding:24px 20px}.login-brand{flex-direction:column;align-items:flex-start;gap:12px}.login-brand-logo-wrap{border-radius:16px;width:60px;height:60px}.login-card h1{font-size:1.7rem}}.confirm-modal-open{overflow:hidden}.confirm-backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:100;background:#00000073;place-items:center;min-height:100dvh;padding:16px;animation:.18s confirm-fade-in;display:grid;position:fixed;inset:0;overflow-y:auto}@keyframes confirm-fade-in{0%{opacity:0}to{opacity:1}}.confirm-modal{text-align:center;background:#fff;border-radius:20px;flex-direction:column;align-items:center;gap:12px;width:min(400px,100%);max-height:calc(100dvh - 32px);margin:auto;padding:32px 28px 24px;animation:.2s cubic-bezier(.34,1.56,.64,1) confirm-slide-up;display:flex;overflow-y:auto;box-shadow:0 24px 48px #0000002e,0 0 0 1px #0000000d}@keyframes confirm-slide-up{0%{opacity:0;transform:translateY(16px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.confirm-icon{color:#b91c1c;background:#b91c1c1a;border:2px solid #b91c1c33;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;margin-bottom:4px;font-size:1.6rem;font-weight:900;display:flex}.confirm-title{font-size:1.05rem;font-family:var(--font-display);color:var(--ink-900);margin:0}.confirm-message{color:var(--ink-700);max-width:320px;margin:0;font-size:.9rem;line-height:1.55}.confirm-actions{gap:10px;width:100%;margin-top:8px;display:flex}.confirm-cancel,.confirm-ok{font:inherit;cursor:pointer;border:none;border-radius:10px;flex:1;padding:11px 16px;font-size:.88rem;font-weight:700;transition:background .15s,opacity .15s,transform .1s}.confirm-cancel:active,.confirm-ok:active{transform:scale(.97)}.confirm-cancel{color:var(--ink-900);background:#0a254012;border:1px solid #0a25401f}.confirm-cancel:hover{background:#0a25401f}.confirm-ok{color:#fff;background:#b91c1c;box-shadow:0 2px 8px #b91c1c40}.confirm-ok:hover{background:#991b1b}.confirm-backdrop{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:radial-gradient(circle at 50% 18%,#f4c5422e,#0000 28%),#0713229e}.confirm-modal{background:radial-gradient(circle at 88% 0,#f4c54233,#0000 30%),linear-gradient(#fff 0%,#f8fbff 100%);border:1px solid #fff9;width:min(440px,100%);box-shadow:0 36px 72px #0713224d}.confirm-icon{background:radial-gradient(circle at 35% 25%,#ffffffe0,#0000 34%),linear-gradient(135deg,#b91c1c24,#f4c5422e);border-radius:22px;width:60px;height:60px;box-shadow:0 18px 30px #b91c1c1f}.confirm-title{font-size:1.35rem}.confirm-cancel,.confirm-ok{border-radius:14px;transition:transform .16s,box-shadow .16s,background .16s}.confirm-cancel:hover,.confirm-ok:hover{transform:translateY(-2px);box-shadow:0 18px 30px #0d223d24}.confirm-title{font-family:var(--font-display);letter-spacing:-.03em;font-weight:800}.confirm-message{font-family:var(--font-body)}.confirm-cancel,.confirm-ok{font-family:var(--font-ui)}.confirm-modal{border-radius:32px}.infra-page{flex:1;align-content:start;gap:0;display:grid}.infra-header{color:#fff;background:linear-gradient(135deg,#0a2540 0%,#0d3260 55%,#0a3d72 100%);grid-template-columns:1fr auto;align-items:center;gap:24px;padding:clamp(20px,2.8vw,32px) clamp(20px,3vw,40px);display:grid}.infra-kicker{text-transform:uppercase;letter-spacing:.12em;color:#fcd025cc;margin:0 0 6px;font-size:.72rem;font-weight:700}.infra-header h2{font-family:var(--font-display);margin:0 0 8px;font-size:clamp(1.6rem,2.8vw,2.2rem);line-height:1.1}.infra-header>div>p{color:#ffffffbf;margin:0;font-size:.95rem}.infra-summary{flex-wrap:wrap;justify-content:flex-end;gap:12px;display:flex}.infra-summary div{text-align:center;background:#ffffff1a;border:1px solid #ffffff1f;border-radius:14px;min-width:90px;padding:14px 20px}.infra-summary span{color:#ffffffa6;font-size:.78rem;display:block}.infra-summary strong{font-size:1.6rem;font-family:var(--font-display);margin-top:2px;display:block}.infra-alert{margin:0;padding:14px 20px;font-size:.92rem;font-weight:600}.infra-success{color:#166534;background:#15803d14;border-left:4px solid #16a34a}.infra-error{color:#7f1d1d;background:#b91c1c14;border-left:4px solid #dc2626}.infra-body{gap:24px;padding:clamp(16px,2.5vw,32px) clamp(16px,3vw,40px);display:grid}.infra-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-items:start;gap:24px;padding:clamp(16px,2.5vw,32px) clamp(16px,3vw,40px);display:grid}.infra-card{border:1px solid var(--line-300);background:#fff;border-radius:18px;gap:20px;padding:24px;display:grid;box-shadow:0 2px 12px #0a25400d}.infra-card-full{grid-column:1/-1}.infra-section-head h3{color:var(--ink-900);margin:0;font-size:1.05rem}.infra-section-head p{color:var(--ink-700);margin:4px 0 0;font-size:.88rem}.infra-form,.infra-list{gap:16px;display:grid}.infra-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.infra-form label{color:var(--ink-700);gap:6px;font-size:.86rem;font-weight:600;display:grid}.infra-form input,.infra-form select,.infra-form textarea{border:1.5px solid var(--line-300);width:100%;font:inherit;color:var(--ink-900);background:#fafbfc;border-radius:10px;padding:10px 12px;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.infra-form select[multiple]{min-height:118px;padding:8px}.infra-form label small,.infra-muted{color:var(--ink-700);margin:0;font-size:.8rem;font-weight:500;line-height:1.45}.infra-form input:focus,.infra-form select:focus,.infra-form textarea:focus{background:#fff;border-color:#064d9080;outline:none;box-shadow:0 0 0 3px #064d9014}.infra-form input:disabled,.infra-form select:disabled,.infra-form textarea:disabled{color:var(--ink-700);cursor:not-allowed;background:#f1f5f9}.infra-checkbox{cursor:pointer;align-items:center;gap:10px;display:flex!important}.infra-checkbox input{width:17px;height:17px;accent-color:var(--ucb-blue);cursor:pointer}.infra-actions{flex-wrap:wrap;gap:8px;display:flex}.infra-actions.compact{justify-content:flex-end}.infra-actions-start{justify-content:flex-start}.infra-primary,.infra-secondary,.infra-danger{font:inherit;cursor:pointer;white-space:nowrap;border:none;border-radius:10px;padding:9px 16px;font-size:.86rem;font-weight:700;transition:opacity .15s,transform .1s}.infra-primary:active,.infra-secondary:active,.infra-danger:active{transform:scale(.97)}.infra-primary{color:#fff;background:linear-gradient(135deg,#0a3559,#1255a0);box-shadow:0 2px 8px #0a355933}.infra-primary:hover{opacity:.9}.infra-primary:disabled{opacity:.45;cursor:not-allowed}.infra-secondary{color:var(--ink-900);background:#0a355912;border:1px solid #0a35591f}.infra-secondary:hover{background:#0a35591f}.infra-secondary:disabled{opacity:.45;cursor:not-allowed}.infra-danger{color:#b91c1c;background:#b91c1c14;border:1px solid #b91c1c24}.infra-danger:hover{background:#b91c1c24}.infra-danger:disabled{opacity:.45;cursor:not-allowed}.infra-item{background:#fafbfc;border:1px solid #0a355914;border-radius:12px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;padding:14px 16px;transition:background .15s,border-color .15s;display:grid}.infra-item:hover{background:#f0f6ff;border-color:#064d9026}.infra-item strong{color:var(--ink-900);font-size:.95rem}.infra-item p,.infra-item small{color:var(--ink-700);margin:3px 0 0;font-size:.82rem}.infra-table-wrap{border:1px solid var(--line-300);border-radius:12px;overflow-x:auto}.infra-table{border-collapse:collapse;width:100%;font-size:.88rem}.infra-table th{text-align:left;color:var(--ink-700);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--line-300);white-space:nowrap;background:#f8fafc;padding:11px 14px;font-size:.76rem;font-weight:700}.infra-table td{vertical-align:middle;color:var(--ink-900);border-bottom:1px solid #0a35590f;padding:12px 14px}.infra-table tbody tr:last-child td{border-bottom:none}.infra-table tbody tr:hover td{background:#f8fafc}.infra-table td small{color:var(--ink-700);margin-top:3px;font-size:.78rem;display:block}.infra-status-cell{gap:6px;min-width:200px;display:grid}.infra-status-badge{border-radius:999px;align-items:center;width:fit-content;padding:4px 10px;font-size:.78rem;font-weight:700;display:inline-flex}.infra-status-badge.available{color:#166534;background:#16a34a1a;border:1px solid #16a34a2e}.infra-status-badge.loaned{color:#9a3412;background:#ea580c1a;border:1px solid #ea580c2e}.infra-status-badge.maintenance{color:#0b4a6f;background:#064d901a;border:1px solid #064d902e}.infra-status-badge.damaged{color:#991b1b;background:#b91c1c1a;border:1px solid #b91c1c2e}.infra-status-badge.neutral{color:var(--ink-900);background:#0a355912;border:1px solid #0a35591a}.infra-history-row td{border-bottom:none;padding:0}.infra-history-panel{border-top:1px dashed var(--line-300);background:#f8fafc;padding:18px 20px 14px}.infra-history-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.infra-history-head strong{color:var(--ink-900);font-size:.92rem}.infra-history-head span{color:var(--ink-700);font-size:.82rem}.infra-history-list{gap:8px;display:grid}.infra-history-item{border:1px solid var(--line-300);background:#fff;border-radius:10px;grid-template-columns:minmax(0,1fr) minmax(160px,.7fr);gap:12px;padding:12px 14px;display:grid}.infra-history-item>div{gap:4px;display:grid}.infra-ticket-card{background:linear-gradient(#fff 0%,#f6f9fc 100%);border:1px solid #0a35591f;border-radius:16px;gap:12px;padding:18px;display:grid}.infra-ticket-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.infra-ticket-copy{color:var(--ink-800);background:#063f770a;border:1px solid #063f771a;border-radius:10px;margin:0;padding:10px 12px;font-size:.92rem;line-height:1.6}.infra-ticket-meta{color:var(--ink-700);gap:8px;font-size:.83rem;display:grid}.infra-ticket-meta span{background:#fff;border:1px solid #0a355914;border-radius:10px;padding:8px 10px;display:block}.infra-ticket-resolution{gap:8px;width:min(100%,720px);display:grid}.infra-ticket-resolution>span{color:var(--ink-700);font-size:.82rem;font-weight:700}.infra-ticket-resolution textarea{border:1.5px solid var(--line-300);width:100%;max-width:100%;min-height:92px;font:inherit;color:var(--ink-900);resize:vertical;background:#fff;border-radius:12px;padding:10px 12px;font-size:.9rem;line-height:1.45}.infra-ticket-resolution textarea:focus{border-color:#064d9080;outline:none;box-shadow:0 0 0 3px #064d9014}.infra-empty{color:var(--ink-700);border:1px solid var(--line-300);background:#f8fafc;border-radius:10px;margin:0;padding:16px 18px;font-size:.9rem}.infra-inline-error{color:#991b1b;background:#b91c1c12;border:1px solid #b91c1c1f;border-radius:10px;margin:0;padding:10px 14px;font-size:.88rem;font-weight:600}.infra-positive{color:#166534;font-weight:700}.infra-negative{color:#b91c1c;font-weight:700}.infra-stock-ops{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;display:grid}.infra-stock-panel{border:1px solid var(--line-300);background:#f8fafc;border-radius:14px;gap:16px;padding:20px;display:grid}.infra-stock-alert-count{justify-items:end;gap:2px;display:grid}.infra-stock-alert-count span{color:var(--ink-700);font-size:.78rem}.infra-stock-alert-count strong{color:var(--ink-900);font-size:1.4rem}.infra-chip-list{flex-wrap:wrap;gap:8px;display:flex}.infra-chip{color:var(--ink-900);background:#0a355912;border-radius:999px;align-items:center;padding:6px 12px;font-size:.82rem;font-weight:600;display:inline-flex}.infra-chip.danger{color:#991b1b;background:#b91c1c1a;border:1px solid #b91c1c24}.infra-form-section{border:1px solid var(--line-300);background:#f8fafc;border-radius:12px;gap:12px;padding:16px 18px;display:grid}.infra-form-section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--ucb-blue);border-bottom:1px solid #064d901a;padding-bottom:6px;font-size:.7rem;font-weight:700}.infra-loan-ops{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;display:grid}.infra-loan-panel{border:1px solid var(--line-300);background:#f8fafc;border-radius:14px;gap:16px;padding:20px;display:grid}.infra-user-search{gap:8px;display:grid}.infra-user-result{text-align:left;cursor:pointer;background:#fff;border:1px solid #0a355914;border-radius:12px;gap:4px;width:100%;padding:12px 14px;transition:background .15s,border-color .15s,transform .1s;display:grid}.infra-user-result:hover{background:#f0f6ff;border-color:#064d9033;transform:translateY(-1px)}.infra-user-result strong{color:var(--ink-900);font-size:.9rem}.infra-user-result span,.infra-user-result small{color:var(--ink-700)}.infra-user-selected{background:linear-gradient(135deg,#0a35590f,#1255a014);border:1px solid #0a355924;border-radius:14px;gap:10px;padding:14px 16px;display:grid}.infra-user-selected strong{color:var(--ink-900);font-size:.95rem}.infra-user-selected p{color:var(--ink-700);margin:4px 0 0;font-size:.84rem}.infra-user-selected-meta{flex-wrap:wrap;gap:8px;display:flex}.infra-user-selected-meta span{color:var(--ink-700);background:#ffffffe6;border:1px solid #0a355914;border-radius:999px;align-items:center;padding:5px 10px;font-size:.78rem;font-weight:600;display:inline-flex}.infra-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.infra-subsection{align-content:start;gap:14px;display:grid}.infra-subsection-head h4{color:var(--ink-900);margin:0;font-size:.98rem}.infra-subsection-head p{color:var(--ink-700);margin:4px 0 0;font-size:.84rem;line-height:1.55}.infra-history-table-wrap{border:1px solid var(--line-300);background:#fff;border-radius:12px;overflow-x:auto}@media (width<=1100px){.infra-header{grid-template-columns:1fr}.infra-summary{justify-content:flex-start}.infra-grid,.infra-stock-ops,.infra-loan-ops,.infra-detail-grid{grid-template-columns:1fr}}@media (width<=720px){.infra-form-grid,.infra-item{grid-template-columns:1fr}.infra-actions.compact{justify-content:flex-start}.infra-history-item{grid-template-columns:1fr}.infra-table th,.infra-table td{padding:10px}}.infra-page,.profiles-page,.roles-page{background:radial-gradient(circle at 86% 4%,#f4c54221,#0000 28%),linear-gradient(135deg,#f5f9fd 0%,#edf4fa 100%)}.infra-header{background:radial-gradient(circle at 90% 10%,#f4c5423d,#0000 28%),linear-gradient(135deg,#09233f 0%,#063f77 56%,#125fa8 100%);border-radius:30px;margin:clamp(16px,2vw,24px) clamp(16px,2.4vw,32px) 0;position:relative;overflow:hidden;box-shadow:0 28px 60px #0d223d33}.infra-header:after{content:"";pointer-events:none;background:linear-gradient(90deg,#ffffff17,#0000 34%),radial-gradient(circle at 10% 80%,#ffffff1a,#0000 20%);position:absolute;inset:0}.infra-header>*{z-index:1;position:relative}.infra-summary div{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff24}.infra-body,.infra-grid{padding-top:clamp(20px,2.5vw,34px)}.infra-card,.infra-stock-panel,.infra-loan-panel,.infra-form-section,.infra-ticket-card,.infra-history-panel{box-shadow:var(--shadow-card);border-color:#d8e2eee6}.infra-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border-radius:26px}.infra-form input,.infra-form select,.infra-form textarea{border-radius:14px;min-height:44px}.infra-primary,.infra-secondary,.infra-danger,.infra-user-result,.infra-item{transition:transform .16s,box-shadow .16s,background .16s,border-color .16s}.infra-primary:hover,.infra-secondary:hover,.infra-danger:hover,.infra-user-result:hover,.infra-item:hover{transform:translateY(-2px);box-shadow:0 18px 30px #0d223d1f}.infra-table-wrap,.infra-history-table-wrap{border-radius:18px;box-shadow:0 14px 28px #0d223d12}.infra-table th{background:linear-gradient(#063f7717,#063f770a)}.infra-empty,.infra-alert,.infra-inline-error{border-radius:16px}.infra-page[aria-label=Equipos] .infra-grid{grid-template-columns:1fr}.infra-command-panel{background:radial-gradient(circle at 90% 0,#f4c54238,#0000 30%),linear-gradient(135deg,#fffffff5,#eff6fceb);border:1px solid #d8e2eeeb;border-radius:32px;grid-template-columns:minmax(0,1fr) minmax(320px,1.2fr);gap:clamp(18px,2.4vw,30px);padding:clamp(22px,3vw,34px);display:grid;box-shadow:0 28px 62px #0d223d21}.infra-command-copy{align-content:center;gap:10px;display:grid}.infra-command-copy h3{font-family:var(--font-display);color:var(--ink-900);margin:0;font-size:clamp(1.8rem,3vw,2.6rem)}.infra-command-copy p:not(.infra-kicker){color:var(--ink-700);margin:0;font-size:1rem;line-height:1.7}.infra-action-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.infra-action-card{min-height:170px;color:var(--ink-900);text-align:left;cursor:pointer;background:linear-gradient(#fff 0%,#063f770a 100%);border:1px solid #063f771f;border-radius:26px;align-content:space-between;gap:12px;padding:20px;transition:transform .18s,box-shadow .18s,border-color .18s;display:grid;box-shadow:0 18px 36px #0d223d14}.infra-action-card:hover{border-color:#063f7747;transform:translateY(-5px);box-shadow:0 30px 54px #0d223d26}.infra-action-card span{width:42px;height:42px;color:var(--ucb-blue);background:#063f771a;border-radius:16px;justify-content:center;align-items:center;font-weight:900;display:inline-flex}.infra-action-card strong{color:var(--ink-900);font-size:1.05rem;display:block}.infra-action-card small{color:var(--ink-700);font-weight:700;line-height:1.45}.infra-action-card.is-primary{background:radial-gradient(circle at 88% 0,#f4c5423d,#0000 30%),linear-gradient(135deg,#09233f,#063f77 58%,#1260aa)}.infra-action-card.is-primary span{color:#fff;background:#ffffff29}.infra-action-card.is-primary strong,.infra-action-card.is-primary small{color:#fff}.infra-page[aria-label=Equipos] .infra-grid>.infra-card:nth-of-type(2),.infra-page[aria-label=Equipos] .infra-grid>.infra-card:nth-of-type(3)>.infra-section-head:first-child,.infra-page[aria-label=Equipos] .infra-grid>.infra-card:nth-of-type(3)>form,.infra-page[aria-label=Equipos] .infra-grid>.infra-card:nth-of-type(4)>.infra-section-head:first-child,.infra-page[aria-label=Equipos] .infra-grid>.infra-card:nth-of-type(4) .infra-loan-ops>.infra-loan-panel:first-child{display:none}.infra-page[aria-label=Equipos] .infra-grid>.infra-card:nth-of-type(4) .infra-loan-ops{grid-template-columns:1fr}.infra-page[aria-label=Equipos] .infra-grid>.infra-card:nth-of-type(3),.infra-page[aria-label=Equipos] .infra-grid>.infra-card:nth-of-type(4),.infra-page[aria-label=Equipos] .infra-grid>.infra-card:nth-of-type(5){grid-column:1/-1}.infra-page[aria-label="Materiales y reactivos"] .infra-grid{grid-template-columns:1fr}.infra-page[aria-label="Materiales y reactivos"] .infra-grid>.infra-card:nth-of-type(2){display:none}.infra-page[aria-label="Materiales y reactivos"] .infra-grid>.infra-card:nth-of-type(3) .infra-stock-ops{grid-template-columns:1fr}.infra-page[aria-label="Materiales y reactivos"] .infra-grid>.infra-card:nth-of-type(3) .infra-stock-ops>.infra-stock-panel:first-child{display:none}.infra-page[aria-label="Materiales y reactivos"] .infra-grid>.infra-card:nth-of-type(3),.infra-page[aria-label="Materiales y reactivos"] .infra-grid>.infra-card:nth-of-type(4){grid-column:1/-1}.infra-page[aria-label="Materiales y reactivos"] .infra-stock-panel{background:radial-gradient(circle at 94% 8%,#f4c54224,#0000 24%),linear-gradient(#fff 0%,#f8fbff 100%);border-radius:26px}.infra-page[aria-label="Materiales y reactivos"] .infra-table-wrap{overflow-x:auto}.infra-list-cards{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.infra-section-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.infra-section-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.infra-workflow-backdrop{z-index:120;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:radial-gradient(circle at 50% 12%,#f4c5422e,#0000 30%),#071322a8;place-items:center;min-height:100dvh;padding:clamp(12px,3vw,28px);display:grid;position:fixed;inset:0;overflow-y:auto}.infra-workflow-open{overflow:hidden}.infra-workflow-modal{background:radial-gradient(circle at 92% 0,#f4c54233,#0000 30%),linear-gradient(#fff 0%,#f8fbff 100%);border:1px solid #ffffff8f;border-radius:34px;gap:18px;width:min(980px,100%);max-height:min(92vh,920px);margin:auto;padding:clamp(20px,3vw,34px);display:grid;overflow:auto;box-shadow:0 42px 90px #07132257}.infra-workflow-modal.is-history{width:min(1180px,100%)}.infra-workflow-modal-head{justify-content:space-between;align-items:flex-start;gap:18px;display:flex}.infra-workflow-modal-head h3{font-family:var(--font-display);color:var(--ink-900);margin:0 0 6px;font-size:clamp(1.7rem,3vw,2.35rem)}.infra-workflow-modal-head p:not(.infra-kicker){color:var(--ink-700);margin:0;line-height:1.6}.infra-workflow-close{width:44px;height:44px;color:var(--ink-900);font:inherit;cursor:pointer;background:#063f7712;border:1px solid #063f771f;border-radius:16px;font-weight:900;transition:transform .16s,background .16s,box-shadow .16s}.infra-workflow-close:hover{background:#f4c54238;transform:rotate(3deg)scale(1.05);box-shadow:0 18px 30px #0d223d1f}.infra-workflow-form{gap:18px}.infra-workflow-actions{background:linear-gradient(#f8fbff00,#f8fbff 38%);justify-content:flex-end;padding-top:14px;position:sticky;bottom:-1px}.infra-history-modal-shell{gap:22px;display:grid}.infra-history-modal-overview{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}.infra-history-modal-stat{background:linear-gradient(#fffffffa,#f0f6ffeb);border:1px solid #063f771f;border-radius:22px;gap:6px;padding:18px 18px 16px;display:grid;box-shadow:0 16px 30px #0d223d14}.infra-history-modal-stat.is-highlight{background:radial-gradient(circle at 90% 0,#f4c5423d,#0000 34%),linear-gradient(135deg,#09233ff5,#063f77f0 55%,#1260aaeb);border-color:#ffffff24}.infra-history-modal-stat span{letter-spacing:.08em;text-transform:uppercase;color:var(--ink-700);font-size:.72rem;font-weight:700}.infra-history-modal-stat strong{color:var(--ink-900);font-size:1.08rem}.infra-history-modal-stat small{color:var(--ink-700);font-size:.82rem;line-height:1.5}.infra-history-modal-stat.is-highlight span,.infra-history-modal-stat.is-highlight strong,.infra-history-modal-stat.is-highlight small{color:#fff}.infra-filter-callout{color:var(--ink-800);background:linear-gradient(135deg,#063f7714,#f4c5421f);border:1px solid #063f771a;border-radius:16px;padding:12px 14px;font-size:.85rem;font-weight:600;line-height:1.55}.infra-filter-grid{align-items:end}.infra-filter-panel{background:radial-gradient(circle at 94% 10%,#f4c54229,#0000 24%),linear-gradient(135deg,#fffffffa,#f0f6fff0);border:1px solid #063f771a;border-radius:22px;gap:14px;padding:18px;display:grid;box-shadow:0 18px 34px #0d223d14}.infra-filter-primary,.infra-filter-row{gap:12px;display:grid}.infra-filter-primary{grid-template-columns:minmax(0,1fr)}.infra-filter-row{grid-template-columns:repeat(3,minmax(0,1fr)) auto;align-items:end}.infra-filter-panel label{color:var(--ink-700);gap:6px;font-size:.84rem;font-weight:700;display:grid}.infra-filter-panel input,.infra-filter-panel select{min-height:46px;font:inherit;color:var(--ink-900);background:#ffffffeb;border:1.5px solid #063f771f;border-radius:14px;padding:0 14px}.infra-filter-panel input:focus,.infra-filter-panel select:focus{background:#fff;border-color:#064d9080;outline:none;box-shadow:0 0 0 3px #064d9014}.infra-equipment-results{justify-items:end;gap:2px;display:grid}.infra-equipment-results strong{font-family:var(--font-display);color:var(--ink-900);font-size:2rem;line-height:1}.infra-equipment-results span{color:var(--ink-700);font-size:.82rem;font-weight:600}.infra-table-meta,.infra-pagination{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.infra-table-meta{color:var(--ink-700);font-size:.84rem;font-weight:600}.infra-secondary-strong{color:#fff;background:linear-gradient(135deg,#0a3559,#1255a0);border:none;box-shadow:0 10px 20px #0a355924}.infra-secondary-strong:hover{background:linear-gradient(135deg,#0d406d,#1763b8)}.infra-pagination-pages{flex-wrap:wrap;gap:8px;display:flex}.infra-page-chip{min-width:40px;height:40px;color:var(--ink-900);font:inherit;cursor:pointer;background:#fffffff0;border:1px solid #063f771f;border-radius:12px;font-size:.88rem;font-weight:700;transition:transform .16s,box-shadow .16s,background .16s,border-color .16s}.infra-page-chip:hover{transform:translateY(-2px);box-shadow:0 16px 24px #0d223d1a}.infra-page-chip.is-active{color:#fff;background:linear-gradient(135deg,#0a3559,#1255a0);border-color:#0a355933;box-shadow:0 18px 28px #0a35592e}.infra-manage-shell{gap:20px;display:grid}.infra-manage-hero{background:radial-gradient(circle at 92% 0,#f4c54229,#0000 28%),linear-gradient(135deg,#fffffffa,#f0f6fff0);border:1px solid #063f771f;border-radius:24px;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:18px;padding:22px;display:grid}.infra-manage-copy{align-content:start;gap:8px;display:grid}.infra-manage-copy h4{color:var(--ink-900);margin:0;font-size:1.35rem}.infra-manage-copy p{color:var(--ink-700);margin:0;line-height:1.55}.infra-manage-meta{gap:10px;display:grid}.infra-manage-meta span{color:var(--ink-700);background:#ffffffeb;border:1px solid #0a355914;border-radius:14px;padding:10px 12px;font-size:.86rem;display:block}.infra-manage-meta strong{color:var(--ink-900)}.infra-manage-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;display:grid}.infra-manage-card{color:var(--ink-900);text-align:left;cursor:pointer;background:#fffffff5;border:1px solid #063f771f;border-radius:20px;gap:8px;padding:18px;transition:transform .16s,box-shadow .16s,border-color .16s;display:grid;box-shadow:0 12px 22px #0d223d0f}.infra-manage-card:hover{border-color:#063f7738;transform:translateY(-2px);box-shadow:0 18px 30px #0d223d1f}.infra-manage-card strong{color:var(--ink-900);font-size:1rem}.infra-manage-card span{color:var(--ink-700);font-size:.86rem;line-height:1.55}.infra-manage-card.danger{background:#fffafaf5;border-color:#b91c1c24}.infra-manage-card.danger strong{color:#991b1b}@media (width<=1020px){.infra-command-panel{grid-template-columns:1fr}.infra-action-grid{grid-template-columns:repeat(3,minmax(160px,1fr));padding-bottom:6px;overflow-x:auto}.infra-history-modal-overview{grid-template-columns:repeat(2,minmax(0,1fr))}.infra-filter-row,.infra-manage-hero{grid-template-columns:1fr}}@media (width<=760px){.infra-page[aria-label=Equipos] .infra-grid,.infra-page[aria-label="Materiales y reactivos"] .infra-grid,.infra-body{padding:14px}.infra-command-panel,.infra-card,.infra-workflow-modal{border-radius:24px}.infra-action-grid,.infra-list-cards{grid-template-columns:1fr;overflow:visible}.infra-action-card{min-height:132px}.infra-pagination,.infra-table-meta{flex-direction:column;align-items:stretch}.infra-pagination-pages{justify-content:center}.infra-workflow-backdrop{align-items:start;overflow-y:auto}.infra-workflow-modal{max-height:none}.infra-history-modal-overview{grid-template-columns:1fr}.infra-workflow-modal-head,.infra-section-head,.infra-section-actions{flex-direction:column;align-items:stretch}.infra-workflow-actions{flex-direction:column-reverse;align-items:stretch}.infra-page[aria-label=Equipos] .infra-table,.infra-page[aria-label="Materiales y reactivos"] .infra-table{min-width:720px}.infra-equipment-results{justify-items:start}}.loan-return-open{overflow:hidden}.loan-return-backdrop{z-index:80;background:#0a16288c;justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex;position:fixed;inset:0;overflow-y:auto}.loan-return-modal{background:#fff;border:1px solid #0a35591f;border-radius:20px;gap:18px;width:min(560px,100%);max-height:calc(100dvh - 48px);margin:auto;padding:22px;display:grid;overflow-y:auto;box-shadow:0 26px 60px #0a162847}.loan-return-head{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.loan-return-kicker{text-transform:uppercase;letter-spacing:.1em;color:var(--ucb-blue);margin:0 0 6px;font-size:.72rem;font-weight:700}.loan-return-head h3{color:var(--ink-900);margin:0 0 6px;font-size:1.15rem}.loan-return-head p{color:var(--ink-700);margin:0;line-height:1.5}.loan-return-close{color:var(--ink-900);cursor:pointer;background:#0a355914;border:none;border-radius:999px;width:34px;height:34px;font-size:1.3rem}.loan-return-form{gap:14px;display:grid}.loan-return-form label{color:var(--ink-700);gap:6px;font-size:.86rem;font-weight:600;display:grid}.loan-return-form input,.loan-return-form select,.loan-return-form textarea{border:1.5px solid var(--line-300);width:100%;font:inherit;color:var(--ink-900);background:#fafbfc;border-radius:10px;padding:10px 12px;font-size:.9rem}.loan-return-form input:focus,.loan-return-form select:focus,.loan-return-form textarea:focus{background:#fff;border-color:#064d9080;outline:none;box-shadow:0 0 0 3px #064d9014}.loan-return-actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.loan-return-primary,.loan-return-secondary{font:inherit;cursor:pointer;border:none;border-radius:10px;padding:10px 16px;font-size:.88rem;font-weight:700}.loan-return-primary{color:#fff;background:linear-gradient(135deg,#0a3559,#1255a0)}.loan-return-secondary{color:var(--ink-900);background:#0a355914}.profiles-page{flex:1;align-content:start;gap:0;display:grid}.profiles-header{color:#fff;background:linear-gradient(135deg,#0a2540 0%,#0d3260 55%,#0a3d72 100%);grid-template-columns:1fr auto;align-items:center;gap:24px;padding:clamp(20px,2.8vw,32px) clamp(20px,3vw,40px);display:grid}.profiles-kicker{text-transform:uppercase;letter-spacing:.12em;color:#fcd025cc;margin:0 0 6px;font-size:.72rem;font-weight:700}.profiles-header h2{font-family:var(--font-display);margin:0 0 8px;font-size:clamp(1.6rem,2.8vw,2.2rem)}.profiles-header p{color:#ffffffbf;margin:0;font-size:.95rem}.profiles-summary{flex-wrap:wrap;justify-content:flex-end;gap:12px;display:flex}.profiles-summary div{text-align:center;background:#ffffff1a;border:1px solid #ffffff1f;border-radius:14px;min-width:80px;padding:14px 20px}.profiles-summary span{color:#ffffffa6;font-size:.78rem;display:block}.profiles-summary strong{font-size:1.6rem;font-family:var(--font-display);margin-top:2px;display:block}.profiles-alert{margin:0;padding:14px 20px;font-size:.92rem;font-weight:600}.profiles-alert.success{color:#166534;background:#15803d14;border-left:4px solid #16a34a}.profiles-alert.error{color:#7f1d1d;background:#b91c1c14;border-left:4px solid #dc2626}.profiles-grid{grid-template-columns:minmax(300px,400px) minmax(0,1fr);align-items:start;gap:24px;padding:clamp(16px,2.5vw,32px) clamp(16px,3vw,40px);display:grid}.profiles-card{border:1px solid var(--line-300);background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 2px 12px #0a25400d}.profiles-card-head{padding:20px 22px 0}.profiles-card h3{color:var(--ink-900);margin:0 0 4px;font-size:1.05rem}.profiles-card p{color:var(--ink-700);margin:0;font-size:.86rem}.profiles-empty{color:var(--ink-700);padding:20px 22px;font-size:.9rem}.profiles-form{gap:14px;padding:16px 22px 22px;display:grid}.profiles-form-grid{gap:12px;display:grid}.profiles-form label{color:var(--ink-700);gap:6px;font-size:.84rem;font-weight:600;display:grid}.profiles-form input,.profiles-form select{border:1.5px solid var(--line-300);width:100%;font:inherit;color:var(--ink-900);background:#fafbfc;border-radius:10px;padding:10px 12px;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.profiles-form input:focus,.profiles-form select:focus{background:#fff;border-color:#064d9080;outline:none;box-shadow:0 0 0 3px #064d9014}.profiles-form input:disabled,.profiles-form select:disabled{color:var(--ink-700);cursor:not-allowed;background:#f1f5f9}.profiles-checkbox{cursor:pointer;color:var(--ink-700);align-items:center;gap:10px;font-size:.88rem;font-weight:500;display:flex!important}.profiles-checkbox input{width:17px;height:17px;accent-color:var(--ucb-blue);cursor:pointer}.profiles-actions{flex-wrap:wrap;gap:8px;display:flex}.profiles-actions.compact{justify-content:flex-end}.profiles-primary,.profiles-secondary,.profiles-danger{font:inherit;cursor:pointer;border:none;border-radius:10px;padding:9px 16px;font-size:.86rem;font-weight:700;transition:opacity .15s}.profiles-primary{color:#fff;background:linear-gradient(135deg,#0a3559,#1255a0);box-shadow:0 2px 8px #0a355933}.profiles-primary:hover{opacity:.9}.profiles-primary:disabled{opacity:.45;cursor:not-allowed}.profiles-secondary{color:var(--ink-900);background:#0a355912;border:1px solid #0a35591f}.profiles-secondary:hover{background:#0a35591f}.profiles-secondary:disabled{opacity:.45;cursor:not-allowed}.profiles-danger{color:#b91c1c;background:#b91c1c14;border:1px solid #b91c1c24}.profiles-danger:hover{background:#b91c1c24}.profiles-danger:disabled{opacity:.45;cursor:not-allowed}.profiles-list{gap:8px;max-height:calc(100dvh - 280px);padding:0 12px 16px;display:grid;overflow-y:auto}.profiles-list::-webkit-scrollbar{width:4px}.profiles-list::-webkit-scrollbar-thumb{background:var(--line-300);border-radius:2px}.profiles-item{background:#fafbfc;border:1px solid #0a355914;border-radius:12px;gap:10px;padding:12px 14px;transition:background .15s,border-color .15s;display:grid}.profiles-item:hover{background:#f0f6ff;border-color:#064d9026}.profiles-item.editing{background:#fcd0250a;border-color:#fcd025;box-shadow:0 0 0 2px #fcd02533}.profiles-item-head{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.profiles-item-head strong{color:var(--ink-900);font-size:.92rem}.profiles-item-head p{color:var(--ink-700);margin:2px 0 0;font-size:.8rem}.profiles-badge{border-radius:999px;flex-shrink:0;padding:3px 10px;font-size:.74rem;font-weight:700}.profiles-badge.active{color:#166534;background:#16a34a1a;border:1px solid #16a34a26}.profiles-badge.inactive{color:#991b1b;background:#b91c1c1a;border:1px solid #b91c1c26}.profiles-meta{flex-wrap:wrap;gap:6px;display:flex}.profiles-meta span{color:#0a3559;background:#064d9012;border-radius:999px;padding:3px 10px;font-size:.76rem;font-weight:600}.profiles-flag-banner{background:#b91c1c14;border:1px solid #b91c1c1f;border-radius:10px;margin:0;padding:10px 12px;line-height:1.55;color:#991b1b!important;font-size:.82rem!important}.profiles-form-section{border:1px solid var(--line-300);background:#f8fafc;border-radius:10px;gap:12px;padding:14px 16px;display:grid}.profiles-form-section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--ucb-blue);border-bottom:1px solid #064d901a;padding-bottom:6px;font-size:.7rem;font-weight:700}@media (width<=1100px){.profiles-header{grid-template-columns:1fr}.profiles-summary{justify-content:flex-start}}@media (width<=860px){.profiles-grid{grid-template-columns:1fr;padding:16px}.profiles-list{max-height:none}}.profiles-header{background:radial-gradient(circle at 90% 10%,#f4c5423d,#0000 28%),linear-gradient(135deg,#09233f 0%,#063f77 56%,#125fa8 100%);border-radius:30px;margin:clamp(16px,2vw,24px) clamp(16px,2.4vw,32px) 0;position:relative;overflow:hidden;box-shadow:0 28px 60px #0d223d33}.profiles-header:after{content:"";pointer-events:none;background:linear-gradient(90deg,#ffffff17,#0000 34%);position:absolute;inset:0}.profiles-header>*{z-index:1;position:relative}.profiles-summary div{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff24}.profiles-card,.profiles-form-section,.profiles-item{border-color:#d8e2eee6}.profiles-card{box-shadow:var(--shadow-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffeb;border-radius:26px}.profiles-form input,.profiles-form select{border-radius:14px;min-height:44px}.profiles-item,.profiles-primary,.profiles-secondary,.profiles-danger{transition:transform .16s,box-shadow .16s,background .16s,border-color .16s}.profiles-item:hover,.profiles-primary:hover,.profiles-secondary:hover,.profiles-danger:hover{transform:translateY(-2px);box-shadow:0 18px 30px #0d223d1f}.profiles-item.editing{background:linear-gradient(135deg,#f4c5421f,#ffffffe0);border-color:#d89b008c}.roles-page{flex:1;align-content:start;gap:0;display:grid}.roles-header{color:#fff;background:linear-gradient(135deg,#0a2540 0%,#0d3260 55%,#0a3d72 100%);grid-template-columns:1fr auto;align-items:center;gap:24px;padding:clamp(20px,2.8vw,32px) clamp(20px,3vw,40px);display:grid}.roles-header-kicker{text-transform:uppercase;letter-spacing:.12em;color:#fcd025cc;margin:0 0 6px;font-size:.72rem;font-weight:700}.roles-header-content{flex-direction:column;gap:4px;display:flex}.roles-header h2{font-family:var(--font-display);color:#fff;margin:0 0 8px;font-size:clamp(1.6rem,2.8vw,2.2rem);line-height:1.1}.roles-header p{color:#ffffffbf;margin:0;font-size:.95rem}.roles-reload-button{color:#fff;cursor:pointer;white-space:nowrap;font-weight:600;font:inherit;background:#ffffff1f;border:1px solid #ffffff4d;border-radius:10px;flex-shrink:0;padding:10px 16px;font-size:.875rem;transition:background .15s,border-color .15s}.roles-reload-button:hover:not(:disabled){background:#fff3;border-color:#ffffff73}.roles-reload-button:active:not(:disabled){transform:scale(.98)}.roles-reload-button:disabled{opacity:.6;cursor:not-allowed}.roles-body{flex-direction:column;gap:20px;padding:clamp(16px,2.5vw,28px) clamp(16px,3vw,40px);display:flex}.roles-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.roles-counter{color:var(--ink-700);font-weight:600}.roles-save-button{border-radius:var(--radius-sm);background:var(--ucb-blue);color:#fff;cursor:pointer;border:1px solid #0000;padding:10px 14px;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 2px 8px #064d9026}.roles-save-button:hover:not(:disabled){background:linear-gradient(135deg, var(--ucb-blue) 0%, #004a8f 100%);transform:translateY(-2px);box-shadow:0 6px 16px #064d9040}.roles-save-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #064d9026}.roles-save-button:disabled{opacity:.6;cursor:not-allowed}.roles-success{border-radius:var(--radius-sm);color:#14643b;background:#18a0581f;padding:10px 12px;font-weight:600}.roles-error{border-radius:var(--radius-sm);color:#8e1c1c;background:#db40401f;padding:10px 12px;font-weight:600}.roles-tabs{flex-wrap:wrap;gap:10px;display:flex}.roles-tab-button{border:2px solid var(--line-300);border-radius:var(--radius-sm);background:var(--surface-100);color:var(--ink-900);cursor:pointer;padding:9px 13px;font-weight:600;transition:all .3s}.roles-tab-button:hover{background:#064d900f;border-color:#064d9080}.roles-tab-button.is-active{border-color:var(--ucb-blue);color:var(--ucb-blue);background:linear-gradient(135deg,#064d901f 0%,#064d9014 100%);box-shadow:0 2px 8px #064d901a}.roles-form-card{border:1px solid var(--line-300);border-radius:var(--radius-md);background:var(--surface-100);flex-direction:column;gap:14px;padding:18px;transition:all .3s;display:flex;box-shadow:0 2px 8px #0000000d}.roles-form-card:hover{box-shadow:0 4px 12px #00000014}.roles-form-card h3{color:var(--ink-900)}.roles-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.roles-form-grid label{color:var(--ink-700);flex-direction:column;gap:6px;font-weight:600;display:flex}.roles-form-full{grid-column:1/-1}.roles-input{border:1px solid var(--line-300);border-radius:var(--radius-sm);background:var(--surface-100);color:var(--ink-900);padding:8px 10px;transition:all .3s}.roles-input:focus{border-color:var(--ucb-blue);outline:none;box-shadow:0 0 0 3px #064d901a}.roles-permissions-field{flex-direction:column;gap:8px;display:flex}.roles-permissions-display{border:1px solid var(--line-300);border-radius:var(--radius-sm);background:var(--surface-100);padding:12px}.roles-chips-container{flex-wrap:wrap;gap:8px;display:flex}.roles-chip{color:var(--ink-900);background:linear-gradient(135deg,#064d901f 0%,#064d9014 100%);border:1px solid #064d9040;border-radius:20px;align-items:center;gap:6px;max-width:200px;padding:6px 10px;font-size:.85rem;font-weight:500;transition:all .3s;display:inline-flex}.roles-chip:hover{background:linear-gradient(135deg,#064d902e 0%,#064d901f 100%);border-color:#064d9059;box-shadow:0 2px 8px #064d901a}.roles-chip-icon{flex-shrink:0;font-size:1rem}.roles-chip-label{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.roles-chip-remove{color:#8e1c1c;cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;padding:0;font-weight:700;transition:all .3s;display:flex}.roles-chip-remove:hover{color:#c40000;transform:scale(1.2)}.roles-empty-state{color:var(--ink-700);text-align:center;margin:8px 0;font-style:italic}.roles-modal-backdrop{z-index:40;background:#00000059;place-items:center;padding:16px;animation:.3s fadeIn;display:grid;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.roles-modal{border:1px solid var(--line-300);border-radius:var(--radius-md);background:var(--surface-100);flex-direction:column;gap:12px;width:min(920px,100%);max-height:85vh;padding:14px;animation:.3s cubic-bezier(.4,0,.2,1) slideUp;display:flex;overflow:auto;box-shadow:0 20px 40px #00000026,0 0 0 1px #0000000d}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.roles-modal-permissions{width:min(600px,100%);max-height:70vh}.roles-modal-confirm{width:min(420px,100%);max-height:none}.roles-modal-content{color:var(--ink-900);padding:16px 0;line-height:1.6}.roles-modal-content p{margin:0 0 12px}.roles-modal-content p:last-child{margin-bottom:0}.roles-warning-text{color:var(--ink-700);border-radius:var(--radius-sm);background:#db404014;border-left:3px solid #db4040;padding:10px;font-size:.9rem;font-style:italic}.roles-modal-header{border-bottom:1px solid var(--line-300);justify-content:space-between;align-items:center;gap:8px;padding-bottom:12px;display:flex}.roles-modal-header h3{color:var(--ink-900);margin:0}.roles-permissions-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.roles-permission-item{border:1px solid var(--line-300);border-radius:var(--radius-sm);background:var(--surface-100);color:var(--ink-900);text-align:left;cursor:pointer;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:10px;transition:all .3s;display:grid;position:relative;overflow:hidden}.roles-permission-item:before{content:"";opacity:0;pointer-events:none;background:linear-gradient(135deg,#064d900d 0%,#0000 100%);transition:opacity .3s;position:absolute;inset:0}.roles-permission-item:hover{border-color:#064d904d;box-shadow:0 2px 8px #064d9014}.roles-permission-item:hover:before{opacity:1}.roles-permission-item.is-selected{background:linear-gradient(135deg,#064d901a 0%,#064d900d 100%);border-color:#064d9059;box-shadow:0 2px 8px #064d901a}.roles-permission-icon{flex-shrink:0;font-size:1.1rem}.roles-permission-texts{z-index:1;flex-direction:column;gap:3px;display:flex;position:relative}.roles-permission-texts small{color:var(--ink-700);font-size:.78rem}.roles-permission-check{color:var(--ucb-blue);z-index:1;flex-shrink:0;font-weight:700;position:relative}.roles-permissions-list{padding:14px 0}.roles-permissions-list ul{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.roles-permission-list-item{border-radius:var(--radius-sm);background:#064d900d;border:1px solid #064d901a;align-items:flex-start;gap:12px;padding:12px;transition:all .3s;display:flex}.roles-permission-list-item:hover{background:#064d901a;border-color:#064d9033;transform:translate(4px);box-shadow:0 2px 8px #064d901a}.roles-permission-list-icon{border-radius:var(--radius-sm);background:#064d901a;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.3rem;display:flex}.roles-permission-list-item strong{color:var(--ink-900);margin-bottom:4px;display:block}.roles-permission-list-item small{color:var(--ink-700);font-size:.75rem;display:block}.roles-modal-actions{justify-content:flex-end;align-items:center;gap:8px;display:flex}.roles-actions{align-items:center;gap:8px;display:flex}.roles-ghost-button{border:1px solid var(--line-300);border-radius:var(--radius-sm);background:var(--surface-100);color:var(--ink-900);cursor:pointer;padding:10px 12px;font-weight:600;transition:all .3s}.roles-ghost-button:hover{background:#064d9014;border-color:#064d904d;box-shadow:0 2px 6px #0000000d}.roles-ghost-button:active{transform:scale(.98)}.roles-primary-button{border-radius:var(--radius-sm);background:var(--ucb-blue);color:#fff;cursor:pointer;border:1px solid #0000;padding:10px 14px;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #064d9026}.roles-primary-button:hover{background:linear-gradient(135deg, var(--ucb-blue) 0%, #004a8f 100%);transform:translateY(-2px);box-shadow:0 6px 16px #064d9040}.roles-primary-button:active{transform:translateY(0)}.roles-danger-button{border-radius:var(--radius-sm);color:#8e1c1c;cursor:pointer;background:#db40401f;border:1px solid #db404047;padding:8px 10px;font-weight:600}.roles-danger-button:disabled{opacity:.6;cursor:not-allowed}.roles-actions-cell{align-items:center;gap:8px;display:flex}.roles-table-wrap{border-radius:var(--radius-md);border:1px solid var(--line-300);background:var(--surface-100);-webkit-overflow-scrolling:touch;overflow-x:auto;box-shadow:0 2px 8px #0000000d}.roles-table{border-collapse:collapse;width:100%;min-width:600px}.roles-table th,.roles-table td{text-align:left;border-bottom:1px solid var(--line-300);padding:12px 14px}.roles-table th{color:var(--ink-900);z-index:10;background:linear-gradient(135deg,#064d901f 0%,#064d9014 100%);font-weight:700;position:sticky;top:0}.roles-table tbody tr:hover{background:#064d900a}.roles-table-name{color:var(--ink-900);min-width:140px;font-weight:600}.roles-table-description{color:var(--ink-700);white-space:nowrap;text-overflow:ellipsis;min-width:150px;max-width:200px;overflow:hidden}.roles-table-permissions{min-width:180px;padding:12px 14px}.roles-badges-container{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.roles-badge-wrapper{display:inline-flex;position:relative}.roles-badge{width:28px;height:28px;color:var(--ucb-blue);cursor:help;background:linear-gradient(135deg,#064d9026 0%,#064d901a 100%);border:1px solid #064d9040;border-radius:50%;justify-content:center;align-items:center;font-size:.95rem;font-weight:600;transition:all .3s;display:inline-flex}.roles-badge:hover{background:linear-gradient(135deg,#064d9033 0%,#064d9026 100%);border-color:#064d9059;transform:scale(1.1);box-shadow:0 2px 8px #064d9026}.roles-badge-tooltip{color:#fff;border-radius:var(--radius-sm);white-space:nowrap;z-index:50;pointer-events:none;opacity:0;background:#000000e6;padding:8px 12px;font-size:.8rem;font-weight:500;transition:opacity .3s;position:absolute;bottom:100%;left:50%;transform:translate(-50%)translateY(-8px)}.roles-badge-wrapper:hover .roles-badge-tooltip{opacity:1}.roles-badge-tooltip:after{content:"";border:5px solid #0000;border-top-color:#000000e6;position:absolute;top:100%;left:50%;transform:translate(-50%)}.roles-badge-more{min-width:32px;height:28px;color:var(--ucb-blue);cursor:pointer;background:#064d901a;border:1px solid #064d9040;border-radius:20px;justify-content:center;align-items:center;padding:0 8px;font-size:.8rem;font-weight:700;transition:all .3s;display:inline-flex}.roles-badge-more:hover{background:#064d9026;border-color:#064d9059;transform:scale(1.05);box-shadow:0 2px 8px #064d9026}.roles-select{border:1px solid var(--line-300);border-radius:var(--radius-sm);background:var(--surface-100);min-width:180px;color:var(--ink-900);cursor:pointer;padding:8px 10px;transition:all .3s}.roles-select:hover{border-color:var(--ucb-blue)}.roles-select:focus{border-color:var(--ucb-blue);outline:none;box-shadow:0 0 0 3px #064d901a}.roles-action-button{border:1px solid var(--line-300);border-radius:var(--radius-sm);cursor:pointer;padding:8px 10px;font-size:.85rem;font-weight:600;transition:all .3s}.roles-action-edit{color:var(--ucb-blue);background:#064d901a;border-color:#064d9033}.roles-action-edit:hover{border-color:var(--ucb-blue);background:#064d9026;transform:translateY(-1px);box-shadow:0 2px 6px #064d9026}.roles-action-delete{color:#8e1c1c;background:#db40401a;border-color:#db404033}.roles-action-delete:hover:not(:disabled){background:#db404026;border-color:#8e1c1c;transform:translateY(-1px);box-shadow:0 2px 6px #db404026}.roles-action-delete:disabled{opacity:.6;cursor:not-allowed}@media (width<=860px){.roles-header{grid-template-columns:1fr}.roles-reload-button{align-self:flex-start}}@media (width<=479px){.roles-body{gap:14px;padding:14px 16px}.roles-header h2{font-size:clamp(1.25rem,6vw,1.5rem)}.roles-header p{font-size:.85rem}.roles-toolbar{flex-direction:column;align-items:stretch;gap:8px}.roles-save-button,.roles-primary-button,.roles-ghost-button{width:100%}.roles-tabs{flex-direction:column;gap:8px}.roles-tab-button{text-align:center;width:100%;padding:10px 12px}.roles-form-card{gap:12px;padding:14px}.roles-form-card h3{font-size:1rem}.roles-form-grid{grid-template-columns:1fr;gap:10px}.roles-input{padding:10px 8px;font-size:16px}.roles-permissions-grid{grid-template-columns:1fr;gap:8px}.roles-permission-item{grid-template-columns:auto 1fr;gap:8px;padding:8px}.roles-permission-check{display:none}.roles-badges-container{gap:4px}.roles-badge{width:26px;height:26px;font-size:.85rem}.roles-badge-more{min-width:30px;height:26px;padding:0 6px;font-size:.75rem}.roles-chip{max-width:100%;padding:4px 8px;font-size:.75rem}.roles-modal{border-radius:var(--radius-sm);width:100%;max-height:90vh;padding:12px}.roles-modal-permissions,.roles-modal-confirm{width:100%}.roles-modal-header h3{font-size:1.1rem}.roles-table{min-width:100%;font-size:.85rem}.roles-table th,.roles-table td{padding:8px 6px;font-size:.8rem}.roles-table-name{min-width:100px}.roles-table-description{max-width:100px;font-size:.75rem}.roles-table-permissions{min-width:120px}.roles-select{min-width:100%;font-size:16px}.roles-action-button{width:100%;padding:8px;font-size:.8rem}.roles-actions-cell{flex-direction:column;align-items:stretch;gap:6px;min-width:90px}.roles-permission-list-icon{width:28px;height:28px;font-size:1.1rem}.roles-permission-list-item{gap:10px;padding:10px}.roles-modal-actions{flex-direction:column-reverse}.roles-modal-actions button{width:100%}}@media (width>=480px) and (width<=767px){.roles-body{padding:16px 20px}.roles-header h2{font-size:clamp(1.35rem,4vw,1.65rem)}.roles-toolbar{flex-direction:column;align-items:stretch;gap:10px}.roles-tabs{flex-direction:column;gap:8px}.roles-tab-button{width:100%;padding:10px}.roles-form-card{padding:16px}.roles-form-grid{grid-template-columns:1fr;gap:12px}.roles-permissions-grid{grid-template-columns:1fr;gap:10px}.roles-modal{width:95%;max-height:85vh}.roles-modal-permissions,.roles-modal-confirm{width:95%}.roles-action-button{padding:8px 10px;font-size:.9rem}.roles-action-delete,.roles-action-edit{flex:1}.roles-select{min-width:140px}.roles-table-description{max-width:150px}.roles-table th,.roles-table td{padding:10px;font-size:.9rem}}@media (width>=768px) and (width<=1023px){.roles-form-card{padding:18px}.roles-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.roles-permissions-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.roles-modal{width:90%;max-height:80vh}.roles-modal-permissions{width:90%;max-height:70vh}.roles-modal-confirm{width:90%}.roles-badges-container{gap:6px}.roles-table{font-size:.95rem}.roles-table th,.roles-table td{padding:12px}}@media (width>=1024px){.roles-toolbar{flex-direction:row;align-items:center}.roles-tabs{flex-direction:row}.roles-form-grid,.roles-permissions-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.roles-modal{width:min(920px,95%)}.roles-modal-permissions{width:min(600px,95%)}.roles-action-button{width:auto}.roles-actions-cell{flex-direction:row}}.roles-modal-actions{border-top:1px solid var(--line-300);flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;padding-top:12px;display:flex}@media (width<=479px){.roles-modal-actions{flex-direction:column-reverse;gap:10px}.roles-modal-actions button{width:100%}}@media (width<=767px){.roles-table-wrap{border-radius:var(--radius-sm)}.roles-table{font-size:.9rem}.roles-table th,.roles-table td{padding:10px 8px}.roles-table thead{background-color:#064d9014}.roles-badges-container{max-width:100%}}.roles-header{background:radial-gradient(circle at 90% 10%,#f4c5423d,#0000 28%),linear-gradient(135deg,#09233f 0%,#063f77 56%,#125fa8 100%);border-radius:30px;margin:clamp(16px,2vw,24px) clamp(16px,2.4vw,32px) 0;position:relative;overflow:hidden;box-shadow:0 28px 60px #0d223d33}.roles-header:after{content:"";pointer-events:none;background:linear-gradient(90deg,#ffffff17,#0000 34%);position:absolute;inset:0}.roles-header>*{z-index:1;position:relative}.roles-body{padding-top:clamp(20px,2.5vw,34px)}.roles-form-card,.roles-table-wrap,.roles-modal,.roles-permission-item,.roles-permissions-display{box-shadow:var(--shadow-card);border-color:#d8e2eee6}.roles-form-card,.roles-table-wrap{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffeb;border-radius:26px}.roles-input,.roles-select{border-radius:14px;min-height:44px}.roles-save-button,.roles-tab-button,.roles-action-button,.roles-primary-button,.roles-ghost-button,.roles-danger-button,.roles-permission-item{transition:transform .16s,box-shadow .16s,background .16s,border-color .16s}.roles-save-button:hover:not(:disabled),.roles-tab-button:hover,.roles-action-button:hover:not(:disabled),.roles-primary-button:hover,.roles-ghost-button:hover,.roles-danger-button:hover:not(:disabled),.roles-permission-item:hover{transform:translateY(-2px);box-shadow:0 18px 30px #0d223d1f}.roles-modal-backdrop{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#07132294}.roles-modal{background:radial-gradient(circle at 90% 0,#f4c5422e,#0000 30%),#fff;border-radius:26px}.penalty-backdrop{align-items:start;overflow-y:auto}.penalty-modal{background:radial-gradient(circle at 12% 0,#f4c54238,#0000 28%),radial-gradient(circle at 100% 0,#0a355929,#0000 24%),linear-gradient(#fff 0%,#f8fbff 100%);gap:20px;width:min(1040px,100%);max-height:calc(100vh - 40px);overflow:auto}.penalty-modal-hero{padding:4px 4px 0}.penalty-modal-form{gap:18px}.penalty-modal-warning,.penalty-modal-ready{border-radius:14px;margin:0;padding:12px 14px;font-size:.9rem;font-weight:800}.penalty-modal-warning{color:#8b1e1e;background:#b91c1c14;border:1px solid #b91c1c2e}.penalty-modal-ready{color:#0a3559;background:#0a35590f;border:1px solid #0a35591f}.penalty-form-section{background:#ffffffd1;border:1px solid #0a35591a;border-radius:22px;gap:14px;padding:18px;display:grid;box-shadow:0 12px 30px #0a35590f}.penalty-section-heading{align-items:flex-start;gap:12px;display:flex}.penalty-section-heading>span{color:#fff;background:linear-gradient(135deg,#0a3559,#155e9f);border-radius:12px;flex:none;justify-content:center;align-items:center;width:32px;height:32px;font-size:.9rem;font-weight:900;display:inline-flex;box-shadow:0 10px 20px #0a35592e}.penalty-section-heading h4{color:var(--ink-900);margin:0 0 4px;font-size:1rem}.penalty-section-heading p{color:var(--ink-700);margin:0;font-size:.9rem;line-height:1.5}.penalty-form-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.penalty-field{color:var(--ink-700);flex-direction:column;gap:6px;font-size:.86rem;font-weight:800;display:flex}.penalty-field.is-wide{grid-column:1/-1}.penalty-field small,.penalty-evidence-card small{color:var(--ink-700);font-size:.78rem;font-weight:600;line-height:1.45}.penalty-field input,.penalty-field select,.penalty-field textarea{font:inherit;color:var(--ink-900);background:#fff;border:1.5px solid #0a355929;border-radius:14px;padding:12px 13px;transition:border-color .15s,box-shadow .15s,background .15s}.penalty-field textarea{resize:vertical}.penalty-field input:focus,.penalty-field select:focus,.penalty-field textarea:focus{background:#fff;border-color:#064d9099;outline:none;box-shadow:0 0 0 4px #064d901a}.penalty-field-error{color:#9f1239!important;font-weight:800!important}.penalty-selected-user,.penalty-evidence-card{background:linear-gradient(135deg,#0a355914,#f4c5421f);border:1px solid #0a35591f;border-radius:18px;justify-content:space-between;align-items:center;gap:16px;padding:14px 16px;display:flex}.penalty-selected-user div,.penalty-evidence-card{min-width:0}.penalty-selected-user strong,.penalty-evidence-card strong{color:var(--ink-900);font-size:.98rem;display:block}.penalty-selected-user span{color:var(--ink-700);font-size:.86rem;font-weight:700}.penalty-selected-user>span{color:#0a3559;background:#ffffffc7;border-radius:999px;padding:6px 10px}.penalty-duration-pills{flex-wrap:wrap;gap:10px;display:flex}.penalty-duration-pills button{color:#0a3559;font:inherit;cursor:pointer;background:#0a35590f;border:1px solid #0a355924;border-radius:999px;padding:8px 12px;font-size:.82rem;font-weight:900}.penalty-duration-pills button:hover{background:#f4c5422e;border-color:#f4c5428c}.penalty-modal-actions{background:linear-gradient(#f8fbff00,#f8fbff 36%);padding-top:12px;position:sticky;bottom:-1px}@media (width<=820px){.penalty-form-grid{grid-template-columns:1fr}.penalty-selected-user,.penalty-evidence-card{flex-direction:column;align-items:flex-start}}@media (width<=640px){.penalty-modal{max-height:calc(100vh - 24px)}.penalty-form-section{padding:14px}}.penalty-backdrop{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:radial-gradient(circle at 50% 10%,#f4c54229,#0000 30%),#0713229e}.penalty-modal{border-radius:32px;box-shadow:0 42px 84px #07132252}.penalty-form-section{background:linear-gradient(#fffffff2,#f8fbffe0);transition:transform .18s,box-shadow .18s,border-color .18s}.penalty-form-section:hover{border-color:#063f772e;transform:translateY(-2px);box-shadow:0 22px 46px #0d223d1f}.penalty-section-heading>span{background:radial-gradient(circle at 35% 25%,#ffffff6b,#0000 34%),linear-gradient(135deg,#063f77,#1260aa);border-radius:16px}.penalty-field input,.penalty-field select,.penalty-field textarea{border-radius:16px;min-height:44px}.penalty-selected-user,.penalty-evidence-card{box-shadow:0 16px 30px #0d223d14}.penalty-duration-pills button{transition:transform .16s,box-shadow .16s,background .16s,border-color .16s}.penalty-duration-pills button:hover{transform:translateY(-2px);box-shadow:0 14px 24px #0d223d1f}.reservations-page{background:linear-gradient(135deg, var(--surface-100) 0%, #064d9005 100%);min-height:100%;color:var(--ink-900);flex-direction:column;gap:20px;padding:clamp(16px,2.5vw,28px) clamp(16px,3vw,36px);display:flex}.reservations-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.reservations-kicker{text-transform:uppercase;letter-spacing:.1em;color:var(--ucb-blue);margin:0 0 6px;font-size:.72rem;font-weight:700}.reservations-header h2{font-family:var(--font-display);color:var(--ink-900);margin:0 0 6px;font-size:clamp(1.5rem,2.5vw,2rem)}.reservations-header p{color:var(--ink-700);margin:0;font-size:.95rem}.reservations-summary{flex-wrap:wrap;gap:10px;display:flex}.reservations-summary div{background:var(--surface-100);border:1px solid var(--line-300);text-align:center;border-radius:14px;min-width:80px;padding:12px 18px;box-shadow:0 2px 8px #0a25400a}.reservations-summary span{color:var(--ink-700);text-transform:uppercase;letter-spacing:.06em;font-size:.74rem;font-weight:600;display:block}.reservations-summary strong{font-size:1.5rem;font-family:var(--font-display);color:var(--ink-900);margin-top:2px;display:block}.reservations-panel{border:1px solid var(--line-300);background:#fff;border-radius:18px;flex-direction:column;gap:16px;padding:22px 26px;display:flex;box-shadow:0 2px 12px #0a25400d}.reservations-panel-priority{background:radial-gradient(circle at 96% 2%,#f4c54229,#0000 32%),#fff;border-color:#0a355933;box-shadow:0 18px 38px #0a35591f}.reservations-panel-secondary{background:radial-gradient(circle at 92% 6%,#064d900f,#0000 30%),#fff}.reservations-panel-tertiary{background:linear-gradient(#f8fbffeb,#fffffff5)}.reservations-panel h3{color:var(--ink-900);margin:0;font-size:1.05rem}.reservations-panel-header{gap:4px;display:grid}.reservations-panel-subtitle{color:var(--ink-700);margin:0;font-size:.88rem}.reservations-controls{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.reservations-controls label,.reservations-form label{color:var(--ink-700);flex-direction:column;gap:6px;font-size:.86rem;font-weight:600;display:flex}.reservations-controls input,.reservations-controls select,.reservations-form input,.reservations-form select,.reservations-form textarea{border:1.5px solid var(--line-300);font:inherit;color:var(--ink-900);background:#fafbfc;border-radius:10px;padding:9px 12px;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.reservations-controls input:focus,.reservations-controls select:focus,.reservations-form input:focus,.reservations-form select:focus,.reservations-form textarea:focus{background:#fff;border-color:#064d9080;outline:none;box-shadow:0 0 0 3px #064d9014}.reservations-form{gap:14px;display:grid}.reservations-form-grid{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px;display:grid}.reservations-actions{flex-wrap:wrap;gap:10px;display:flex}.reservations-primary,.reservations-secondary,.reservations-danger{font:inherit;cursor:pointer;white-space:nowrap;border:none;border-radius:10px;padding:9px 16px;font-size:.86rem;font-weight:700;transition:opacity .15s,transform .1s}.reservations-primary:active,.reservations-secondary:active,.reservations-danger:active{transform:scale(.97)}.reservations-primary{color:#fff;background:linear-gradient(135deg,#0a3559,#1255a0);box-shadow:0 2px 8px #0a355933}.reservations-primary:hover{opacity:.9}.reservations-primary:disabled{opacity:.45;cursor:not-allowed}.reservations-secondary{color:var(--ink-900);background:#0a355912;border:1px solid #0a35591f}.reservations-secondary:hover{background:#0a35591f}.reservations-danger{color:#b91c1c;background:#b91c1c14;border:1px solid #b91c1c24}.reservations-danger:hover{background:#b91c1c24}.reservations-danger:disabled{opacity:.45;cursor:not-allowed}.reservations-status{border-radius:999px;padding:3px 10px;font-size:.76rem;font-weight:700;display:inline-flex}.reservations-status.pending{color:#854d0e;background:#eab3081f;border:1px solid #eab30833}.reservations-status.approved{color:#166534;background:#16a34a1a;border:1px solid #16a34a26}.reservations-status.in_progress{color:#1d4ed8;background:#2563eb1a;border:1px solid #2563eb29}.reservations-status.completed{color:#065f46;background:#065f461a;border:1px solid #065f4629}.reservations-status.absent{color:#374151;background:#6b72801f;border:1px solid #6b72802e}.reservations-status.rejected,.reservations-status.cancelled{color:#991b1b;background:#b91c1c1a;border:1px solid #b91c1c26}.reservations-slots{gap:8px;display:grid}.reservations-slot{appearance:none;text-align:left;border:1px solid var(--line-300);border-left:4px solid var(--ink-700);cursor:pointer;border-radius:10px;justify-content:space-between;align-items:center;gap:10px;width:100%;padding:10px 16px;font-size:.9rem;font-weight:500;display:flex}.reservations-slot:disabled{cursor:not-allowed;opacity:.92}.reservations-slot:disabled.past{opacity:.6;filter:grayscale(.15)}.reservations-slot.available{color:#166534;background:#16a34a0d;border-left-color:#16a34a}.reservations-slot.busy{color:#9a3412;background:#ea580c0d;border-left-color:#ea580c}.reservations-slot.maintenance{color:#1d4ed8;background:#2563eb0f;border-left-color:#2563eb}.reservations-slot.blocked-other{color:#6d28d9;background:#7c3aed0f;border-left-color:#7c3aed}.reservations-slot.past{color:#334155;background:#47556914;border-left-color:#475569}.reservations-slot.past:not(:disabled){cursor:not-allowed}.reservations-slot.is-selected{outline:3px solid #064d902e;transform:translateY(-1px);box-shadow:0 10px 18px #064d9014}.reservation-slot-panel{gap:14px;display:grid}.reservation-slot-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.reservation-slot-header strong{color:var(--ink-900);font-size:.96rem}.reservation-slot-header p{color:var(--ink-700);margin:6px 0 0;font-size:.84rem;line-height:1.55}.reservation-slot-legend{flex-wrap:wrap;gap:12px;display:flex}.reservation-slot-legend-item{align-items:center;gap:6px;font-size:.82rem;font-weight:600;display:inline-flex}.reservation-slot-legend-item.maintenance{color:#1d4ed8}.reservation-slot-legend-item.blocked-other{color:#6d28d9}.reservation-slot-legend-item.tutorial{color:#0a3559}.reservation-slot-legend-item.past{color:#334155}.reservation-slot-legend-dot{border-radius:50%;width:10px;height:10px;display:inline-flex}.reservation-slot-legend-item.maintenance .reservation-slot-legend-dot{background:#2563eb}.reservation-slot-legend-item.blocked-other .reservation-slot-legend-dot{background:#7c3aed}.reservation-slot-legend-item.tutorial .reservation-slot-legend-dot{background:#0a3559}.reservation-slot-legend-item.past .reservation-slot-legend-dot{background:#475569}.reservation-slot-grid{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:10px;display:grid}.reservations-table{border-collapse:collapse;width:100%;font-size:.88rem}.reservations-table th{text-align:left;background:var(--surface-200);color:var(--ink-700);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--line-300);white-space:nowrap;padding:11px 14px;font-size:.74rem;font-weight:700}.reservations-table td{vertical-align:middle;color:var(--ink-900);border-bottom:1px solid #0a35590f;padding:12px 14px}.reservations-table tbody tr:last-child td{border-bottom:none}.reservations-table tbody tr.reservation-row-highlight td{background:#064d9014}.reservations-table tbody tr.reservation-row-rejecting td{background:#b91c1c0a}.reservations-table td div{color:var(--ink-700);margin-top:3px;font-size:.8rem}.reservations-table-meta,.reservations-pagination{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.reservations-table-meta{color:var(--ink-700);font-size:.84rem;font-weight:600}.reservations-empty{background:var(--surface-200);color:var(--ink-700);border:1px solid var(--line-300);border-radius:10px;margin:0;padding:16px 18px;font-size:.9rem}.reservations-message{margin:0;padding:14px 20px;font-size:.92rem;font-weight:600}.reservations-message.error{color:#7f1d1d;background:#b91c1c14;border-left:4px solid #dc2626}.reservations-message.success{color:#166534;background:#15803d14;border-left:4px solid #16a34a}.reservation-occupancy-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.reservation-occupancy-card{background:linear-gradient(#fff 0%,#064d9008 100%);border:1px solid #0a355914;border-radius:16px;gap:6px;padding:18px;display:grid}.reservation-occupancy-card.is-primary{background:linear-gradient(135deg,#0a3559 0%,#1255a0 100%);border-color:#0a355933}.reservation-occupancy-card span{color:var(--ink-700);text-transform:uppercase;letter-spacing:.08em;font-size:.76rem;font-weight:700}.reservation-occupancy-card strong{color:var(--ink-900);font-size:1.9rem;line-height:1;font-family:var(--font-display)}.reservation-occupancy-card p{color:var(--ink-700);margin:0;font-size:.84rem}.reservation-occupancy-card.is-primary span,.reservation-occupancy-card.is-primary strong,.reservation-occupancy-card.is-primary p{color:#fff}.reservation-inline-hint{color:var(--ink-700);font-size:.8rem;font-weight:600}.reservation-inline-hint code{color:var(--ink-900);word-break:break-all;background:#0a35590f;border-radius:8px;margin-top:6px;padding:6px 10px;font-size:.78rem;font-weight:700;display:inline-block}.reservation-card-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;display:grid}.reservation-user-card{background:linear-gradient(#fff 0%,#064d9008 100%);border:1px solid #0a355914;border-radius:18px;gap:14px;padding:18px;display:grid;box-shadow:0 12px 24px #0a35590d}.reservation-user-card.is-focused{border-color:#064d9038;box-shadow:0 16px 30px #064d901a}.reservation-user-card-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.reservation-user-card-head h4{color:var(--ink-900);margin:8px 0 0;font-size:1rem}.reservation-user-card-kicker{color:var(--ucb-blue);text-transform:uppercase;letter-spacing:.08em;background:#064d901a;border-radius:999px;align-items:center;padding:5px 10px;font-size:.74rem;font-weight:700;display:inline-flex}.reservation-user-card-meta{gap:6px;display:grid}.reservation-user-card-meta span{color:var(--ink-700);font-size:.86rem;line-height:1.55}.reservation-user-card-actions{flex-wrap:wrap;gap:10px;display:flex}.reservation-user-card-warning{color:#7f1d1d;background:#b91c1c14;border-radius:12px;margin:0;padding:10px 12px;font-size:.85rem;line-height:1.55}.reservation-history-header{margin-top:24px}.reservation-focus-panel{border-color:#064d902e;box-shadow:0 16px 34px #064d9014}.reservation-focus-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;display:grid}.reservation-focus-card{background:linear-gradient(#064d900a 0%,#fff 100%);border:1px solid #0a355914;border-radius:14px;gap:6px;padding:14px 16px;display:grid}.reservation-focus-card span{text-transform:uppercase;letter-spacing:.08em;color:var(--ink-700);font-size:.74rem;font-weight:700}.reservation-focus-card strong{color:var(--ink-900);font-size:.96rem}.reservation-focus-copy{gap:8px;display:grid}.reservation-focus-copy p{color:var(--ink-800);margin:0;line-height:1.6}.reservation-focus-status.pending{color:#854d0e}.reservation-focus-status.approved{color:#166534}.reservation-focus-status.in_progress{color:#1d4ed8}.reservation-focus-status.completed{color:#065f46}.reservation-focus-status.absent{color:#374151}.reservation-focus-status.rejected,.reservation-focus-status.cancelled{color:#991b1b}.reservation-notification-list{gap:14px;display:grid}.reservation-notification-card{border:1px solid var(--line-300);background:linear-gradient(#fff 0%,#064d9005 100%);border-radius:16px;gap:14px;padding:18px;display:grid}.reservation-notification-card.is-unread{border-color:#064d9047;box-shadow:0 10px 24px #064d9014}.reservation-notification-card.is-reminder{background:linear-gradient(#fcd02524 0%,#fff 100%);border-color:#e8a80047}.reservation-notification-card.is-reminder-urgent{background:linear-gradient(#ea580c24 0%,#fff 100%);border-color:#ea580c47}.reservation-notification-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.reservation-notification-head h4{color:var(--ink-900);margin:8px 0 0;font-size:1rem}.reservation-notification-badge{color:var(--ucb-blue);text-transform:uppercase;letter-spacing:.06em;background:#064d901a;border-radius:999px;align-items:center;padding:5px 10px;font-size:.76rem;font-weight:700;display:inline-flex}.reservation-notification-meta{color:var(--ink-700);justify-items:end;gap:4px;font-size:.8rem;display:grid}.reservation-notification-meta strong{color:#0b4a6f}.reservation-notification-message{color:var(--ink-800);margin:0;font-size:.92rem}.reservation-notification-diff{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.reservation-notification-change{background:var(--surface-200);border:1px solid #0a355914;border-radius:12px;gap:6px;padding:12px 14px;display:grid}.reservation-notification-change span{text-transform:uppercase;letter-spacing:.08em;color:var(--ink-700);font-size:.74rem;font-weight:700}.reservation-notification-change strong{color:var(--ink-900);font-size:.95rem}.reservation-notification-old{-webkit-text-decoration:line-through #b91c1c8c;text-decoration:line-through #b91c1c8c;text-decoration-thickness:2px;color:#8b1e1e!important}.reservation-notification-new{background:#16a34a1a;border-radius:10px;padding:8px 10px;color:#0b6d39!important}.reservation-reject-box{background:#b91c1c0a;border:1px solid #b91c1c1f;border-radius:14px;gap:10px;margin-top:12px;padding:12px;display:grid}.reservation-suspension-banner{background:linear-gradient(135deg,#b91c1c1f 0%,#7f1d1d0f 100%);border-color:#b91c1c42}.reservation-suspension-copy{gap:8px;display:grid}.reservation-suspension-copy strong{color:#7f1d1d;font-size:1rem}.reservation-suspension-copy p{color:#7f1d1d;margin:0;line-height:1.6}.penalty-card-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;display:grid}.penalty-card{background:linear-gradient(#fff 0%,#0a355908 100%);border:1px solid #0a355914;border-radius:18px;gap:14px;padding:18px;display:grid;box-shadow:0 10px 24px #0a35590d}.penalty-card.is-active{border-color:#b91c1c38;box-shadow:0 14px 28px #7f1d1d1a}.penalty-card-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.penalty-card-head h4{color:var(--ink-900);margin:8px 0 0;font-size:1rem}.penalty-card-meta{color:var(--ink-700);gap:6px;font-size:.86rem;line-height:1.55;display:grid}.penalty-status{text-transform:uppercase;letter-spacing:.06em;border-radius:999px;justify-content:center;align-items:center;padding:5px 10px;font-size:.75rem;font-weight:700;display:inline-flex}.penalty-status.active{color:#991b1b;background:#b91c1c1f}.penalty-status.scheduled{color:#854d0e;background:#eab30824}.penalty-status.expired,.penalty-status.lifted{color:#166534;background:#16a34a1f}.cal-lab-controls{grid-template-columns:minmax(220px,400px)}.cal-panel{gap:20px}.cal-week-nav{justify-content:space-between;align-items:center;gap:12px;display:flex}.cal-nav-btn{border:1.5px solid var(--line-300);background:var(--surface-200);width:40px;height:40px;color:var(--ink-900);cursor:pointer;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.4rem;line-height:1;transition:background .15s,border-color .15s;display:flex}.cal-nav-btn:hover{background:var(--line-300);border-color:var(--ink-700)}.cal-week-center{flex-wrap:wrap;flex:1;justify-content:center;align-items:center;gap:12px;display:flex}.cal-week-range{color:var(--ink-900);font-size:.95rem;font-weight:600}.cal-today-btn{border:1.5px solid var(--ucb-blue);color:var(--ucb-blue);font:inherit;cursor:pointer;background:0 0;border-radius:8px;padding:4px 12px;font-size:.82rem;font-weight:700;transition:background .15s,color .15s}.cal-today-btn:hover{background:var(--ucb-blue);color:#fff}.cal-week-grid{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.cal-day{border:1.5px solid var(--line-300);background:var(--surface-200);cursor:pointer;font:inherit;border-radius:12px;flex-direction:column;align-items:center;gap:6px;padding:10px 4px;transition:background .15s,border-color .15s,transform .1s;display:flex}.cal-day:hover{background:#064d9012;border-color:#064d904d;transform:translateY(-1px)}.cal-day--today .cal-day-num{background:var(--ucb-blue);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;display:flex}.cal-day--selected{background:#fcd02533;border-color:#e8a800}.cal-day--selected .cal-day-name,.cal-day--selected .cal-day-num{color:#7a5500;font-weight:700}.cal-day--today.cal-day--selected .cal-day-num{color:#3d2a00;background:#e8a800}.cal-day-name{color:var(--ink-700);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:600}.cal-day-num{color:var(--ink-900);justify-content:center;align-items:center;width:30px;height:30px;font-size:1rem;font-weight:600;display:flex}.cal-slots-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.cal-slots-title{color:var(--ink-900);margin:0;font-size:1rem;font-weight:600}.cal-slots-legend{flex-wrap:wrap;gap:14px;display:flex}.cal-legend-item{align-items:center;gap:6px;font-size:.82rem;font-weight:600;display:flex}.cal-legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.cal-legend--available .cal-legend-dot{background:#16a34a}.cal-legend--available{color:#166534}.cal-legend--busy .cal-legend-dot{background:#ea580c}.cal-legend--busy{color:#9a3412}.reservations-form-section{gap:12px;display:grid}.reservations-form-section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--ucb-blue);border-bottom:1px solid var(--line-300);padding-bottom:6px;font-size:.76rem;font-weight:700;display:block}@media (width<=860px){.reservations-header{flex-direction:column}.reservations-panel{padding:16px 18px}}@media (width<=720px){.reservations-form-grid{grid-template-columns:1fr}}.reservations-slot,.reservation-user-card,.reservation-focus-card,.reservation-occupancy-card,.penalty-card,.cal-day,.reservations-panel{transition:transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base), background var(--transition-fast)}.reservation-user-card:hover{border-color:#064d902e;transform:translateY(-2px);box-shadow:0 18px 36px #0a35591a}.reservation-occupancy-card:hover{transform:translateY(-2px);box-shadow:0 16px 32px #0a35591a}.penalty-card:hover{border-color:#064d9024;transform:translateY(-2px);box-shadow:0 16px 32px #0a35591a}.reservations-slot:not(:disabled):hover{filter:brightness(.97);transform:translate(2px)}.reservations-primary,.reservations-secondary,.reservations-danger{transition:transform var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast), opacity var(--transition-fast)}.reservations-primary:hover:not(:disabled){opacity:1;transform:translateY(-2px);box-shadow:0 12px 24px #0a355940}.reservations-status{font-family:var(--font-display);letter-spacing:.04em;font-weight:700}.reservations-summary div{transition:transform var(--transition-fast), box-shadow var(--transition-fast)}.reservations-summary div:hover{transform:translateY(-2px);box-shadow:0 10px 22px #0a35591a}.reservations-controls input,.reservations-controls select,.reservations-form input,.reservations-form select,.reservations-form textarea{font-family:var(--font-body);min-height:44px}.reservations-header h2{letter-spacing:-.03em;font-weight:800}.reservations-panel{border-radius:22px}.reservations-page{animation:.28s both pageIn}.cal-day--today{background:#063f770a;border-color:#063f774d}.cal-day--selected{border-color:var(--ucb-gold-strong);background:#f4c5422e;box-shadow:0 4px 12px #f4c54233}.reservations-empty{text-align:center;border-radius:14px;padding:24px}.reservations-message{border-radius:14px;animation:.22s both fadeUp}.reservations-table tbody tr{transition:background var(--transition-fast)}.penalty-card.is-active{box-shadow:0 12px 28px #7f1d1d1f}@media (width<=640px){.reservation-card-grid{grid-template-columns:1fr}.reservation-occupancy-grid{grid-template-columns:1fr 1fr}.cal-week-grid{gap:4px}.cal-day{padding:8px 2px}}@media (width<=480px){.reservations-page{gap:14px;padding:14px 12px}.reservations-table{min-width:480px;font-size:.82rem}.reservations-table th,.reservations-table td{padding:8px}.reservations-panel{overflow-x:auto}.reservations-actions{flex-direction:column;align-items:stretch}.reservation-notification-meta{justify-items:start}.cal-week-grid{gap:4px}.cal-day{border-radius:8px;padding:8px 2px}.cal-day-name{font-size:.64rem}.cal-day-num,.cal-day--today .cal-day-num{width:26px;height:26px;font-size:.88rem}.cal-week-range{text-align:center;font-size:.84rem}}.reservations-page{background:radial-gradient(circle at 86% 0,#f4c54226,#0000 28%),radial-gradient(circle at 6% 12%,#063f771a,#0000 26%),linear-gradient(135deg,#f6f9fc 0%,#eef5fb 100%)}.reservations-header{box-shadow:var(--shadow-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:radial-gradient(circle at 92% 8%,#f4c5422e,#0000 24%),#ffffffc7;border:1px solid #d8e2eee6;border-radius:28px;padding:clamp(20px,2vw,28px)}.reservations-header h2,.reservations-panel h3,.cal-slots-title{letter-spacing:.01em}.reservations-summary div{background:linear-gradient(#fff 0%,#063f770a 100%);border-radius:18px;min-width:104px;box-shadow:0 16px 30px #0d223d14}.reservations-panel{box-shadow:var(--shadow-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border-radius:26px}.reservations-panel-header{padding-bottom:4px}.reservations-controls input,.reservations-controls select,.reservations-form input,.reservations-form select,.reservations-form textarea,.reservation-modal-form input,.reservation-modal-form select,.reservation-modal-form textarea{border-radius:14px;min-height:44px}.reservations-primary,.reservations-secondary,.reservations-danger,.cal-today-btn,.cal-nav-btn{transition:transform .16s,box-shadow .16s,background .16s,opacity .16s;box-shadow:0 10px 20px #0d223d14}.reservations-primary:hover,.reservations-secondary:hover,.reservations-danger:hover,.cal-today-btn:hover,.cal-nav-btn:hover{transform:translateY(-2px);box-shadow:0 18px 30px #0d223d1f}.reservations-slot,.cal-day,.reservation-user-card,.reservation-occupancy-card,.reservation-notification-card,.penalty-card{transition:transform .18s,box-shadow .18s,border-color .18s,background .18s}.reservations-slot:not(:disabled):hover,.cal-day:hover,.reservation-user-card:hover,.reservation-occupancy-card:hover,.reservation-notification-card:hover,.penalty-card:hover{transform:translateY(-3px);box-shadow:0 22px 42px #0d223d1f}.reservations-slot.available,.cal-legend--available .cal-legend-dot{background-color:#16a34a14}.reservations-slot.tutorial{color:#123d75;background:linear-gradient(90deg,#123d7521,#123d750a);border-left-color:#123d75}.reservations-slot.busy{background:linear-gradient(90deg,#ea580c1f,#ea580c09)}.reservations-slot.blocked-other,.cal-day--selected{background:linear-gradient(90deg,#7c3aed1f,#f4c5421f)}.reservations-table{border-radius:18px;overflow:hidden}.reservations-table th{color:var(--ink-800);background:linear-gradient(#063f7717,#063f770a)}.reservations-table tbody tr:hover td{background:#063f770b}.reservations-empty,.reservations-message,.reservation-inline-hint code{border-radius:16px}.cal-week-nav,.cal-slots-header,.reservation-slot-panel{padding:6px}.cal-week-grid{gap:10px}.cal-day{background:#ffffffb8;border-radius:18px;min-height:84px}.cal-day--selected{border-color:#d89b008c;box-shadow:0 16px 28px #d89b0024}.reservation-suspension-banner{border-left:5px solid #b91c1c}.reservations-header-copy{gap:6px;max-width:720px;display:grid}.reservations-summary-card{text-align:left;grid-template-columns:auto 1fr;align-items:center;gap:12px;min-width:152px;display:grid}.reservations-summary-card-icon,.reservations-workspace-icon,.reservations-workspace-status-icon,.reservations-task-card-icon{border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:inline-flex}.reservations-summary-card>div{gap:2px;display:grid}.reservations-summary-card.tone-overview .reservations-summary-card-icon,.reservations-workspace-tab.tone-overview .reservations-workspace-icon,.reservations-workspace-status-icon.tone-overview,.reservations-task-card.tone-overview .reservations-task-card-icon{color:#0b4a87;background:#063f771f}.reservations-summary-card.tone-requests .reservations-summary-card-icon,.reservations-workspace-tab.tone-requests .reservations-workspace-icon,.reservations-workspace-status-icon.tone-requests,.reservations-task-card.tone-requests .reservations-task-card-icon{color:#b45309;background:#f59e0b29}.reservations-summary-card.tone-live .reservations-summary-card-icon,.reservations-workspace-tab.tone-live .reservations-workspace-icon,.reservations-workspace-status-icon.tone-live,.reservations-task-card.tone-live .reservations-task-card-icon{color:#0369a1;background:#0ea5e924}.reservations-summary-card.tone-control .reservations-summary-card-icon,.reservations-workspace-tab.tone-control .reservations-workspace-icon,.reservations-workspace-status-icon.tone-control,.reservations-task-card.tone-control .reservations-task-card-icon{color:#15803d;background:#22c55e24}.reservations-summary-card.tone-walkin .reservations-summary-card-icon,.reservations-workspace-tab.tone-walkin .reservations-workspace-icon,.reservations-workspace-status-icon.tone-walkin,.reservations-task-card.tone-walkin .reservations-task-card-icon{color:#7e22ce;background:#a855f724}.reservations-workspace-nav{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.reservations-workspace-tab{text-align:left;cursor:pointer;transition:transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);background:linear-gradient(#fffffff5,#f5f9ffeb);border:1px solid #0a35591a;border-radius:20px;gap:6px;padding:16px 18px;display:grid}.reservations-workspace-tab-head{align-items:center;gap:10px;display:flex}.reservations-workspace-tab strong{color:var(--ink-900);font-size:.98rem}.reservations-workspace-tab span{color:var(--ink-700);font-size:.82rem;line-height:1.5}.reservations-workspace-tab:hover{border-color:#063f772e;transform:translateY(-2px);box-shadow:0 18px 30px #0d223d1a}.reservations-workspace-tab.is-active{background:radial-gradient(circle at 92% 10%,#f4c5422e,#0000 28%),linear-gradient(135deg,#063f7714,#fffffff5);border-color:#063f7747;box-shadow:0 24px 38px #0d223d1f}.reservations-workspace-status{background:radial-gradient(circle at 94% 8%,#f4c5421f,#0000 24%),#ffffffe6;border:1px solid #063f771a;border-radius:20px;grid-template-columns:auto 1fr;align-items:center;gap:12px;padding:16px 18px;display:grid;box-shadow:0 12px 26px #0d223d14}.reservations-workspace-status>div{gap:4px;display:grid}.reservations-workspace-status strong{color:var(--ink-900);font-size:.95rem}.reservations-workspace-status span{color:var(--ink-700);font-size:.84rem;line-height:1.55}.reservations-task-grid,.reservations-insight-grid,.reservations-step-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;display:grid}.reservations-task-card,.reservations-insight-card,.reservations-step-card{background:#fffffff0;border:1px solid #0a355914;border-radius:22px;gap:10px;padding:20px;display:grid;box-shadow:0 12px 24px #0d223d0f}.reservations-task-card-head{justify-content:space-between;align-items:center;gap:10px;display:flex}.reservations-task-card span,.reservations-insight-card span{text-transform:uppercase;letter-spacing:.12em;color:var(--ucb-blue);font-size:.72rem;font-weight:800}.reservations-task-card h4{color:var(--ink-900);margin:0;font-size:1.08rem}.reservations-task-card strong,.reservations-insight-card strong{font-family:var(--font-display);color:var(--ink-900);font-size:2rem;line-height:1}.reservations-task-card.tone-requests{background:linear-gradient(#fffbebfa,#fffffff5);border-color:#f59e0b2e}.reservations-task-card.tone-control{background:linear-gradient(#f0fdf4fa,#fffffff5);border-color:#22c55e2e}.reservations-task-card.tone-live{background:linear-gradient(#f0f9fffa,#fffffff5);border-color:#0ea5e92e}.reservations-task-card.tone-walkin{background:linear-gradient(#faf5fffa,#fffffff5);border-color:#a855f72e}.reservations-task-card p,.reservations-insight-card p,.reservations-step-card span{color:var(--ink-700);margin:0;font-size:.88rem;line-height:1.55}.reservations-step-card{grid-template-columns:auto 1fr;align-items:start}.reservations-step-card strong{width:36px;height:36px;color:var(--ucb-blue);background:#063f771a;border-radius:999px;justify-content:center;align-items:center;font-size:1rem;display:inline-flex}.reservations-filter-callout{color:var(--ink-800);background:linear-gradient(135deg,#063f7714,#f4c5421f);border:1px solid #063f771a;border-radius:16px;align-items:center;gap:10px;padding:12px 14px;font-size:.85rem;font-weight:600;line-height:1.5;display:flex}.reservations-filter-callout svg{color:var(--ucb-blue);flex-shrink:0}.reservations-table-wrap{background:#ffffffeb;border:1px solid #063f7714;border-radius:20px;overflow-x:auto;box-shadow:inset 0 1px #ffffffb3}.reservations-table-row.status-pending td:first-child{border-left:4px solid #f59e0b}.reservations-table-row.status-approved td:first-child,.reservations-table-row.status-in_progress td:first-child,.reservations-table-row.status-completed td:first-child{border-left:4px solid #16a34a}.reservations-table-row.status-rejected td:first-child,.reservations-table-row.status-cancelled td:first-child,.reservations-table-row.status-absent td:first-child{border-left:4px solid #dc2626}@media (width<=720px){.reservations-workspace-nav,.reservations-task-grid,.reservations-insight-grid,.reservations-step-grid{grid-template-columns:1fr}.reservations-workspace-tab{padding:14px 16px}.reservations-summary-card,.reservations-workspace-status{grid-template-columns:1fr}}.reservation-modal-open{overflow:hidden}.reservation-modal-backdrop{z-index:110;overscroll-behavior:contain;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0a14228c;place-items:center;min-height:100dvh;padding:20px;display:grid;position:fixed;inset:0;overflow-y:auto}.reservation-modal{background:radial-gradient(circle at 100% 0,#fcd02529,#0000 24%),#fff;border:1px solid #0a355914;border-radius:24px;gap:18px;width:min(720px,100%);max-height:calc(100dvh - 40px);margin:auto;padding:24px;display:grid;overflow-y:auto;box-shadow:0 30px 60px #0a142240}.reservation-modal-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.reservation-modal-kicker{text-transform:uppercase;letter-spacing:.1em;color:var(--ucb-blue);margin:0 0 6px;font-size:.72rem;font-weight:800}.reservation-modal-header h3{color:var(--ink-900);margin:0 0 6px;font-size:1.2rem}.reservation-modal-header p{color:var(--ink-700);margin:0;line-height:1.6}.reservation-modal-close{width:40px;height:40px;color:var(--ink-900);cursor:pointer;background:#0a35590f;border:1px solid #0a35591f;border-radius:999px;font-size:1.5rem}.reservation-modal-form{gap:14px;display:grid}.reservation-modal-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;display:grid}.reservation-modal-form label{color:var(--ink-700);flex-direction:column;gap:6px;font-size:.86rem;font-weight:700;display:flex}.reservation-modal-form input,.reservation-modal-form select,.reservation-modal-form textarea{border:1.5px solid var(--line-300);font:inherit;color:var(--ink-900);background:#fbfcfd;border-radius:12px;padding:10px 12px}.reservation-modal-form input:focus,.reservation-modal-form select:focus,.reservation-modal-form textarea:focus{background:#fff;border-color:#064d9080;outline:none;box-shadow:0 0 0 3px #064d9014}.reservation-modal-actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.reservation-modal-extra{background:#0a35590a;border:1px solid #0a355914;border-radius:18px;gap:12px;padding:14px;display:grid}.reservation-modal-extra-head{gap:4px;display:grid}.reservation-modal-extra-head strong{color:var(--ink-900)}.reservation-modal-extra-head p{color:var(--ink-700);margin:0;line-height:1.5}.reservation-modal-primary,.reservation-modal-secondary{font:inherit;cursor:pointer;border:none;border-radius:12px;padding:10px 16px;font-size:.88rem;font-weight:800}.reservation-modal-primary{color:#fff;background:linear-gradient(135deg,#0a3559,#1255a0)}.reservation-modal-primary:disabled{opacity:.5;cursor:not-allowed}.reservation-modal-secondary{color:var(--ink-900);background:#0a355914;border:1px solid #0a35591f}@media (width<=640px){.reservation-modal{padding:18px}.reservation-modal-grid{grid-template-columns:1fr}.reservation-modal-actions{flex-direction:column;align-items:stretch}}.reservation-modal-backdrop{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:radial-gradient(circle at 50% 12%,#f4c54229,#0000 30%),#0713229e}.reservation-modal{background:radial-gradient(circle at 90% 0,#f4c54238,#0000 28%),linear-gradient(#fff 0%,#f8fbff 100%);border-radius:30px;box-shadow:0 36px 72px #0713224d}.reservation-modal-close{transition:transform .16s,background .16s,box-shadow .16s}.reservation-modal-close:hover{background:#f4c54238;transform:rotate(3deg)scale(1.05);box-shadow:0 16px 26px #0d223d1f}.reservation-modal-primary,.reservation-modal-secondary{transition:transform .16s,box-shadow .16s,background .16s}.reservation-modal-primary:hover:not(:disabled),.reservation-modal-secondary:hover{transform:translateY(-2px);box-shadow:0 18px 30px #0d223d24}.tutorials-page{min-height:100%;color:var(--ink-900);background:radial-gradient(circle at 100% 0,#fcd02529,#0000 28%),linear-gradient(135deg,#f7fafc 0%,#064d900a 100%);flex-direction:column;gap:20px;padding:clamp(16px,2.5vw,28px) clamp(16px,3vw,36px);display:flex}.tutorials-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.tutorials-kicker{text-transform:uppercase;letter-spacing:.1em;color:#0b4a6f;margin:0 0 6px;font-size:.72rem;font-weight:700}.tutorials-header h2{font-family:var(--font-display);color:var(--ink-900);margin:0 0 6px;font-size:clamp(1.5rem,2.5vw,2rem)}.tutorials-header p{color:var(--ink-700);max-width:760px;margin:0;font-size:.95rem}.tutorials-summary{flex-wrap:wrap;gap:10px;display:flex}.tutorials-summary div{text-align:center;background:#fff;border:1px solid #0a355914;border-radius:14px;min-width:96px;padding:12px 18px;box-shadow:0 2px 10px #0a35590d}.tutorials-summary span{color:var(--ink-700);text-transform:uppercase;letter-spacing:.06em;font-size:.74rem;font-weight:700;display:block}.tutorials-summary strong{color:var(--ink-900);font-size:1.45rem;font-family:var(--font-display);margin-top:2px;display:block}.tutorials-panel{background:#ffffffeb;border:1px solid #0a355914;border-radius:20px;gap:16px;padding:22px 26px;display:grid;box-shadow:0 18px 34px #0a35590f}.tutorials-panel-header{gap:4px;display:grid}.tutorials-panel-header h3{color:var(--ink-900);margin:0;font-size:1.05rem}.tutorials-panel-subtitle{color:var(--ink-700);margin:0;font-size:.88rem}.tutorials-form{gap:14px;display:grid}.tutorials-form-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.tutorials-form label{color:var(--ink-700);flex-direction:column;gap:6px;font-size:.86rem;font-weight:700;display:flex}.tutorials-form input,.tutorials-form select,.tutorials-form textarea{font:inherit;color:var(--ink-900);background:#fcfdff;border:1.5px solid #0a355924;border-radius:12px;padding:10px 12px;font-size:.92rem}.tutorials-form input:focus,.tutorials-form select:focus,.tutorials-form textarea:focus{border-color:#064d9073;outline:none;box-shadow:0 0 0 3px #064d9014}.tutorial-slot-panel{gap:14px;display:grid}.tutorial-slot-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.tutorial-slot-header strong{color:var(--ink-900);font-size:.96rem}.tutorial-slot-header p{color:var(--ink-700);margin:6px 0 0;font-size:.84rem;line-height:1.55}.tutorial-slot-legend{flex-wrap:wrap;gap:12px;display:flex}.tutorial-slot-legend-item{align-items:center;gap:6px;font-size:.82rem;font-weight:600;display:inline-flex}.tutorial-slot-legend-item.available{color:#166534}.tutorial-slot-legend-item.busy{color:#9a3412}.tutorial-slot-legend-item.maintenance{color:#1d4ed8}.tutorial-slot-legend-item.blocked-other{color:#6d28d9}.tutorial-slot-legend-item.past{color:#111827}.tutorial-slot-legend-dot{border-radius:50%;width:10px;height:10px;display:inline-flex}.tutorial-slot-legend-item.available .tutorial-slot-legend-dot{background:#16a34a}.tutorial-slot-legend-item.busy .tutorial-slot-legend-dot{background:#ea580c}.tutorial-slot-legend-item.maintenance .tutorial-slot-legend-dot{background:#2563eb}.tutorial-slot-legend-item.blocked-other .tutorial-slot-legend-dot{background:#7c3aed}.tutorial-slot-legend-item.past .tutorial-slot-legend-dot{background:#111827}.tutorial-slot-grid{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:10px;display:grid}.tutorial-slot{appearance:none;text-align:left;width:100%;font:inherit;cursor:pointer;background:#fff;border:1px solid #0a35591f;border-left:4px solid #0a3559;border-radius:12px;flex-direction:column;gap:6px;padding:10px 14px;display:flex}.tutorial-slot:disabled{cursor:not-allowed;opacity:.92}.tutorial-slot.available{color:#166534;background:#16a34a0d;border-left-color:#16a34a}.tutorial-slot.busy{color:#9a3412;background:#ea580c0d;border-left-color:#ea580c}.tutorial-slot.maintenance{color:#1d4ed8;background:#2563eb0f;border-left-color:#2563eb}.tutorial-slot.blocked-other{color:#6d28d9;background:#7c3aed0f;border-left-color:#7c3aed}.tutorial-slot.past{color:#111827;background:#11182714;border-left-color:#111827}.tutorial-slot.is-selected{outline:3px solid #064d902e;transform:translateY(-1px);box-shadow:0 10px 18px #064d9014}.tutorial-slot-legend-item.tutorial{color:#0a3559}.tutorial-slot-legend-item.tutorial .tutorial-slot-legend-dot{background:#0a3559}.tutorials-inline-meta,.tutorials-inline-hint{border-radius:12px;margin:0;padding:12px 14px;font-size:.86rem}.tutorials-inline-meta{color:var(--ink-700);background:#0a35590a;border:1px solid #0a355914;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.tutorials-inline-hint{color:#7f1d1d;background:#b91c1c14;border-left:4px solid #dc2626}.tutorial-detail-backdrop{z-index:70;background:#0f172a66;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.tutorial-detail-modal{background:#fff;border:1px solid #0a35591a;border-radius:18px;gap:18px;width:min(760px,100%);max-height:90vh;padding:22px;display:grid;overflow:auto;box-shadow:0 22px 40px #0f172a2e}.tutorial-detail-header{justify-content:space-between;gap:16px;display:flex}.tutorial-detail-header h3,.tutorial-detail-header p{margin:0}.tutorial-detail-header h3{color:var(--ink-900);margin-top:6px}.tutorial-detail-header p{color:var(--ink-700);margin-top:8px;line-height:1.6}.tutorial-detail-kicker{color:#0a3559;text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;font-weight:800}.tutorial-detail-close{color:var(--ink-900);cursor:pointer;width:40px;height:40px;font:inherit;background:#0a355914;border:none;border-radius:10px;font-weight:800}.tutorial-detail-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;display:grid}.tutorial-detail-hero{grid-template-columns:minmax(0,1.7fr) minmax(200px,.9fr);align-items:start;gap:16px;display:grid}.tutorial-detail-hero-copy{gap:6px;display:grid}.tutorial-detail-hero-badges{flex-wrap:wrap;justify-content:flex-end;align-items:flex-start;gap:10px;display:flex}.tutorial-detail-badge{color:#0a3559;letter-spacing:.03em;background:linear-gradient(135deg,#0a35591f,#1255a01a);border-radius:999px;justify-content:center;align-items:center;padding:10px 14px;font-size:.82rem;font-weight:800;display:inline-flex}.tutorial-detail-badge.subtle{color:#7a5500;background:#fcd02529}.tutorial-detail-card{background:#0a35590d;border:1px solid #0a35591f;border-radius:14px;gap:6px;padding:14px 16px;display:grid}.tutorial-detail-card span{text-transform:uppercase;letter-spacing:.08em;color:var(--ink-700);font-size:.74rem;font-weight:700}.tutorial-detail-card.emphasis{background:linear-gradient(#0a355914,#1255a00a)}.tutorial-detail-card strong{color:var(--ink-900);font-size:.94rem}.tutorial-detail-enrolled{gap:10px;display:grid}.tutorial-detail-enrolled strong{color:var(--ink-900)}.tutorial-detail-enrolled-list{flex-wrap:wrap;gap:8px;display:flex}.tutorial-detail-enrolled-list span{color:var(--ink-800);background:#0a35590f;border-radius:999px;padding:8px 12px;font-size:.84rem}.tutorial-detail-story{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;display:grid}.tutorial-detail-story-card{background:linear-gradient(#ffffffeb,#0a35590a);border:1px solid #0a355914;border-radius:16px;gap:8px;padding:16px 18px;display:grid}.tutorial-detail-story-card span{letter-spacing:.08em;text-transform:uppercase;color:#0a3559;font-size:.75rem;font-weight:800}.tutorial-detail-story-card p{color:var(--ink-800);margin:0;line-height:1.65}.tutorial-detail-hint{color:var(--ink-700);background:#0a35590d;border:1px solid #0a355914;border-radius:14px;margin:0;padding:14px 16px;line-height:1.6}.tutorial-detail-actions{justify-content:flex-end;align-items:center;gap:10px;display:flex}.tutorial-detail-primary{box-shadow:0 14px 28px #0a355929}.tutorials-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;display:grid}.tutorial-card{background:linear-gradient(#fff 0%,#064d9008 100%);border:1px solid #0a355914;border-radius:18px;gap:14px;padding:18px;transition:transform .16s,box-shadow .16s,border-color .16s;display:grid}.tutorial-card:hover{transform:translateY(-2px);box-shadow:0 16px 28px #0a355914}.tutorial-card.is-focused,.tutorial-focus-panel{border-color:#064d9038;box-shadow:0 18px 34px #064d901a}.tutorial-card.is-enrolled{background:radial-gradient(circle at 100% 0,#fcd02529,#0000 24%),linear-gradient(#fff 0%,#fcd0250a 100%);border-color:#fcd02552}.tutorial-card-head{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.tutorial-card-head h4{color:var(--ink-900);margin:8px 0 0;font-size:1rem}.tutorial-badge{color:#7a5500;text-transform:uppercase;letter-spacing:.08em;background:#fcd02533;border-radius:999px;align-items:center;padding:5px 10px;font-size:.74rem;font-weight:800;display:inline-flex}.tutorial-seats{color:#0b4a6f;font-size:.94rem}.tutorial-copy{color:var(--ink-700);margin:0;font-size:.9rem;line-height:1.6}.tutorial-meta,.tutorial-students,.tutorial-enrolled-list{gap:6px;display:grid}.tutorial-meta span,.tutorial-students span,.tutorial-enrolled-list span,.tutorial-enrolled-list p{color:var(--ink-700);margin:0;font-size:.84rem}.tutorial-students strong,.tutorial-enrolled-list strong{color:var(--ink-900);font-size:.82rem}.tutorial-status-pill{color:#166534;background:#15803d14;border:1px solid #16a34a29;border-radius:999px;justify-self:start;align-items:center;padding:6px 10px;font-size:.78rem;font-weight:700;display:inline-flex}.tutorial-status-pill.active{color:#0a3559;background:#0a355914;border-color:#0a355924}.tutorial-focus-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;display:grid}.tutorial-focus-hero{color:#fff;background:radial-gradient(circle at 100% 0,#fcd0252e,#0000 28%),linear-gradient(135deg,#0a3559f5,#1255a0e6);border-radius:20px;grid-template-columns:minmax(0,1.6fr) minmax(210px,.8fr);gap:16px;padding:22px 24px;display:grid}.tutorial-focus-hero-copy{gap:8px;display:grid}.tutorial-focus-hero-copy h4{color:#fff;margin:0;font-size:clamp(1.35rem,2vw,1.8rem)}.tutorial-focus-hero-copy p{color:#ffffffe0;margin:0;line-height:1.7}.tutorial-focus-hero-side{text-align:right;align-content:start;justify-items:end;gap:10px;display:grid}.tutorial-focus-hero-side strong{color:#fff;font-size:1.25rem;font-family:var(--font-display)}.tutorial-focus-chip{color:#fff;background:#ffffff24;border:1px solid #ffffff38;border-radius:999px;align-items:center;padding:8px 12px;font-size:.84rem;font-weight:700;display:inline-flex}.tutorial-focus-card{background:#064d900d;border:1px solid #0a355914;border-radius:14px;gap:6px;padding:14px 16px;display:grid}.tutorial-focus-card span{text-transform:uppercase;letter-spacing:.08em;color:var(--ink-700);font-size:.74rem;font-weight:700}.tutorial-focus-card strong{color:var(--ink-900);font-size:.94rem}.tutorial-focus-copy{gap:8px;display:grid}.tutorial-focus-copy p{color:var(--ink-800);margin:0;line-height:1.6}.tutorial-focus-actions{justify-content:flex-end;display:flex}.tutorial-card-facts{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.tutorial-card-facts span{color:var(--ink-800);background:#0a35590d;border:1px solid #0a35590f;border-radius:12px;padding:11px 12px;font-size:.84rem}.tutorial-card-action-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.tutorials-actions{flex-wrap:wrap;gap:10px;display:flex}.tutorials-primary,.tutorials-secondary,.tutorials-danger{font:inherit;cursor:pointer;border:none;border-radius:11px;padding:10px 16px;font-size:.86rem;font-weight:800;transition:opacity .14s,transform .1s}.tutorials-primary:active,.tutorials-secondary:active,.tutorials-danger:active{transform:scale(.98)}.tutorials-primary{color:#fff;background:linear-gradient(135deg,#0a3559,#1255a0)}.tutorials-secondary{color:var(--ink-900);background:#0a355914;border:1px solid #0a35591f}.tutorials-danger{color:#991b1b;background:#b91c1c14;border:1px solid #b91c1c24}.tutorials-primary:hover,.tutorials-secondary:hover,.tutorials-danger:hover{opacity:.92}.tutorials-primary:disabled,.tutorials-secondary:disabled,.tutorials-danger:disabled{opacity:.5;cursor:not-allowed}.tutorials-empty,.tutorials-message{border-radius:12px;margin:0;padding:14px 18px}.tutorials-empty{color:var(--ink-700);background:#0a35590d;border:1px solid #0a355914}.tutorials-message.success{color:#166534;background:#15803d14;border-left:4px solid #16a34a}.tutorials-message.error{color:#7f1d1d;background:#b91c1c14;border-left:4px solid #dc2626}@media (width<=860px){.tutorials-header{flex-direction:column}.tutorials-panel{padding:18px}.tutorial-detail-hero,.tutorial-focus-hero{grid-template-columns:1fr}.tutorial-detail-hero-badges,.tutorial-focus-hero-side{text-align:left;justify-content:flex-start;justify-items:start}}@media (width<=640px){.tutorials-page{padding:14px 12px}.tutorials-form-grid,.tutorials-grid,.tutorial-card-facts{grid-template-columns:1fr}.tutorials-actions,.tutorial-detail-actions,.tutorial-card-action-row,.tutorial-focus-actions{flex-direction:column;align-items:stretch}}.tutorials-page{background:radial-gradient(circle at 86% 2%,#f4c5422b,#0000 28%),radial-gradient(circle at 4% 10%,#063f771c,#0000 25%),linear-gradient(135deg,#f7fafc 0%,#edf5fb 100%)}.tutorials-header{box-shadow:var(--shadow-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:radial-gradient(circle at 100% 0,#f4c54233,#0000 26%),#ffffffc7;border:1px solid #d8e2eee6;border-radius:28px;padding:clamp(20px,2vw,28px)}.tutorials-summary div{background:linear-gradient(#fff 0%,#063f770a 100%);border-radius:18px;box-shadow:0 16px 30px #0d223d14}.tutorials-panel{box-shadow:var(--shadow-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border-radius:28px}.tutorials-form input,.tutorials-form select,.tutorials-form textarea{border-radius:14px;min-height:44px}.tutorial-slot,.tutorial-card,.tutorial-focus-card,.tutorial-detail-card,.tutorial-detail-story-card{transition:transform .18s,box-shadow .18s,border-color .18s,background .18s}.tutorial-slot:not(:disabled):hover,.tutorial-card:hover,.tutorial-focus-card:hover,.tutorial-detail-card:hover,.tutorial-detail-story-card:hover{transform:translateY(-3px);box-shadow:0 22px 42px #0d223d1f}.tutorial-slot.tutorial{color:#123d75;background:linear-gradient(90deg,#123d7521,#123d750a);border-left-color:#123d75}.tutorial-detail-backdrop{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#07132294}.tutorial-detail-modal{background:radial-gradient(circle at 90% 0,#f4c54233,#0000 28%),linear-gradient(#fff 0%,#f8fbff 100%);border-radius:30px;padding:clamp(22px,3vw,34px);box-shadow:0 36px 72px #07132247}.tutorial-detail-close{border-radius:16px;transition:transform .16s,background .16s}.tutorial-detail-close:hover{background:#f4c54238;transform:rotate(3deg)scale(1.05)}.tutorial-detail-hero,.tutorial-focus-hero{border-radius:28px;box-shadow:0 28px 60px #0d223d2e}.tutorial-detail-badge,.tutorial-badge,.tutorial-focus-chip{letter-spacing:.08em}.tutorials-primary,.tutorials-secondary,.tutorials-danger{transition:transform .16s,box-shadow .16s,opacity .16s;box-shadow:0 12px 24px #0d223d14}.tutorials-primary:hover,.tutorials-secondary:hover,.tutorials-danger:hover{transform:translateY(-2px);box-shadow:0 18px 30px #0d223d1f}.sidebar{inset-block:0;z-index:40;background:radial-gradient(at 50% -10%,#ffffff61,#0000 30%),radial-gradient(circle at 18% 82%,#063f7724,#0000 26%),linear-gradient(175deg,#fcd84a 0%,#f0b800 48%,#d4930a 100%);flex-direction:column;width:248px;transition:transform .28s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;left:0;overflow:hidden;box-shadow:6px 0 32px #0d223d1f}.sidebar:before{content:"";pointer-events:none;z-index:0;background:linear-gradient(90deg,#ffffff1f,#0000 40%),url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23000000' fill-opacity='0.018'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");position:absolute;inset:0}.sidebar-brand{z-index:1;text-align:center;border-bottom:1px solid #00000014;flex-direction:column;flex-shrink:0;align-items:center;gap:14px;padding:28px 20px 22px;display:flex;position:relative}.sidebar-logo{object-fit:contain;background:#fff3;border:1px solid #0d223d2e;border-radius:22px;flex-shrink:0;width:82px;height:82px;padding:8px;transition:transform .2s,box-shadow .2s;box-shadow:0 12px 26px #0d223d29,inset 0 1px #ffffff59}.sidebar-logo:hover{transform:translateY(-1px);box-shadow:0 18px 34px #0d223d38,0 4px 8px #0000001f}.sidebar-brand-text{text-align:center;flex-direction:column;align-items:center;min-width:0;line-height:1.25;display:flex}.sidebar-kicker{letter-spacing:.04em;color:#0d223da6;text-transform:none;font-size:.68rem;font-weight:600;font-family:var(--font-ui)}.sidebar-title{font-size:1.38rem;font-family:var(--font-ui);color:#0a2540;letter-spacing:-.01em;font-weight:800;line-height:1}.sidebar-search-wrap{z-index:1;border-bottom:1px solid #00000014;padding:12px 12px 10px;position:relative}.sidebar-search{color:#0a2540ad;min-height:40px;transition:border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);background:#ffffff8f;border:1px solid #0a25402e;border-radius:12px;align-items:center;gap:8px;padding:0 10px;display:flex}.sidebar-search svg{opacity:.82;flex-shrink:0}.sidebar-search input{color:#0a2540;width:100%;font:inherit;font-family:var(--font-ui);background:0 0;border:0;outline:0;font-size:.84rem}.sidebar-search input::placeholder{color:#0a254085}.sidebar-search:focus-within{background:#ffffffc7;border-color:#063f7785;box-shadow:0 0 0 3px #063f7724}.sidebar-search-hint{color:#0a25409e;margin:8px 2px 0;font-size:.72rem;font-weight:600}.sidebar-nav{z-index:1;scrollbar-width:thin;scrollbar-color:#00000026 transparent;flex-direction:column;flex:1;gap:3px;padding:14px 12px;display:flex;position:relative;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-thumb{background:#00000026;border-radius:2px}.sidebar-group{gap:3px;display:grid}.sidebar-group-title{letter-spacing:.12em;text-transform:uppercase;color:#0a254073;font-size:.64rem;font-weight:800;font-family:var(--font-display);margin:8px 2px 4px;padding:0 10px}.sidebar-link{color:#0a2540b8;font-size:.9rem;font-weight:600;font-family:var(--font-ui);transition:background var(--transition-fast), color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast), border-left-color var(--transition-fast);box-sizing:border-box;letter-spacing:0;border-left:3px solid #0000;border-radius:12px;align-items:center;gap:11px;min-height:44px;padding:10px 14px;line-height:1.35;text-decoration:none;display:flex;position:relative}.sidebar-link svg{opacity:.75;transition:opacity var(--transition-fast), transform var(--transition-fast);flex-shrink:0}.sidebar-link:hover{color:#0a2540;background:#ffffff7a;transform:translate(2px)}.sidebar-link:hover svg{opacity:1;transform:scale(1.08)}.sidebar-link--active{color:var(--ucb-blue,#063f77);border-left-color:var(--ucb-blue,#063f77);background:#ffffffb8;font-weight:700;box-shadow:0 4px 14px #0d223d1a}.sidebar-link--active svg{opacity:1;color:var(--ucb-blue,#063f77)}.sidebar-link--active:hover{color:var(--ucb-blue,#063f77);background:#fffc;transform:none}.sidebar-link--subsection{color:#0a25409e;min-height:38px;padding-block:8px;font-size:.82rem}.sidebar-subsection-line{white-space:nowrap;text-overflow:ellipsis;display:inline-block;overflow:hidden}.sidebar-empty-results{color:#0a2540b3;background:#ffffff6b;border:1px dashed #0a254033;border-radius:12px;margin:10px 4px;padding:12px 14px;font-size:.8rem;line-height:1.45}.sidebar-footer{z-index:1;border-top:1px solid #00000017;flex-direction:column;flex-shrink:0;gap:8px;padding:12px 12px 16px;display:flex;position:relative}.sidebar-user{transition:background var(--transition-fast);background:#ffffff70;border:1px solid #ffffff80;border-radius:12px;align-items:center;gap:10px;padding:10px 12px;display:flex;box-shadow:0 4px 12px #0d223d0f}.sidebar-user:hover{background:#ffffff8f}.sidebar-user-avatar{color:#fcd025;width:36px;height:36px;font-size:.9rem;font-weight:800;font-family:var(--font-display);letter-spacing:0;background:linear-gradient(135deg,#0a2540,#0d3260);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex;box-shadow:0 4px 10px #0a25404d}.sidebar-user-info{flex-direction:column;min-width:0;line-height:1.3;display:flex}.sidebar-user-name{color:#0a2540;white-space:nowrap;text-overflow:ellipsis;font-size:.83rem;font-weight:700;font-family:var(--font-ui);overflow:hidden}.sidebar-user-role{color:#0a25408f;text-transform:capitalize;white-space:nowrap;text-overflow:ellipsis;font-size:.7rem;font-weight:500;overflow:hidden}.sidebar-logout{color:#991b1b;width:100%;font:inherit;font-family:var(--font-ui);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);text-align:left;background:#b91c1c0f;border:1px solid #b91c1c2e;border-radius:12px;align-items:center;gap:10px;min-height:42px;padding:10px 14px;font-size:.875rem;font-weight:600;display:flex}.sidebar-logout:hover{color:#7f1d1d;background:#b91c1c24;border-color:#b91c1c47;transform:translate(2px)}.sidebar-topbar{z-index:50;background:radial-gradient(circle at 92%,#ffffff38,#0000 28%),linear-gradient(135deg,#fcd84a 0%,#e8a800 100%);border-bottom:1px solid #00000017;justify-content:space-between;align-items:center;height:58px;padding:0 16px;display:none;position:fixed;top:0;left:0;right:0;box-shadow:0 2px 16px #0000001f}.sidebar-brand-mobile{align-items:center;gap:10px;display:flex}.sidebar-brand-mobile-text{flex-direction:column;gap:2px;display:flex}.sidebar-brand-mobile-kicker{color:#0a2540;font-size:.7rem;font-weight:600;line-height:1}.sidebar-brand-mobile-title{color:#0a2540;font-size:.95rem;font-family:var(--font-display);letter-spacing:-.01em;font-weight:800;line-height:1}.sidebar-brand-mobile .sidebar-logo{border-radius:12px;width:46px;height:46px;padding:5px;box-shadow:0 4px 12px #0d223d29}.sidebar-brand-mobile span{color:#0a2540b3;font-size:.72rem;font-weight:600;line-height:1}.sidebar-brand-mobile strong{color:#0a2540;font-size:1rem;font-family:var(--font-display);letter-spacing:-.01em;font-weight:800;display:block}.sidebar-toggle{color:#0a2540;cursor:pointer;width:40px;height:40px;transition:background var(--transition-fast), border-color var(--transition-fast);background:#0a254014;border:1px solid #0a25402e;border-radius:10px;justify-content:center;align-items:center;display:flex}.sidebar-toggle:hover{background:#0a254026;border-color:#0a254047}.sidebar-toggle:active{transform:scale(.98)}.sidebar-overlay{z-index:39;-webkit-backdrop-filter:blur(3px);background:#040f1c8a;animation:.2s both fadeIn;display:none;position:fixed;inset:0}@media (width<=860px){.sidebar-topbar{display:flex}.sidebar-overlay{display:block}.sidebar{box-shadow:none;top:0;transform:translate(-100%)}.sidebar--open{transform:translate(0);box-shadow:8px 0 32px #0000003d}.sidebar-brand{padding-top:72px}}.sidebar-nav-divider{background:#00000014;border:none;height:1px;margin:6px 4px}.sidebar-nav-label{letter-spacing:.12em;text-transform:uppercase;color:#0a254073;font-size:.62rem;font-weight:700;font-family:var(--font-display);padding:8px 14px 4px}.notification-bell{position:relative}.notification-bell-trigger{width:42px;height:42px;color:var(--ink-900);cursor:pointer;background:#fff;border:1px solid #0a25401f;border-radius:999px;justify-content:center;align-items:center;display:inline-flex;position:relative;box-shadow:0 2px 10px #0a25400f}.notification-bell-trigger:hover{background:var(--surface-200)}.notification-bell-count{color:#fff;background:#dc2626;border-radius:999px;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 6px;font-size:.72rem;font-weight:800;display:inline-flex;position:absolute;top:-5px;right:-4px;box-shadow:0 4px 10px #dc26264d}.notification-bell-panel{border:1px solid var(--line-300);z-index:60;background:#fff;border-radius:18px;width:min(420px,100vw - 32px);max-height:min(70vh,560px);position:absolute;top:calc(100% + 10px);right:0;overflow:auto;box-shadow:0 24px 48px #0a25402e}.notification-bell-header{z-index:1;border-bottom:1px solid var(--line-300);background:#fff;justify-content:space-between;align-items:center;gap:12px;padding:16px 18px;display:flex;position:sticky;top:0}.notification-bell-header strong{color:var(--ink-900);display:block}.notification-bell-header small{color:var(--ink-700)}.notification-bell-action,.notification-bell-mark{background:var(--surface-200);color:var(--ink-900);font:inherit;cursor:pointer;border:1px solid #0a25401f;border-radius:10px;padding:8px 12px;font-size:.82rem;font-weight:700}.notification-bell-action:disabled{opacity:.45;cursor:not-allowed}.notification-bell-empty{color:var(--ink-700);margin:0;padding:18px}.notification-bell-list{display:grid}.notification-bell-item{border-bottom:1px solid #0a35590f;grid-template-columns:1fr auto;gap:12px;padding:14px 16px;display:grid}.notification-bell-link{text-align:left;cursor:pointer;background:0 0;border:none;gap:6px;padding:0;display:grid}.notification-bell-item-head{justify-content:space-between;gap:10px;display:flex}.notification-bell-item-head strong{color:var(--ink-900);font-size:.92rem}.notification-bell-item-head small{color:var(--ink-700);white-space:nowrap;font-size:.76rem}.notification-bell-link p{color:var(--ink-800);margin:0;font-size:.86rem;font-weight:600}.notification-bell-summary{color:var(--ink-700);font-size:.8rem;line-height:1.5}.notification-bell-change-card{background:#0923400a;border:1px solid #09234014;border-radius:14px;gap:8px;padding:10px 12px;display:grid}.notification-bell-change-row{gap:4px;display:grid}.notification-bell-change-row>span{letter-spacing:.04em;text-transform:uppercase;color:var(--ink-700);font-size:.72rem;font-weight:700}.notification-bell-change-values{flex-direction:column;gap:4px;display:flex}.notification-bell-old,.notification-bell-new{border-radius:999px;align-items:center;width:fit-content;padding:4px 10px;font-size:.8rem;line-height:1.3;display:inline-flex}.notification-bell-old{color:#8d1531;background:#b32f541f;text-decoration:line-through}.notification-bell-new{color:#0b5b5f;background:#0c7c871f}@media (width<=640px){.notification-bell-panel{right:-8px}.notification-bell-item{grid-template-columns:1fr}}.notification-bell-trigger{background:radial-gradient(circle at 35% 25%,#ffffffe6,#0000 34%),linear-gradient(135deg,#fff,#f1f6fb);transition:transform .16s,box-shadow .16s,background .16s;box-shadow:0 14px 26px #0d223d1f}.notification-bell-trigger:hover{transform:translateY(-2px);box-shadow:0 20px 36px #0d223d29}.notification-bell-count{border:2px solid #fff}.notification-bell-panel{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:radial-gradient(circle at 90% 0,#f4c54229,#0000 26%),#fffffff5;border-radius:26px;box-shadow:0 34px 70px #0713223d}.notification-bell-header{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffe0}.notification-bell-item{transition:background .16s,transform .16s}.notification-bell-item:hover{background:#063f770b}.notification-bell-item.is-unread{background:linear-gradient(90deg,#063f771a,#f4c54214)}.notification-bell-action,.notification-bell-mark{transition:transform .16s,box-shadow .16s,background .16s}.notification-bell-action:hover:not(:disabled),.notification-bell-mark:hover{transform:translateY(-2px);box-shadow:0 12px 22px #0d223d1f}.notification-bell-item-head strong{font-family:var(--font-ui);font-weight:700}.notification-bell-header strong{font-family:var(--font-display);letter-spacing:-.02em;font-size:1.05rem;font-weight:800}.notification-bell-link p{font-family:var(--font-ui)}.notification-bell-unread-dot{background:var(--ucb-blue);border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:2s ease-in-out infinite pulseBlue}@keyframes pulseBlue{0%,to{box-shadow:0 0 #063f7766}50%{box-shadow:0 0 0 4px #063f7700}}.notification-bell-empty{text-align:center;font-size:.9rem;font-family:var(--font-ui);padding:32px 24px}.app-layout{background:radial-gradient(circle at 10% 6%,#f4c54224,#0000 24%),radial-gradient(circle at 88% 4%,#063f771a,#0000 26%),linear-gradient(135deg,#eef5fb 0%,#f8fbff 52%,#edf3f9 100%);min-height:100dvh;display:flex}.home-main{flex-direction:column;flex:1;min-height:100dvh;margin-left:248px;display:flex;overflow:hidden}.home-toolbar{z-index:30;-webkit-backdrop-filter:blur(20px);transition:background var(--transition-base), box-shadow var(--transition-base);background:#ffffffd1;border-bottom:1px solid #d8e2eeb3;justify-content:space-between;align-items:center;gap:16px;padding:14px 28px;display:flex;position:sticky;top:0;box-shadow:0 4px 20px #0d223d0f}.home-toolbar-copy{flex-direction:column;gap:2px;display:flex}.home-toolbar-copy strong{color:var(--ink-900);font-size:.96rem;font-weight:700;font-family:var(--font-ui)}.home-toolbar-copy span{color:var(--ink-700);font-size:.82rem}.home-toolbar-actions{align-items:center;gap:10px;display:flex}.content-window{flex-direction:column;flex:1;animation:.28s both pageIn;display:flex;position:relative;overflow:auto}.section-help-trigger-wrap{z-index:15;margin:0;position:absolute;top:14px;right:18px}.section-help-trigger{color:#0a2540;width:36px;height:36px;font:inherit;cursor:pointer;transition:transform var(--transition-fast), box-shadow var(--transition-fast), filter var(--transition-fast);background:radial-gradient(circle at 28% 24%,#ffffff6b,#0000 46%),linear-gradient(145deg,#fcd84a,#e9b30b);border:1px solid #0a254038;border-radius:999px;font-size:1rem;font-weight:800;line-height:1;box-shadow:0 10px 24px #0d223d24}.section-help-trigger:hover{filter:saturate(1.08);transform:translateY(-1px);box-shadow:0 16px 30px #0d223d33}.section-help-trigger:focus-visible{outline:0;box-shadow:0 0 0 3px #063f772e,0 12px 26px #0d223d2e}.home-placeholder{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:18px;padding:clamp(32px,5vw,64px);display:flex;position:relative}.home-placeholder:before{content:"";pointer-events:none;background:radial-gradient(circle at 80% 15%,#f4c5421a,#0000 30%);border-radius:32px;position:absolute;inset:0}.home-placeholder>*{position:relative}.home-placeholder-icon{background:radial-gradient(circle at 30% 20%,#ffffffe0,#0000 36%),linear-gradient(135deg,#063f771a,#f4c54238);border-radius:32px;justify-content:center;align-items:center;width:108px;height:108px;display:flex;overflow:hidden;box-shadow:0 20px 44px #0d223d1f}.home-placeholder-icon img{object-fit:contain;filter:drop-shadow(0 4px 8px #00000026);width:72px;height:72px}.home-placeholder h2{font-family:var(--font-display);color:var(--ink-900);letter-spacing:-.04em;margin:0;font-size:clamp(2.2rem,4vw,3.4rem);font-weight:800}.home-placeholder-subtitle{max-width:480px;color:var(--ink-700);margin:0;font-size:1rem;line-height:1.65}.home-placeholder-hint{max-width:500px;color:var(--ink-700);border:1px solid var(--line-300);text-align:left;box-shadow:var(--shadow-card);background:#ffffffe6;border-radius:18px;margin:0;padding:16px 22px;font-size:.9rem;line-height:1.7}.home-admin-overview{gap:18px;width:min(900px,100%);display:grid}.home-admin-card-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;display:grid}.home-admin-card{box-shadow:var(--shadow-card);text-align:left;transition:transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);background:#fffffff0;border:1px solid #d8e2eee6;border-radius:22px;gap:8px;padding:22px 20px;display:grid}.home-admin-card:hover{border-color:#063f772e;transform:translateY(-3px);box-shadow:0 24px 50px #0d223d21}.home-admin-card.is-primary{box-shadow:var(--shadow-blue);background:radial-gradient(circle at 90% 10%,#f4c54233,#0000 28%),linear-gradient(135deg,#041f3a 0%,#063f77 55%,#1260aa 100%);border-color:#0a35594d}.home-admin-card span{text-transform:uppercase;letter-spacing:.1em;color:var(--ink-700);font-size:.72rem;font-weight:700;font-family:var(--font-display)}.home-admin-card strong{font-family:var(--font-display);color:var(--ink-900);letter-spacing:-.04em;font-size:2.6rem;font-weight:800;line-height:1}.home-admin-card p{color:var(--ink-700);margin:0;font-size:.86rem;line-height:1.55}.home-admin-card.is-primary span,.home-admin-card.is-primary strong,.home-admin-card.is-primary p{color:#fff}.home-admin-card.is-primary span{color:#ffffffb8}.home-admin-badges{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.home-admin-badge{color:var(--ink-800);transition:background var(--transition-fast), border-color var(--transition-fast);background:#063f7712;border:1px solid #063f7721;border-radius:999px;align-items:center;gap:7px;padding:8px 14px;font-size:.84rem;font-weight:600;display:inline-flex}.home-admin-badge:hover{background:#063f771f;border-color:#063f7733}.home-admin-badge strong{color:var(--ucb-blue);font-size:1rem;font-weight:800;font-family:var(--font-display)}.home-admin-badge svg{color:var(--ucb-blue);opacity:.8}.home-role-note{color:var(--ink-700);background:#063f770d;border:1px solid #063f771a;border-radius:16px;margin:0;padding:14px 18px;font-size:.9rem;line-height:1.55}.home-empty-note{text-align:center;max-width:560px;margin:0 auto}.home-dashboard{flex-direction:column;flex:1;display:flex}.home-showcase{width:min(1280px,100%);font-family:var(--font-ui);gap:clamp(22px,3vw,36px);margin:0 auto;padding:clamp(20px,3vw,40px);display:grid}.home-modern-hero{color:#fff;background:radial-gradient(circle at 88% 8%,#ffbc6e4d,#0000 26%),radial-gradient(circle at 6% 96%,#ffffff12,#0000 28%),linear-gradient(108deg,#071e36 0%,#0b3d63 50%,#1a5f8a 100%);border-radius:clamp(28px,3vw,44px);grid-template-columns:minmax(0,1.3fr) minmax(300px,.7fr);align-items:center;gap:clamp(26px,4vw,56px);min-height:480px;padding:clamp(32px,5vw,66px);display:grid;position:relative;overflow:hidden;box-shadow:0 32px 72px #04122247}.home-modern-hero:before,.home-modern-hero:after{content:"";pointer-events:none;border-radius:50%;position:absolute}.home-modern-hero:before{background:#ffffff0f;width:360px;height:360px;top:-130px;right:-100px}.home-modern-hero:after{background:#ffffff0a;width:260px;height:260px;bottom:-120px;left:-70px}.home-modern-hero-copy,.home-modern-hero-panel{z-index:1;position:relative}.home-modern-brand{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff1a;border:1px solid #ffffff26;border-radius:22px;align-items:center;gap:14px;margin-bottom:28px;padding:10px 16px 10px 10px;display:inline-flex}.home-modern-brand img{object-fit:contain;background:#fffffff5;border-radius:16px;width:58px;height:58px;padding:7px;box-shadow:0 10px 22px #0003}.home-modern-brand div{gap:2px;display:grid}.home-modern-brand span{letter-spacing:.14em;text-transform:uppercase;color:#ffffffb3;font-size:.68rem;font-weight:700;font-family:var(--font-display)}.home-modern-brand strong{font-family:var(--font-display);letter-spacing:-.01em;color:#fff;font-size:1.4rem;font-weight:800}.home-modern-kicker{color:#ffbc6e;letter-spacing:.18em;text-transform:uppercase;font-size:.74rem;font-weight:700;font-family:var(--font-display);margin:0 0 14px}.home-modern-hero h1{font-family:var(--font-display);letter-spacing:-.05em;color:#fff;margin:0;font-size:clamp(2.4rem,5.5vw,4.8rem);font-weight:800;line-height:.98}.home-modern-tagline{color:#ffffffd1;border-left:4px solid #ffbc6e;max-width:640px;margin:22px 0 0;padding-left:18px;font-size:clamp(.95rem,1.6vw,1.15rem);line-height:1.75}.home-modern-actions{flex-wrap:wrap;gap:14px;margin-top:32px;display:flex}.home-modern-primary,.home-modern-secondary{min-height:50px;font:inherit;font-family:var(--font-ui);cursor:pointer;transition:transform var(--transition-base), box-shadow var(--transition-base);border:0;border-radius:999px;justify-content:center;align-items:center;gap:10px;padding:0 26px;font-size:.95rem;font-weight:700;display:inline-flex}.home-modern-primary{color:#071e36;background:linear-gradient(135deg,#ffbc6e,#f4c542);box-shadow:0 14px 30px #f4c5424d}.home-modern-secondary{color:#fff;box-shadow:none;background:#ffffff1f;border:1px solid #ffffff3d!important}.home-modern-primary:hover{transform:translateY(-3px);box-shadow:0 22px 42px #f4c54261}.home-modern-secondary:hover{background:#fff3!important;transform:translateY(-3px)!important;box-shadow:0 12px 28px #00000024!important}.home-modern-hero-panel{gap:14px;display:grid}.home-modern-hero-panel article{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:background var(--transition-fast);background:#ffffff1a;border:1px solid #ffffff29;border-radius:24px;grid-template-columns:auto 1fr;align-items:center;gap:3px 14px;padding:20px 22px;display:grid;box-shadow:0 16px 36px #0000001f}.home-modern-hero-panel article:hover{background:#ffffff26}.home-modern-hero-panel svg{color:#ffbc6e;grid-row:span 3}.home-modern-hero-panel span{color:#ffffffa6;text-transform:uppercase;letter-spacing:.14em;font-size:.68rem;font-weight:700;font-family:var(--font-display)}.home-modern-hero-panel strong{color:#fff;font-size:1.05rem;font-weight:800}.home-modern-hero-panel p{color:#ffffffb3;font-size:.88rem;line-height:1.5}.home-modern-section{background:radial-gradient(circle at 96% 0,#f4c5421a,#0000 28%),#ffffffeb;border:1px solid #dce8f0f2;border-radius:clamp(28px,3vw,38px);padding:clamp(26px,4vw,44px);box-shadow:0 20px 50px #0d223d17}.home-modern-section-head{gap:8px;margin-bottom:26px;display:grid}.home-modern-section-head h2{font-family:var(--font-display);letter-spacing:-.04em;color:var(--ink-900);margin:0;font-size:clamp(1.7rem,3vw,2.6rem);font-weight:800;line-height:1.05}.home-feature-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;display:grid}.home-feature-card{text-align:center;min-height:220px;transition:transform var(--transition-base), box-shadow var(--transition-base);background:#fff;border:1px solid #dce8f0e6;border-radius:26px;align-content:start;justify-items:center;gap:14px;padding:28px 22px;display:grid;box-shadow:0 12px 28px #0d223d12}.home-feature-card:hover{border-color:#063f7724;transform:translateY(-5px);box-shadow:0 26px 46px #0d223d21}.home-feature-card span{width:68px;height:68px;color:var(--ucb-blue);background:linear-gradient(145deg,#063f7714,#f4c5421f);border-radius:22px;justify-content:center;align-items:center;display:inline-flex}.home-feature-card h3{color:var(--ink-900);font-size:1.05rem;font-weight:700;font-family:var(--font-display);letter-spacing:-.02em;margin:0}.home-feature-card p{color:var(--ink-700);margin:0;font-size:.9rem;line-height:1.6}.home-modern-labs{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;display:grid}.home-modern-labs article{text-align:center;min-height:200px;transition:transform var(--transition-base), box-shadow var(--transition-base);background:#fff;border:1px solid #dce8f0e6;border-radius:26px;justify-items:center;gap:12px;padding:28px 22px;display:grid;box-shadow:0 12px 28px #0d223d12}.home-modern-labs article:hover{transform:translateY(-4px);box-shadow:0 22px 42px #0d223d1f}.home-modern-labs span{width:64px;height:64px;color:var(--ucb-blue);background:linear-gradient(145deg,#063f7714,#f4c5421f);border-radius:20px;justify-content:center;align-items:center;display:inline-flex}.home-modern-labs h3{color:var(--ink-900);font-size:1.05rem;font-weight:700;font-family:var(--font-display);letter-spacing:-.02em;margin:0}.home-modern-labs p{color:var(--ink-700);margin:0;font-size:.88rem}.home-role-panel{border:1px solid #f1b24a4d;border-left:6px solid var(--ucb-gold);background:radial-gradient(circle at 96% 0,#f4c5421f,#0000 26%),linear-gradient(135deg,#fef7e6f2,#ffffffeb);border-radius:clamp(28px,3vw,38px);grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr);align-items:center;gap:clamp(20px,3vw,36px);padding:clamp(26px,4vw,44px);display:grid;box-shadow:0 20px 48px #0d223d17}.home-role-panel h2{font-family:var(--font-display);letter-spacing:-.04em;color:var(--ink-900);margin:0 0 12px;font-size:clamp(1.6rem,2.8vw,2.4rem);font-weight:800}.home-role-panel>div>p{color:var(--ink-700);margin:0;font-size:.95rem;line-height:1.65}.home-role-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.home-role-grid button{min-height:160px;color:var(--ink-900);text-align:left;cursor:pointer;transition:transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);font-family:var(--font-ui);background:#fffffff5;border:1px solid #dce8f0f2;border-radius:22px;align-content:start;gap:10px;padding:22px 18px;display:grid;box-shadow:0 10px 24px #0d223d12}.home-role-grid button:hover{border-color:#f4c54266;transform:translateY(-4px);box-shadow:0 22px 44px #0d223d21}.home-role-grid svg{color:var(--ucb-gold-strong)}.home-role-grid strong{color:var(--ink-900);font-size:.98rem;font-weight:700;font-family:var(--font-display);letter-spacing:-.01em}.home-role-grid span{color:var(--ink-700);font-size:.88rem;line-height:1.45}.home-role-note-modern{color:#8a6b24;border:1px solid #f4c5424d;border-left:6px solid var(--ucb-gold);background:#f4c5421a;border-radius:20px;padding:18px 24px;font-size:.9rem;font-weight:600;line-height:1.55}@media (width<=1100px){.home-modern-hero,.home-role-panel{grid-template-columns:1fr}.home-modern-labs,.home-role-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=860px){.home-main{margin-left:0;padding-top:58px}.home-toolbar{padding:12px 18px;top:58px}}@media (width<=700px){.home-showcase{gap:18px;padding:14px}.home-modern-hero,.home-modern-section,.home-role-panel{border-radius:24px;padding:22px 18px}.home-modern-hero h1{font-size:clamp(2rem,11vw,3rem)}.home-modern-actions{flex-direction:column}.home-modern-primary,.home-modern-secondary{width:100%}.home-modern-hero-panel article{grid-template-columns:1fr}.home-modern-hero-panel svg{grid-row:auto}.home-feature-grid,.home-modern-labs,.home-role-grid,.home-admin-card-grid{grid-template-columns:1fr}}@media (width<=480px){.home-toolbar{flex-direction:column;align-items:stretch;gap:10px;padding:10px 14px}.home-toolbar-actions{justify-content:flex-end}}
