.notification-trigger{position:relative;display:inline-flex}.animated-bell{position:relative;display:flex;align-items:center;justify-content:center;gap:.5rem;animation:bell-shake 2s infinite}.animated-bell .pi-bell{font-size:1.4rem;animation:bell-swing .8s ease-in-out infinite alternate;transform-origin:top center}.p-button-icon{margin-left:6px}@keyframes bell-swing{0%{transform:rotate(0deg)}25%{transform:rotate(-10deg)}50%{transform:rotate(10deg)}75%{transform:rotate(-5deg)}to{transform:rotate(5deg)}}@keyframes bell-shake{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.notification-trigger .notification-header-btn--dark.p-button{background:transparent;border:1px solid rgba(255,255,255,.4);color:#fff;width:2.5rem;height:2.5rem;box-shadow:none}.notification-trigger .notification-header-btn--dark.p-button:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.75);color:#fff}.notification-trigger .notification-header-btn--dark .pi-bell{color:#fff}.notification-trigger .notification-header-btn--light.p-button{background:#f3f4f6;border:1px solid #e5e7eb;color:#374151;width:2.5rem;height:2.5rem;box-shadow:none}.notification-trigger .notification-header-btn--light.p-button:hover{background:#e5e7eb;border-color:#d1d5db;color:#111827}.notification-trigger .notification-header-btn--light .pi-bell{color:#374151}.exam-notif-backdrop{position:fixed;inset:0;z-index:9998;background:transparent}.exam-notif-panel{--accent:#5648fc;--accent-soft:rgba(86,72,252,0.1);position:fixed;z-index:9999;display:flex;flex-direction:column;width:min(420px,94vw);max-height:78vh;background:#fff;border:1px solid #eceef3;border-radius:16px;box-shadow:0 20px 50px -12px rgba(16,24,40,.28),0 8px 18px -10px rgba(16,24,40,.2);overflow:hidden;transform-origin:top right;animation:panel-pop .16s ease-out}@keyframes panel-pop{0%{opacity:0;transform:translateY(-6px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.exam-notif-head{position:relative;display:flex;align-items:center;justify-content:space-between;gap:.6rem;padding:.7rem .85rem;background:linear-gradient(135deg,#5648fc,#7d6eff);color:#fff}.exam-notif-head__title{display:flex;align-items:center;gap:.55rem}.exam-notif-head__icon{display:grid;place-items:center;width:32px;height:32px;border-radius:10px;background:rgba(255,255,255,.18);font-size:1rem}.exam-notif-head h2{margin:0;font-size:.98rem;font-weight:700;line-height:1.2}.exam-notif-head p{margin:1px 0 0;font-size:.72rem;opacity:.85}.exam-notif-close{display:grid;place-items:center;width:30px;height:30px;border:none;border-radius:9px;background:rgba(255,255,255,.16);color:#fff;cursor:pointer;font-size:.85rem;transition:background .15s ease}.exam-notif-close:hover{background:rgba(255,255,255,.3)}.exam-notif-search{position:relative;display:flex;align-items:center;padding:.6rem .85rem .35rem}.exam-notif-search .pi-search{position:absolute;left:1.4rem;color:#9aa1b1;font-size:.82rem}.exam-notif-search input{width:100%;padding:.5rem 2.1rem .5rem 2.15rem;font-size:.86rem;color:#1f2433;background:#f5f6fa;border:1px solid #eceef3;border-radius:12px;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.exam-notif-search input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:#fff}.exam-notif-search__clear{position:absolute;right:1.3rem;display:grid;place-items:center;width:22px;height:22px;border:none;border-radius:50%;background:#e3e5ec;color:#565d70;cursor:pointer;font-size:.65rem}.exam-notif-search__clear:hover{background:#d3d6e0}.exam-notif-cats{flex:0 0 auto;display:flex;align-items:center;gap:.4rem;padding:.4rem .85rem .6rem;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;border-bottom:1px solid #f0f1f5}.exam-notif-cats::-webkit-scrollbar{display:none}.exam-notif-chip{flex:0 0 auto;padding:.35rem .8rem;font-size:.76rem;line-height:1.4;font-weight:600;color:#4b5163;background:#f1f2f7;border:1px solid transparent;border-radius:999px;cursor:pointer;white-space:nowrap;transition:all .15s ease}.exam-notif-chip:hover{background:#e6e7f0}.exam-notif-chip.is-active{color:#fff;background:var(--accent);box-shadow:0 4px 10px -3px rgba(86,72,252,.6)}.exam-notif-body{flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:.5rem .85rem .9rem;overscroll-behavior:contain}.exam-notif-body::-webkit-scrollbar{width:8px}.exam-notif-body::-webkit-scrollbar-thumb{background:#d7dae3;border-radius:8px}.exam-notif-body::-webkit-scrollbar-thumb:hover{background:#c2c6d3}.exam-notif-group{margin-top:.6rem}.exam-notif-group__title{display:flex;align-items:center;gap:.5rem;margin:.4rem 0 .6rem;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#8a90a2}.exam-notif-group__title span{display:grid;place-items:center;min-width:20px;height:20px;padding:0 6px;font-size:.68rem;color:var(--accent);background:var(--accent-soft);border-radius:999px}.exam-notif-grid{display:grid;grid-template-columns:1fr;gap:.45rem}.exam-notif-empty{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:3rem 1rem;color:#9aa1b1;text-align:center}.exam-notif-empty .pi{font-size:2rem}.exam-notif-empty p{margin:0;font-size:.88rem}.exam-card{display:flex;align-items:stretch;gap:.65rem;padding:.5rem .6rem;background:#fff;border:1px solid #edeef2;border-radius:12px;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.exam-card:hover{border-color:#d8d9f7;box-shadow:0 8px 20px -12px rgba(86,72,252,.45);transform:translateY(-1px)}.exam-card__logo{flex:0 0 auto;display:grid;place-items:center;width:42px;height:42px;padding:4px;background:#f6f7fb;border:1px solid #eef0f5;border-radius:10px}.exam-card__logo img{max-width:100%;max-height:100%;object-fit:contain}.exam-card__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:.3rem}.exam-card__top{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}.exam-card__name{margin:0;font-size:.92rem;font-weight:700;color:#1f2433;line-height:1.25;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.exam-card__date{flex:0 0 auto;display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .5rem;font-size:.72rem;font-weight:600;color:#5b6072;background:#f3f4f8;border-radius:8px;white-space:nowrap}.exam-card__date .pi,.exam-status{font-size:.7rem}.exam-status{display:inline-flex;align-items:center;gap:.3rem;align-self:flex-start;padding:.13rem .5rem;font-weight:600;border-radius:999px}.exam-status__dot{width:7px;height:7px;border-radius:50%;background:currentColor}.exam-status--ongoing{color:#0f9d58;background:rgba(15,157,88,.1)}.exam-status--upcoming{color:#d97706;background:rgba(217,119,6,.1)}.exam-status--over{color:#dc2626;background:rgba(220,38,38,.1)}.exam-card__actions{display:flex;gap:.45rem;margin-top:.05rem}.exam-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.3rem;padding:.35rem .5rem;font-size:.76rem;font-weight:600;text-decoration:none;border-radius:9px;cursor:pointer;transition:background .15s ease,opacity .15s ease}.exam-btn .pi{font-size:.72rem}.exam-btn--apply{color:#fff;background:#5648fc}.exam-btn--apply:hover{background:#4536e8}.exam-btn--official{color:#0f9d58;background:rgba(15,157,88,.1)}.exam-btn--official:hover{background:rgba(15,157,88,.18)}.exam-btn.is-disabled{color:#9aa1b1;background:#f0f1f5;cursor:not-allowed;pointer-events:none}.exam-notif-panel--sheet{inset:auto 0 0 0!important;left:0!important;top:auto!important;width:100%!important;max-width:100%!important;max-height:88vh!important;border-radius:22px 22px 0 0;border:none;transform-origin:bottom center;animation:sheet-up .22s ease-out}.exam-notif-panel--sheet .exam-notif-head{padding-top:1.25rem}.exam-notif-panel--sheet .exam-notif-head:before{content:"";position:absolute;top:8px;left:50%;transform:translateX(-50%);width:40px;height:4px;border-radius:4px;background:rgba(255,255,255,.6)}@media (max-width:640px){.exam-notif-backdrop{background:rgba(16,24,40,.5);backdrop-filter:blur(2px)}}@keyframes sheet-up{0%{opacity:.4;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@media (max-width:380px){.exam-card{padding:.6rem;gap:.6rem}.exam-card__logo{width:44px;height:44px}.exam-card__name{font-size:.86rem}.exam-card__actions{gap:.4rem}}