@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.landing-header{padding:16px 24px}.landing-main{padding:100px 28px 40px}.login-card{padding:36px 32px}.desktop-nav{display:flex!important}.mobile-nav-toggle{display:none!important}.mobile-menu{display:block}@media (max-width:900px){.landing-grid{text-align:center;grid-template-columns:1fr!important;gap:32px!important}.landing-grid>div:first-child{flex-direction:column;align-items:center;display:flex}.landing-grid>div:first-child p{text-align:center}.login-card label{text-align:left!important;display:block!important}.login-card form{text-align:left!important}}@media (max-width:768px){.desktop-nav{display:none!important}.mobile-nav-toggle{display:flex!important}}@media (max-width:640px){.landing-header{padding:10px 12px}.landing-header .landing-nav{border-radius:var(--radius-lg)!important;padding:8px 14px!important}.landing-header .landing-nav span{font-size:1.05rem!important}.landing-main{align-items:flex-start;padding:80px 16px 24px}.landing-grid{gap:24px!important}.login-card{padding:24px 20px!important}.login-card h2{font-size:1.2rem!important}.login-card label{text-align:left!important;display:block!important}.login-card form{text-align:left!important}.login-card .input-field{padding:13px 14px 13px 42px!important;font-size:16px!important}.login-card form>div:nth-child(2) .input-field{padding-right:48px!important}.login-card .btn-primary{padding:14px!important;font-size:.95rem!important}.mobile-menu{margin-left:12px!important;margin-right:12px!important}.footer-brand{flex-direction:column!important;gap:2px!important}.footer-sep{display:none!important}}@media (max-width:380px){.landing-header{padding:8px}.landing-header .landing-nav{padding:6px 10px!important}.landing-main{padding:72px 12px 16px}.login-card{padding:20px 16px!important}}
.v-header{z-index:500;background:color-mix(in srgb,var(--bg-primary)78%,transparent);-webkit-backdrop-filter:blur(28px)saturate(1.3);border-bottom:1px solid var(--border-color);width:100%;font-family:Plus Jakarta Sans,Inter,system-ui,sans-serif;position:sticky;top:0}.v-header-inner{justify-content:space-between;align-items:center;max-width:100%;min-height:48px;padding:8px 24px;display:flex}.v-header-left{align-items:center;gap:12px;min-width:0;display:flex}.v-header-titles{flex-direction:column;min-width:0;display:flex}.v-header-page{color:var(--text-primary);letter-spacing:-.02em;white-space:nowrap;text-overflow:ellipsis;font-family:Plus Jakarta Sans,Inter,sans-serif;font-size:1.1rem;font-weight:700;line-height:1.2;overflow:hidden}.v-header-greeting{color:var(--text-tertiary);letter-spacing:.01em;margin-top:4px;font-family:Plus Jakarta Sans,sans-serif;font-size:.7rem;font-weight:500;line-height:1.3}.v-header-right{align-items:center;gap:4px;display:flex}.v-header-btn{cursor:pointer;width:38px;height:38px;color:var(--text-secondary);-webkit-tap-highlight-color:transparent;background:0 0;border:1px solid #0000;border-radius:10px;outline:none;justify-content:center;align-items:center;display:flex;position:relative}.v-header-btn:hover{background:var(--bg-hover,#0000000a);border-color:var(--border-color);color:var(--text-primary)}[data-theme=dark] .v-header-btn:hover{background:#ffffff0f}.v-header-menu{border:1px solid var(--border-color);color:var(--accent);border-radius:9px;display:none}.v-header-badge{background:var(--accent);color:#fff;min-width:16px;height:16px;box-shadow:0 0 0 2px var(--bg-primary);pointer-events:none;border-radius:100px;justify-content:center;align-items:center;padding:0 4px;font-family:Plus Jakarta Sans,sans-serif;font-size:.56rem;font-weight:800;line-height:1;display:flex;position:absolute;top:4px;right:4px}@media (max-width:768px){.v-header-inner{min-height:52px;padding:10px 16px}.v-header-menu{display:flex}.v-header-page{font-size:.95rem}.v-header-greeting{font-size:.64rem}.v-header-btn{border-radius:9px;width:34px;height:34px}.v-header-badge{min-width:14px;height:14px;font-size:.52rem}}@media (max-width:360px){.v-header-inner{padding:8px 12px}}
.v-sidebar-overlay{z-index:999;-webkit-backdrop-filter:blur(12px)saturate(1.1);background:#00000073;position:fixed;inset:0}.v-sidebar{z-index:1000;flex-shrink:0;height:100vh}.v-sidebar-desktop{width:252px;position:sticky;top:0}.v-sidebar-mobile{width:280px;position:fixed;top:0;bottom:0;left:0}.v-sidebar-inner{background:var(--bg-primary);border-right:1px solid var(--border-color);flex-direction:column;width:100%;height:100%;padding:18px 14px 14px;font-family:Plus Jakarta Sans,Inter,system-ui,sans-serif;display:flex;position:relative;overflow:hidden}.v-sidebar-inner:before{content:"";background:radial-gradient(circle,hsla(var(--accent-h),70%,60%,.07)0%,transparent 70%);pointer-events:none;border-radius:50%;width:200px;height:200px;animation:12s ease-in-out infinite alternate v-sidebar-orb-drift;position:absolute;top:-60px;left:-40px}.v-sidebar-inner:after{content:"";pointer-events:none;background:radial-gradient(circle,#8152e00d 0%,#0000 70%);border-radius:50%;width:220px;height:220px;animation:15s ease-in-out infinite alternate-reverse v-sidebar-orb-drift;position:absolute;bottom:-80px;right:-60px}@keyframes v-sidebar-orb-drift{0%{transform:translate(0)scale(1)}to{transform:translate(12px,8px)scale(1.08)}}.v-sidebar-mobile .v-sidebar-inner{padding-top:max(env(safe-area-inset-top,18px),18px)}.v-sidebar-brand{justify-content:space-between;align-items:center;margin-bottom:22px;padding:0 6px;display:flex}.v-sidebar-brand-left{align-items:center;gap:9px;display:flex}.v-sidebar-logo{background:var(--gradient-primary);width:30px;height:30px;box-shadow:0 2px 8px hsla(var(--accent-h),var(--accent-s),var(--accent-l),.3),0 0 0 1px hsla(var(--accent-h),var(--accent-s),var(--accent-l),.1);border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.v-sidebar-brand-name{background:var(--gradient-primary);-webkit-text-fill-color:transparent;letter-spacing:.12em;-webkit-background-clip:text;background-clip:text;font-family:Space Grotesk,Plus Jakarta Sans,sans-serif;font-size:.92rem;font-weight:800}.v-sidebar-close{border:1px solid var(--border-color);cursor:pointer;width:28px;height:28px;color:var(--text-tertiary);background:0 0;border-radius:8px;justify-content:center;align-items:center;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.v-sidebar-close:hover{color:#ef4444;background:#ef444414;border-color:#ef444433}.v-sidebar-profile{border:1px solid var(--border-color);cursor:pointer;text-align:left;background:0 0;border-radius:12px;align-items:center;gap:10px;width:100%;margin:0 2px 18px;padding:10px;font-family:inherit;display:flex;position:relative;overflow:hidden}.v-sidebar-profile:before{content:"";background:linear-gradient(135deg,hsla(var(--accent-h),var(--accent-s),var(--accent-l),0)0%,hsla(var(--accent-h),var(--accent-s),var(--accent-l),0)100%);border-radius:12px;transition:background .35s cubic-bezier(.4,0,.2,1);position:absolute;inset:0}.v-sidebar-profile:hover:before{background:linear-gradient(135deg,hsla(var(--accent-h),var(--accent-s),var(--accent-l),.04)0%,hsla(var(--accent-h),var(--accent-s),var(--accent-l),.08)100%)}.v-sidebar-profile-avatar{background:var(--accent-light);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex;position:relative;overflow:hidden}.v-sidebar-profile-avatar img{object-fit:cover;width:100%;height:100%}.v-sidebar-profile-avatar span{color:var(--accent);font-family:Plus Jakarta Sans,sans-serif;font-size:.72rem;font-weight:800}.v-sidebar-online-dot{border:2px solid var(--bg-primary);background:#22c55e;border-radius:50%;width:10px;height:10px;position:absolute;bottom:-1px;right:-1px}.v-sidebar-profile-info{z-index:1;flex-direction:column;flex:1;min-width:0;display:flex;position:relative}.v-sidebar-profile-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-family:Plus Jakarta Sans,Inter,sans-serif;font-size:.8rem;font-weight:700;line-height:1.25;overflow:hidden}.v-sidebar-profile-label{color:var(--text-tertiary);font-family:Plus Jakarta Sans,sans-serif;font-size:.64rem;font-weight:500;line-height:1.3}.v-sidebar-profile-chevron{color:var(--text-tertiary);opacity:0;z-index:1;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;transform:translate(-4px)}.v-sidebar-profile:hover .v-sidebar-profile-chevron{opacity:1;transform:translate(0)}.v-sidebar-nav{scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:hsla(var(--accent-h),var(--accent-s),var(--accent-l),.15)transparent;flex:1;padding:0 2px;overflow:hidden auto}.v-sidebar-nav::-webkit-scrollbar{width:3px}.v-sidebar-nav::-webkit-scrollbar-track{background:0 0}.v-sidebar-nav::-webkit-scrollbar-thumb{background:hsla(var(--accent-h),var(--accent-s),var(--accent-l),.18);border-radius:10px;transition:background .2s}.v-sidebar-nav::-webkit-scrollbar-thumb:hover{background:hsla(var(--accent-h),var(--accent-s),var(--accent-l),.35)}.v-sidebar-nav{-webkit-mask-image:linear-gradient(#0000 0,#000 8px calc(100% - 8px),#0000 100%);mask-image:linear-gradient(#0000 0,#000 8px calc(100% - 8px),#0000 100%)}.v-sidebar-group{margin-bottom:20px}.v-sidebar-group-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.12em;margin-bottom:6px;padding:0 10px;font-family:Plus Jakarta Sans,sans-serif;font-size:.58rem;font-weight:700}.v-sidebar-group-items{flex-direction:column;gap:2px;display:flex}.v-sidebar-link{cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:10px;outline:none;align-items:center;gap:10px;width:100%;padding:8px 10px;font-family:inherit;display:flex;position:relative}.v-sidebar-link:after{content:"";opacity:0;background:var(--bg-hover,#00000008);pointer-events:none;border-radius:10px;transition:opacity .2s cubic-bezier(.4,0,.2,1);position:absolute;inset:0}.v-sidebar-link:hover:after{opacity:1}[data-theme=dark] .v-sidebar-link:after{background:#ffffff0a}.v-sidebar-link-bg{background:var(--bg-hover,#0000000a);z-index:0;border-radius:10px;position:absolute;inset:0}[data-theme=dark] .v-sidebar-link-bg{background:#ffffff0f}.v-sidebar-link-pill{background:var(--accent);width:3px;height:16px;box-shadow:0 0 8px hsla(var(--accent-h),var(--accent-s),var(--accent-l),.4);border-radius:0 4px 4px 0;margin-top:-8px;position:absolute;top:50%;left:0}.v-sidebar-link-icon{width:30px;height:30px;color:var(--text-tertiary);z-index:1;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:color .2s,background .2s;display:flex;position:relative}.v-sidebar-link:hover .v-sidebar-link-icon{color:var(--text-secondary)}.v-sidebar-link.is-active .v-sidebar-link-icon{color:var(--item-color,var(--accent));background:color-mix(in srgb,var(--item-color,var(--accent))12%,transparent)}.v-sidebar-link-text{color:var(--text-secondary);z-index:1;font-family:Plus Jakarta Sans,Inter,sans-serif;font-size:.8rem;font-weight:500;transition:color .2s,font-weight .2s;position:relative}.v-sidebar-link:hover .v-sidebar-link-text{color:var(--text-primary)}.v-sidebar-link.is-active .v-sidebar-link-text{color:var(--text-primary);font-weight:650}.v-sidebar-footer{border-top:1px solid var(--border-color);margin-top:auto;padding-top:10px}.v-sidebar-signout{cursor:pointer;width:100%;color:var(--text-tertiary);background:0 0;border:none;border-radius:10px;align-items:center;gap:8px;padding:8px 10px;font-family:Plus Jakarta Sans,Inter,sans-serif;font-size:.78rem;font-weight:600;display:flex}.v-sidebar-signout:hover{color:#ef4444;background:#ef44440f}.v-sidebar-install{border:1px dashed var(--border-color);cursor:pointer;text-align:left;background:0 0;border-radius:12px;align-items:center;gap:12px;width:100%;margin-bottom:8px;padding:10px 12px;font-family:inherit;transition:all .2s;display:flex}.v-sidebar-install:hover{border-style:solid;border-color:var(--accent)}.v-sidebar-install-icon{background:var(--gradient-primary);color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.v-sidebar-install-text{flex-direction:column;flex:1;gap:1px;display:flex}.v-sidebar-install-title{color:var(--text-primary);font-size:.78rem;font-weight:700}.v-sidebar-install-desc{color:var(--text-tertiary);font-size:.62rem;font-weight:500}.v-sidebar-install-share{color:var(--accent);opacity:.8}.v-sidebar-close:active{transform:scale(.9)}
@keyframes bn-badge-pop{0%{opacity:0;transform:scale(.3)}60%{opacity:1;transform:scale(1.2)}to{opacity:1;transform:scale(1)}}@keyframes bn-icon-bounce{0%{transform:translateY(0)scale(1)}35%{transform:translateY(-5px)scale(1.15)}65%{transform:translateY(1px)scale(.96)}to{transform:translateY(0)scale(1)}}.appl-bn-wrapper{z-index:9999;padding-bottom:env(safe-area-inset-bottom,0px);pointer-events:none;justify-content:center;align-items:flex-end;display:flex;position:fixed;bottom:0;left:0;right:0}@media (min-width:769px){.appl-bn-wrapper{display:none}}.appl-bn-bar{pointer-events:auto;background:var(--appl-bar-bg,#ffffffeb);-webkit-backdrop-filter:blur(50px)saturate(200%);border:1px solid var(--appl-bar-border,#ffffff8c);border-radius:26px;align-items:stretch;gap:0;width:calc(100% - 32px);max-width:440px;margin-bottom:14px;padding:8px 4px;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 6px #0000000a,0 12px 40px #00000024,inset 0 1px #ffffffe6}[data-theme=dark] .appl-bn-bar{--appl-bar-bg:#0d1117f2;--appl-bar-border:#ffffff1a;box-shadow:0 4px 6px #00000040,0 12px 40px #0000008c,inset 0 1px #ffffff0f}.appl-bn-bar:before{content:"";pointer-events:none;background:linear-gradient(90deg,#0000 0%,#ffffffa6 30% 70%,#0000 100%);border-radius:1px;height:1px;position:absolute;top:0;left:12px;right:12px}[data-theme=dark] .appl-bn-bar:before{background:linear-gradient(90deg,#0000 0%,#ffffff1f 30% 70%,#0000 100%)}.appl-bn-slider{background:var(--appl-pill-bg,#00000012);pointer-events:none;border-radius:18px;position:absolute;top:6px;bottom:6px}[data-theme=dark] .appl-bn-bar .appl-bn-slider{--appl-pill-bg:#ffffff1a}.appl-bn-item{cursor:pointer;z-index:1;-webkit-tap-highlight-color:transparent;color:var(--text-tertiary);background:0 0;border:none;border-radius:18px;outline:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;min-width:0;padding:6px 0 5px;transition:color .25s;display:flex;position:relative}.appl-bn-item.active{color:var(--accent)}.appl-bn-icon{justify-content:center;align-items:center;width:28px;height:28px;transition:transform .2s cubic-bezier(.34,1.56,.64,1);display:flex}.appl-bn-item.active .appl-bn-icon{animation:.38s cubic-bezier(.34,1.56,.64,1) forwards bn-icon-bounce}.appl-bn-item:active .appl-bn-icon{transform:scale(.82)}.appl-bn-label{letter-spacing:.015em;white-space:nowrap;opacity:.45;font-family:-apple-system,SF Pro Text,Inter,sans-serif;font-size:.585rem;font-weight:600;line-height:1;transition:opacity .25s,font-weight .2s}.appl-bn-item.active .appl-bn-label{opacity:1;font-weight:700}@media (max-width:360px){.appl-bn-label{display:none}.appl-bn-bar{border-radius:0;width:100%;margin-bottom:0}}
.gtg-bar{border-radius:var(--radius-full);background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);box-shadow:var(--shadow-sm);-ms-overflow-style:none;scrollbar-width:none;align-items:center;gap:2px;width:100%;padding:4px;display:flex;overflow-x:auto}.gtg-bar::-webkit-scrollbar{display:none}.gtg-btn{border-radius:var(--radius-full);cursor:pointer;color:var(--text-tertiary);white-space:nowrap;isolation:isolate;background:0 0;border:none;padding:7px 20px;font-family:Space Grotesk,sans-serif;font-size:.8rem;font-weight:600;transition:color .22s;position:relative}.gtg-label{z-index:2;position:relative}.gtg-btn.active .gtg-label{color:var(--accent);font-weight:700}.gtg-slider{border-radius:var(--radius-full);z-index:1;background:#ffffffeb;border:1px solid #fff9;position:absolute;inset:0;box-shadow:0 1px 4px #0000001f,0 3px 10px #00000014}[data-theme=dark] .gtg-slider{background:#ffffff24;border:1px solid #ffffff1f;box-shadow:0 1px 4px #0006,0 2px 8px #0000004d}.sfp-btn{border-radius:var(--radius-full);border:1.5px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;padding:6px 13px;font-size:.76rem;font-weight:600}.sfp-btn.active{border-color:var(--accent);background:var(--accent-light);color:var(--accent)}@keyframes ui-shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.ui-sk{background:linear-gradient(90deg,var(--bg-tertiary)25%,var(--bg-hover)50%,var(--bg-tertiary)75%);border-radius:var(--radius-sm);background-size:800px 100%;animation:1.4s ease-in-out infinite ui-shimmer}@keyframes rb-spin{to{transform:rotate(360deg)}}.rb-spin{animation:.9s linear infinite rb-spin}
.jobs-page-container{width:100%;padding:12px 20px 120px}.page-grid-2col{columns:2;column-gap:12px}.page-grid-2col>*{break-inside:avoid;margin-bottom:12px}@media (max-width:768px){.page-grid-2col{columns:1}.page-grid-2col>*{margin-bottom:10px}.jobs-page-container{padding:12px 16px 120px}}.job-card{border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(16px);transition:box-shadow var(--transition-base),border-color var(--transition-base);overflow:hidden}.job-card:hover{box-shadow:var(--shadow-md);border-color:var(--accent)}.job-chip{border-radius:var(--radius-full);align-items:center;gap:3px;padding:2px 7px;font-family:Space Grotesk,sans-serif;font-size:.67rem;font-weight:700;display:inline-flex}.job-empty{text-align:center;color:var(--text-tertiary);padding:48px 20px}.loc-pills{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:6px;padding-bottom:4px;display:flex;overflow-x:auto}.loc-pills::-webkit-scrollbar{display:none}.loc-pill{border-radius:var(--radius-full);border:1px solid var(--border-color);background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);cursor:pointer;color:var(--text-secondary);flex-shrink:0;padding:5px 14px;font-family:Space Grotesk,sans-serif;font-size:.75rem;font-weight:600;transition:all .2s}.loc-pill:hover{border-color:var(--accent);color:var(--accent)}.loc-pill.active{background:var(--gradient-primary);color:#fff;border-color:#0000;box-shadow:0 3px 10px #14b8a54d}.loc-search-wrap{margin-bottom:10px;position:relative}.loc-search-wrap .loc-icon{pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.loc-clear-btn{background:var(--bg-hover);border-radius:var(--radius-full);cursor:pointer;width:22px;height:22px;color:var(--text-tertiary);border:none;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}
.attendance-page-container{width:100%;padding:12px 20px 120px}@media (max-width:768px){.attendance-page-container{padding:12px 16px 120px}}.attn-course-card{border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(16px);cursor:pointer;transition:box-shadow var(--transition-base),border-color var(--transition-base);padding:16px 18px;position:relative;overflow:hidden}.attn-course-card:hover{box-shadow:var(--shadow-md);border-color:var(--accent)}.attn-bar-track{border-radius:var(--radius-full);background:var(--bg-tertiary);height:6px;margin:12px 0 0;overflow:hidden}.attn-chip{border-radius:var(--radius-full);letter-spacing:.02em;padding:2px 8px;font-family:Space Grotesk,sans-serif;font-size:.68rem;font-weight:700}.attn-empty{text-align:center;color:var(--text-tertiary);padding:48px 20px}
.marks-page-container{width:100%;padding:12px 20px 120px}@media (max-width:768px){.marks-page-container{padding:12px 16px 120px}}.mk-card{border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(16px);transition:box-shadow var(--transition-base),border-color var(--transition-base);overflow:hidden}.mk-card:hover{box-shadow:var(--shadow-md);border-color:var(--accent)}.mk-chip{border-radius:var(--radius-full);letter-spacing:.02em;padding:2px 8px;font-family:Space Grotesk,sans-serif;font-size:.68rem;font-weight:700}.mk-empty{text-align:center;color:var(--text-tertiary);padding:48px 20px}
.cal-page-container{width:100%;padding:12px 20px 120px}@media (max-width:768px){.cal-page-container{padding:12px 16px 120px}}.cal-near-row{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px;display:grid}.cal-split-layout{grid-template-columns:1fr 1fr;align-items:start;gap:16px;display:grid}@media (max-width:900px){.cal-split-layout{grid-template-columns:1fr}}.cal-calendar-panel{padding:14px}@media (min-width:901px){.cal-calendar-panel{padding:12px 14px;position:sticky;top:80px}}.cal-events-panel{min-height:200px;padding:18px}.cal-events-header{align-items:center;gap:8px;margin-bottom:14px;display:flex}.cal-events-header h3{color:var(--text-primary);margin:0;font-family:Plus Jakarta Sans,Inter,sans-serif;font-size:.9rem;font-weight:700}.cal-events-list{flex-direction:column;gap:6px;display:flex}.cal-events-empty{color:var(--text-tertiary);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:40px 20px;display:flex}.cal-events-empty p{margin:0;font-size:.82rem;font-weight:500}.cal-month-nav{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.cal-nav-btn{border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-card);width:34px;height:34px;color:var(--text-secondary);justify-content:center;align-items:center;transition:all .15s;display:flex}.cal-nav-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.cal-month-title{color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:1rem;font-weight:800}.cal-month-subtitle{color:var(--text-tertiary);margin-top:1px;font-size:.7rem}.cal-day-header{text-align:center;color:var(--text-tertiary);letter-spacing:.05em;text-transform:uppercase;padding:4px 0;font-size:.65rem;font-weight:700}.cal-selected-detail{border-radius:var(--radius-md);border:1px solid;align-items:flex-start;gap:12px;margin-top:14px;padding:12px 14px;display:flex}.cal-selected-date{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-family:Space Grotesk,sans-serif;font-size:.85rem;font-weight:800;display:flex}.cal-selected-badge{border-radius:var(--radius-full);background:var(--accent);color:#fff;flex-shrink:0;padding:3px 10px;font-family:Space Grotesk,sans-serif;font-size:.76rem;font-weight:800}.cal-legend{border-top:1px solid var(--border-color);flex-wrap:wrap;gap:14px;margin-top:14px;padding-top:12px;display:flex}.cal-legend-item{align-items:center;gap:5px;display:flex}.cal-legend-item span{color:var(--text-tertiary);font-size:.68rem;font-weight:500}.cal-legend-dot{border-radius:50%;width:8px;height:8px}.cal-event-item{border-radius:var(--radius-md);background:var(--bg-hover);cursor:pointer;align-items:flex-start;gap:12px;padding:11px 14px;transition:all .15s;display:flex}.cal-event-item:hover{background:var(--bg-card);transform:translate(2px)}.cal-event-item.holiday{border-left:3px solid var(--status-critical)}.cal-event-item.event{border-left:3px solid #148fb8}.cal-event-date-badge{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-family:Space Grotesk,sans-serif;font-size:.78rem;font-weight:800;display:flex}.cal-event-date-badge.holiday{color:var(--status-critical);background:#ef44441a}.cal-event-date-badge.event{color:#148fb8;background:#148fb81a}.cal-event-content{flex:1;min-width:0}.cal-event-title{color:var(--text-primary);font-size:.82rem;font-weight:600;line-height:1.3}.cal-event-meta{color:var(--text-tertiary);margin-top:2px;font-size:.7rem}.cal-event-icon{flex-shrink:0;align-items:center;gap:4px;display:flex}.cal-mode-bar{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.cal-mode-btn{border-radius:var(--radius-full);border:1.5px solid var(--border-color);background:var(--bg-card);cursor:pointer;transition:all var(--transition-fast);color:var(--text-secondary);padding:6px 14px;font-size:.76rem;font-weight:600}.cal-mode-btn.active{border-color:var(--accent);background:var(--accent-light);color:var(--accent)}.cal-mode-btn.holiday.active{border-color:var(--status-critical);color:var(--status-critical);background:#ef44441a}.cal-mode-btn.event.active{color:#148fb8;background:#148fb81a;border-color:#148fb8}.cal-grid{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.cal-day-cell{aspect-ratio:unset;border-radius:var(--radius-md);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;height:32px;min-height:32px;padding:4px 0;transition:transform .15s,box-shadow .15s;display:flex;position:relative}@media (min-width:901px){.cal-grid{gap:4px}.cal-day-cell{height:34px;min-height:34px}}.cal-day-cell:hover{box-shadow:var(--shadow-sm);transform:scale(1.08)}.cal-day-num{font-size:.82rem;font-weight:600;line-height:1}.cal-day-order{opacity:.75;margin-top:2px;font-family:Space Grotesk,sans-serif;font-size:.54rem;font-weight:700}.cal-dot{border-radius:50%;width:4px;height:4px;position:absolute;bottom:4px}
.pf-page{width:100%;min-height:100%;padding:0 20px 140px}.pf-hero{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-lg);margin-bottom:12px;padding:24px}.pf-hero__top{align-items:flex-start;gap:18px;display:flex}.pf-hero__avatar-wrap{flex-shrink:0;position:relative}.pf-hero__avatar{background:var(--bg-hover);border:2px solid var(--border-color);border-radius:18px;justify-content:center;align-items:center;width:72px;height:72px;display:flex;overflow:hidden}.pf-hero__avatar img{object-fit:cover;width:100%;height:100%}.pf-hero__initials{color:var(--accent);background:var(--accent-light);justify-content:center;align-items:center;width:100%;height:100%;font-family:Space Grotesk,sans-serif;font-size:1.4rem;font-weight:800;display:flex}.pf-hero__online{background:var(--status-safe,#22c55e);border:3px solid var(--bg-card);border-radius:50%;width:14px;height:14px;position:absolute;bottom:2px;right:2px}.pf-hero__info{flex:1;min-width:0}.pf-hero__name{color:var(--text-primary);letter-spacing:-.02em;margin:0;font-family:Space Grotesk,sans-serif;font-size:1.2rem;font-weight:800;line-height:1.25}.pf-hero__sub{color:var(--text-tertiary);margin:2px 0 0;font-size:.76rem;font-weight:500}.pf-hero__tags{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.pf-tag{border-radius:var(--radius-full);letter-spacing:.02em;white-space:nowrap;padding:3px 10px;font-size:.66rem;font-weight:600}.pf-tag--accent{background:var(--accent-light);color:var(--accent)}.pf-tag--muted{background:var(--bg-hover);color:var(--text-secondary)}.pf-hero__logout{border-radius:var(--radius-md);color:var(--status-critical,#ef4444);cursor:pointer;white-space:nowrap;background:#ef44440f;border:1px solid #ef444433;flex-shrink:0;align-items:center;gap:6px;padding:8px 14px;font-family:Inter,sans-serif;font-size:.76rem;font-weight:600;transition:all .18s;display:flex}.pf-hero__logout:hover{background:#ef444424;border-color:#ef444466}.pf-stats{border-top:1px solid var(--border-color);gap:0;margin-top:20px;padding-top:16px;display:flex}.pf-stat{flex-direction:column;flex:1;align-items:center;gap:2px;display:flex}.pf-stat__num{color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:1.15rem;font-weight:800;line-height:1}.pf-stat__label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;font-size:.64rem;font-weight:600}.pf-tabs{border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--glass-border);gap:4px;margin-bottom:12px;padding:4px;display:flex}.pf-tabs__btn{color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-sm);-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:7px;padding:10px 8px;font-family:Inter,sans-serif;font-size:.78rem;font-weight:600;transition:all .18s;display:flex}.pf-tabs__btn.active{background:var(--accent);color:#fff;box-shadow:0 2px 8px hsla(var(--accent-h),var(--accent-s),var(--accent-l),.25)}.pf-tabs__btn:not(.active):hover{background:var(--bg-hover);color:var(--text-secondary)}.pf-content{width:100%}.pf-grid{grid-template-columns:1fr;gap:12px;display:grid}.pf-card{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-lg);overflow:hidden}.pf-card__header{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border-color);background:var(--bg-hover);align-items:center;gap:8px;padding:12px 16px;font-size:.68rem;font-weight:700;display:flex}.pf-card__header svg{color:var(--accent)}.pf-card__body{padding:4px 0}.pf-detail{align-items:center;gap:12px;padding:10px 16px;transition:background .15s;display:flex}.pf-detail:hover{background:var(--bg-hover)}.pf-detail__icon{border-radius:var(--radius-sm);background:var(--accent-light);width:32px;height:32px;color:var(--accent);flex-shrink:0;justify-content:center;align-items:center;display:flex}.pf-detail__content{flex:1;min-width:0}.pf-detail__label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;font-size:.62rem;font-weight:600;line-height:1.2;display:block}.pf-detail__value{color:var(--text-primary);word-break:break-word;margin-top:1px;font-size:.84rem;font-weight:600;display:block}.pf-advisor{padding:14px 16px}.pf-advisor+.pf-advisor{border-top:1px solid var(--border-color)}.pf-advisor__badge{color:var(--accent);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;font-size:.6rem;font-weight:700}.pf-advisor__main{align-items:center;gap:12px;display:flex}.pf-advisor__avatar{color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-family:Space Grotesk,sans-serif;font-size:.72rem;font-weight:800;display:flex}.pf-advisor__info{flex:1;min-width:0}.pf-advisor__name{color:var(--text-primary);font-size:.84rem;font-weight:700}.pf-advisor__links{flex-wrap:wrap;gap:6px 14px;margin-top:4px;display:flex}.pf-advisor__link{color:var(--text-secondary);align-items:center;gap:4px;font-size:.7rem;font-weight:500;text-decoration:none;transition:color .15s;display:inline-flex}.pf-advisor__link:hover{color:var(--accent)}.pf-advisor__link svg{color:var(--accent);flex-shrink:0}.pf-posts{grid-template-columns:1fr;gap:10px;display:grid}.pf-post{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-lg);cursor:pointer;padding:14px 16px;transition:all .18s}.pf-post:hover{border-color:hsla(var(--accent-h),var(--accent-s),var(--accent-l),.22);box-shadow:0 2px 12px hsla(var(--accent-h),var(--accent-s),var(--accent-l),.06)}.pf-post__top{align-items:center;gap:8px;margin-bottom:8px;display:flex}.pf-post__tag{border-radius:var(--radius-full);padding:2px 8px;font-size:.62rem;font-weight:600}.pf-post__edited{color:var(--text-tertiary);font-size:.6rem;font-style:italic}.pf-post__time{color:var(--text-tertiary);margin-left:auto;font-size:.68rem}.pf-post__title{color:var(--text-primary);margin:0 0 4px;font-size:.88rem;font-weight:700;line-height:1.35}.pf-post__desc{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.78rem;line-height:1.5;display:-webkit-box;overflow:hidden}.pf-post__footer{align-items:center;gap:14px;margin-top:10px;display:flex}.pf-post__meta{color:var(--text-tertiary);align-items:center;gap:4px;font-size:.72rem;font-weight:600;display:flex}.pf-post__arrow{color:var(--text-tertiary);opacity:0;margin-left:auto;transition:opacity .15s}.pf-post:hover .pf-post__arrow{opacity:1}.pf-empty{text-align:center;color:var(--text-tertiary);padding:48px 20px}.pf-empty svg{opacity:.3;margin-bottom:12px}.pf-empty p{color:var(--text-secondary);margin:0 0 4px;font-size:.9rem;font-weight:600}.pf-empty span{font-size:.76rem}@media (min-width:720px){.pf-page{padding:0 28px 100px}.pf-hero{padding:28px 32px}.pf-grid{grid-template-columns:1fr 1fr}.pf-posts{grid-template-columns:repeat(2,1fr)}}@media (max-width:520px){.pf-page{padding:0 14px 120px}.pf-hero__top{flex-wrap:wrap}.pf-hero__logout{order:3;justify-content:center;width:100%;margin-top:8px}.pf-hero__logout span{display:inline}.pf-hero__avatar{border-radius:14px;width:60px;height:60px}.pf-hero__name{font-size:1.05rem}}
.community-page-container{width:100%;padding:12px 20px 120px}@media (max-width:768px){.community-page-container{padding:12px 16px 120px}}.community-card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:16px;margin-bottom:12px;transition:box-shadow .2s,border-color .2s;overflow:hidden;box-shadow:0 2px 12px #00000012}.community-card:hover{box-shadow:0 4px 20px #0000001f}.community-menu-btn{text-align:left;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:7px;align-items:center;gap:9px;width:100%;padding:8px 12px;font-size:.8rem;font-weight:600;transition:background .12s;display:flex}.community-menu-btn:hover{background:var(--bg-hover)}.community-input{border:1.5px solid var(--border-color);background:var(--bg-input);color:var(--text-primary);border-radius:10px;outline:none;padding:8px 12px;font-family:inherit;font-size:.85rem;transition:border-color .2s}.community-input:focus{border-color:var(--accent)}.tag-pill-scroll::-webkit-scrollbar{display:none}@keyframes skeleton-pulse{0%,to{opacity:.6}50%{opacity:1}}
.timetable-page-container{width:100%;padding:12px 20px 120px}@media (max-width:768px){.timetable-page-container{padding:12px 16px 120px}}.tt-tab-bar{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-full);scrollbar-width:none;align-items:center;gap:4px;padding:4px;display:flex;overflow-x:auto}.tt-tab-bar::-webkit-scrollbar{display:none}.tt-tab-btn{cursor:pointer;border-radius:var(--radius-full);color:var(--text-tertiary);z-index:1;white-space:nowrap;background:0 0;border:none;flex-shrink:0;padding:6px 14px;font-family:Space Grotesk,sans-serif;font-size:.75rem;font-weight:700;transition:color .18s;position:relative}.tt-tab-btn.active{color:#fff}.tt-tab-btn.today-tab{color:var(--accent)}.tt-tab-btn.today-tab.active{color:#fff}.tt-tab-slider{border-radius:var(--radius-full);background:var(--gradient-primary);z-index:0;pointer-events:none;height:100%;position:absolute;top:0;left:0}.tt-card{border-radius:var(--radius-lg);border:1px solid var(--glass-border);background:var(--bg-card);gap:0;margin-bottom:10px;transition:box-shadow .2s;display:flex;overflow:hidden}.tt-card:hover{box-shadow:var(--shadow-md)}.tt-time-col{border-right:1px solid var(--border-color);flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:4px;width:68px;padding:14px 8px;display:flex}.tt-time-start{color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:.78rem;font-weight:800}.tt-time-sep{color:var(--text-tertiary);font-size:.55rem}.tt-time-end{color:var(--text-secondary);font-family:Space Grotesk,sans-serif;font-size:.72rem;font-weight:600}.tt-slot-badge{border-radius:4px;margin-top:4px;padding:1px 6px;font-family:Space Grotesk,sans-serif;font-size:.58rem;font-weight:800}.tt-body{flex:1;min-width:0;padding:13px 14px}.tt-att-col{flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:54px;padding:0 10px;display:flex}.tt-empty{text-align:center;color:var(--text-tertiary);padding:40px 20px;font-size:.85rem}@keyframes spin{to{transform:rotate(360deg)}}
.notif-page{width:100%;padding:12px 20px 120px}@media (max-width:768px){.notif-page{padding:12px 16px 120px}}.notif-push-toggle{border-radius:12px;justify-content:space-between;align-items:center;gap:14px;height:auto;margin-bottom:16px;padding:14px 16px;transition:border-color .2s;display:flex}.notif-push-toggle:hover{border-color:var(--accent)}.notif-push-toggle__left{align-items:center;gap:12px;min-width:0;display:flex}.notif-push-toggle__icon{width:36px;height:36px;color:var(--text-tertiary);background:#0000000a;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;transition:all .2s;display:flex}[data-theme=dark] .notif-push-toggle__icon{background:#ffffff0f}.notif-push-toggle__icon.enabled{background:var(--gradient-primary);color:#fff}.notif-push-toggle__text{flex-direction:column;gap:2px;min-width:0;display:flex}.notif-push-toggle__title{color:var(--text-primary);font-family:Inter,-apple-system,sans-serif;font-size:.84rem;font-weight:600}.notif-push-toggle__desc{color:var(--text-tertiary);font-family:Inter,-apple-system,sans-serif;font-size:.72rem;line-height:1.3}.notif-push-toggle__btn{background:var(--gradient-primary);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;flex-shrink:0;padding:8px 18px;font-family:Inter,-apple-system,sans-serif;font-size:.76rem;font-weight:600;transition:all .2s}.notif-push-toggle__btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.notif-push-toggle__btn:active:not(:disabled){transform:scale(.97)}.notif-push-toggle__btn.enabled{color:var(--status-safe);cursor:default;background:#10b9811a}.notif-push-toggle__btn.blocked{color:var(--text-tertiary);cursor:default;background:#0000000a}[data-theme=dark] .notif-push-toggle__btn.blocked{background:#ffffff0f}@media (max-width:480px){.notif-push-toggle{padding:12px}.notif-push-toggle__icon{width:32px;height:32px}.notif-push-toggle__btn{padding:6px 12px;font-size:.7rem}}.notif-page-header{justify-content:space-between;align-items:center;margin-bottom:16px;padding:16px 0;display:flex}.notif-page-title{color:var(--text-primary);letter-spacing:-.02em;margin:0;font-family:Space Grotesk,sans-serif;font-size:clamp(1.3rem,3vw,1.65rem);font-weight:800;line-height:1.2}.notif-page-subtitle{color:var(--text-secondary);margin-top:3px;font-size:.82rem}.notif-actions{gap:12px;margin-bottom:20px;padding:0 4px;display:flex}.notif-action-btn{border-radius:var(--radius-md);border:1px solid var(--glass-border);background:var(--bg-card);-webkit-backdrop-filter:blur(12px);color:var(--text-secondary);cursor:pointer;align-items:center;gap:6px;padding:8px 14px;font-size:.82rem;font-weight:500;transition:all .2s;display:flex}.notif-action-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.notif-action-btn:disabled{opacity:.5;cursor:not-allowed}.notif-action-danger:hover:not(:disabled){border-color:var(--error);color:var(--error)}.notif-list{gap:14px}.notif-att-card{border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(16px);transition:all .25s;position:relative;overflow:hidden}.notif-att-card:hover{box-shadow:var(--shadow-md)}.notif-att-card.notif-unread{border-color:rgba(var(--accent-rgb),.3)}.notif-att-card.notif-present.notif-unread{background:linear-gradient(135deg,#10b9810f,var(--bg-card)40%);border-color:#10b98140}.notif-att-card.notif-absent.notif-unread{background:linear-gradient(135deg,#ef44440f,var(--bg-card)40%);border-color:#ef444440}.notif-att-card.notif-read{opacity:.7}.notif-att-collapsed{cursor:pointer;align-items:center;gap:12px;padding:14px 16px;display:flex;position:relative}.notif-att-status-icon-sm{border-radius:var(--radius-md);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.notif-att-status-icon-sm.present{background:linear-gradient(135deg,#10b981,#34d399)}.notif-att-status-icon-sm.absent{background:linear-gradient(135deg,#ef4444,#f87171)}.notif-att-collapsed-content{flex:1;min-width:0}.notif-att-collapsed-top{flex-wrap:wrap;align-items:flex-start;gap:8px;margin-bottom:3px;display:flex}.notif-att-status-text{text-transform:uppercase;letter-spacing:.04em;border-radius:var(--radius-full);padding:2px 7px;font-size:.68rem;font-weight:700}.notif-att-status-text.present{color:#10b981;background:#10b98126}.notif-att-status-text.absent{color:#ef4444;background:#ef444426}.notif-att-collapsed-subject{color:var(--text-primary);font-size:.88rem;font-weight:600}.notif-att-collapsed-bottom{align-items:center;gap:10px;display:flex}.notif-att-collapsed-stat{color:var(--text-tertiary);font-size:.72rem;font-weight:500}.notif-att-collapsed-slot{color:var(--text-tertiary);background:var(--bg-tertiary);border-radius:var(--radius-full);padding:2px 8px;font-size:.68rem}.notif-att-collapsed-right{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.notif-att-time{color:var(--text-tertiary);font-size:.7rem}.notif-att-expand-icon{color:var(--text-tertiary);opacity:.6}.notif-att-expanded{overflow:hidden}.notif-att-expanded-inner{border-top:1px solid var(--glass-border);padding:14px 16px 16px}.notif-att-stats{grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px;display:grid}.notif-att-stat-box{background:var(--bg-secondary);border-radius:var(--radius-sm);text-align:center;padding:10px 8px}.notif-att-stat-label{text-transform:uppercase;letter-spacing:.02em;color:var(--text-tertiary);margin-bottom:4px;font-size:.62rem;font-weight:600}.notif-att-stat-value{margin-bottom:3px;font-family:Space Grotesk,sans-serif;font-size:1rem;font-weight:800;line-height:1}.notif-att-stat-value.present{color:#10b981}.notif-att-stat-value.absent{color:#ef4444}.notif-att-stat-value.safe{color:#10b981}.notif-att-stat-value.critical{color:#f59e0b}.notif-att-stat-value.neutral{color:var(--text-secondary)}.notif-att-stat-desc{color:var(--text-tertiary);font-size:.64rem}.notif-att-stat-desc .trend-up{color:#10b981;align-items:center;gap:2px;display:inline-flex}.notif-att-stat-desc .trend-down{color:#ef4444;align-items:center;gap:2px;display:inline-flex}.notif-att-warning{border-radius:var(--radius-sm);color:#fca5a5;background:#ef44441a;border:1px solid #ef444433;align-items:center;gap:8px;margin-bottom:12px;padding:8px 12px;font-size:.72rem;display:flex}.notif-att-warning svg{color:#f87171;flex-shrink:0}.notif-att-actions{gap:8px;display:flex}.notif-att-action-btn{border-radius:var(--radius-sm);border:1px solid var(--glass-border);background:var(--bg-secondary);color:var(--text-tertiary);cursor:pointer;align-items:center;gap:4px;padding:6px 10px;font-size:.72rem;font-weight:500;transition:all .2s;display:flex}.notif-att-action-btn:hover{border-color:var(--accent);color:var(--accent)}.notif-att-action-btn.delete:hover{border-color:var(--error);color:var(--error)}.notif-card{border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(16px);cursor:pointer;align-items:flex-start;gap:14px;padding:16px;transition:all .2s;display:flex;position:relative}.notif-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md)}.notif-card.notif-read{opacity:.7}.notif-card.notif-unread{background:linear-gradient(135deg,rgba(var(--accent-rgb),.05),var(--bg-card))}.notif-icon{border-radius:var(--radius-md);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.notif-content{flex:1;min-width:0}.notif-card-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:4px;display:flex}.notif-card-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.92rem;font-weight:600;overflow:hidden}.notif-time{color:var(--text-tertiary);white-space:nowrap;font-size:.72rem}.notif-body{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.84rem;line-height:1.4;display:-webkit-box;overflow:hidden}.notif-actions-inline{opacity:0;flex-direction:column;gap:8px;transition:opacity .2s;display:flex}.notif-card:hover .notif-actions-inline{opacity:1}.notif-action-icon{border-radius:var(--radius-sm);background:var(--bg-tertiary);width:28px;height:28px;color:var(--text-tertiary);cursor:pointer;border:none;justify-content:center;align-items:center;transition:all .2s;display:flex}.notif-action-icon:hover{background:var(--accent);color:#fff}.notif-action-delete:hover{background:var(--error);color:#fff}.notif-unread-dot{background:var(--accent);width:8px;height:8px;box-shadow:0 0 8px rgba(var(--accent-rgb),.5);border-radius:50%;position:absolute;top:16px;left:8px}.notif-empty{text-align:center;color:var(--text-tertiary);flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.notif-empty svg{opacity:.5;margin-bottom:16px}.notif-empty p{color:var(--text-secondary);margin:0 0 4px;font-size:1rem;font-weight:500}.notif-empty span{font-size:.84rem}.notif-retry-btn{border-radius:var(--radius-md);border:1px solid var(--accent);color:var(--accent);cursor:pointer;background:0 0;margin-top:16px;padding:10px 20px;font-size:.84rem;font-weight:500;transition:all .2s}.notif-retry-btn:hover{background:var(--accent);color:#fff}.notif-skeleton-wrap{padding:0 4px}.notif-marks-card{border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(16px);transition:all .25s;position:relative;overflow:hidden}.notif-marks-card:hover{box-shadow:var(--shadow-md)}.notif-marks-card.notif-unread{border-color:rgba(var(--accent-rgb),.3)}.notif-marks-card.notif-improved.notif-unread{background:linear-gradient(135deg,#10b9810f,var(--bg-card)40%);border-color:#10b98140}.notif-marks-card.notif-declined.notif-unread{background:linear-gradient(135deg,#f59e0b0f,var(--bg-card)40%);border-color:#f59e0b40}.notif-marks-card.notif-read{opacity:.7}.notif-marks-collapsed{cursor:pointer;align-items:center;gap:12px;padding:14px 16px;display:flex;position:relative}.notif-marks-status-icon-sm{border-radius:var(--radius-md);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.notif-marks-status-icon-sm.improved{background:linear-gradient(135deg,#10b981,#34d399)}.notif-marks-status-icon-sm.declined{background:linear-gradient(135deg,#f59e0b,#fbbf24)}.notif-marks-collapsed-content{flex:1;min-width:0}.notif-marks-collapsed-top{flex-wrap:wrap;align-items:flex-start;gap:8px;margin-bottom:3px;display:flex}.notif-marks-status-text{text-transform:uppercase;letter-spacing:.04em;border-radius:var(--radius-full);padding:2px 7px;font-size:.68rem;font-weight:700}.notif-marks-status-text.improved{color:#10b981;background:#10b98126}.notif-marks-status-text.declined{color:#f59e0b;background:#f59e0b26}.notif-marks-collapsed-subject{color:var(--text-primary);font-size:.88rem;font-weight:600}.notif-marks-collapsed-bottom{align-items:center;gap:10px;display:flex}.notif-marks-collapsed-stat{color:var(--text-tertiary);font-size:.72rem;font-weight:500}.notif-marks-collapsed-code{color:var(--text-tertiary);background:var(--bg-tertiary);border-radius:var(--radius-full);padding:2px 8px;font-size:.68rem}.notif-marks-collapsed-right{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.notif-marks-time{color:var(--text-tertiary);font-size:.7rem}.notif-marks-expand-icon{color:var(--text-tertiary);opacity:.6}.notif-marks-expanded{overflow:hidden}.notif-marks-expanded-inner{border-top:1px solid var(--glass-border);padding:14px 16px 16px}.notif-marks-tests{background:var(--bg-secondary);border-radius:var(--radius-sm);flex-direction:column;gap:8px;margin-bottom:12px;padding:10px 12px;display:flex}.notif-marks-test-item{border-bottom:1px solid var(--glass-border);justify-content:space-between;align-items:center;padding:6px 0;display:flex}.notif-marks-test-item:last-child{border-bottom:none;padding-bottom:0}.notif-marks-test-item.new{border-radius:var(--radius-sm);background:#10b9810d;border-bottom:none;margin:-4px -8px;padding:6px 8px}.notif-marks-test-name{color:var(--text-secondary);font-size:.78rem;font-weight:500}.notif-marks-test-scores{align-items:center;gap:8px;display:flex}.notif-marks-old-score{color:var(--text-tertiary);opacity:.7;font-size:.76rem;text-decoration:line-through}.notif-marks-new-badge{color:#10b981;border-radius:var(--radius-full);background:#10b98126;padding:2px 5px;font-size:.6rem;font-weight:700}.notif-marks-arrow{color:var(--text-tertiary);opacity:.5;font-size:.72rem}.notif-marks-new-score{color:var(--text-primary);font-size:.82rem;font-weight:700}.notif-marks-stats{grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px;display:grid}.notif-marks-stat-box{background:var(--bg-secondary);border-radius:var(--radius-sm);text-align:center;padding:10px 8px}.notif-marks-stat-label{text-transform:uppercase;letter-spacing:.02em;color:var(--text-tertiary);margin-bottom:4px;font-size:.62rem;font-weight:600}.notif-marks-stat-value{margin-bottom:3px;font-family:Space Grotesk,sans-serif;font-size:1rem;font-weight:800;line-height:1}.notif-marks-stat-value.safe{color:#10b981}.notif-marks-stat-value.critical{color:#f59e0b}.notif-marks-stat-value.neutral{color:var(--text-secondary)}.notif-marks-stat-desc{color:var(--text-tertiary);font-size:.64rem}.notif-marks-stat-desc .trend-up{color:#10b981;align-items:center;gap:2px;display:inline-flex}.notif-marks-stat-desc .trend-down{color:#f59e0b;align-items:center;gap:2px;display:inline-flex}.notif-marks-actions{gap:8px;display:flex}.notif-marks-action-btn{border-radius:var(--radius-sm);border:1px solid var(--glass-border);background:var(--bg-secondary);color:var(--text-tertiary);cursor:pointer;align-items:center;gap:4px;padding:6px 10px;font-size:.72rem;font-weight:500;transition:all .2s;display:flex}.notif-marks-action-btn:hover{border-color:var(--accent);color:var(--accent)}.notif-marks-action-btn.delete:hover{border-color:var(--error);color:var(--error)}@media (max-width:600px){.notif-att-stats{grid-template-columns:repeat(2,1fr)}.notif-att-stat-value{font-size:.9rem}.notif-att-collapsed{padding:12px 14px}.notif-att-status-icon-sm{width:32px;height:32px}.notif-att-collapsed-subject{font-size:.82rem}.notif-marks-stats{grid-template-columns:repeat(3,1fr)}.notif-marks-stat-value{font-size:.9rem}.notif-marks-collapsed{padding:12px 14px}.notif-marks-status-icon-sm{width:32px;height:32px}.notif-marks-collapsed-subject{font-size:.82rem}}@media (max-width:480px){.notif-card{gap:12px;padding:14px}.notif-icon{width:36px;height:36px}.notif-actions-inline{opacity:1}.notif-unread-dot{left:6px}}
.conf-page-container{width:100%;padding:12px 20px 120px}@media (max-width:768px){.conf-page-container{padding:12px 16px 120px}}.conf-card{border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(16px);transition:box-shadow var(--transition-base),border-color var(--transition-base);overflow:hidden}.conf-card:hover{box-shadow:var(--shadow-md);border-color:var(--accent)}.conf-chip{border-radius:var(--radius-full);align-items:center;gap:3px;padding:2px 7px;font-family:Space Grotesk,sans-serif;font-size:.67rem;font-weight:700;display:inline-flex}.conf-empty{text-align:center;color:var(--text-tertiary);padding:48px 20px}.conf-filter-row{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.conf-select-wrap{flex:1;min-width:140px;position:relative}.conf-select-wrap .conf-select-icon{pointer-events:none;color:var(--text-tertiary);position:absolute;top:50%;left:10px;transform:translateY(-50%)}.conf-select{border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);width:100%;color:var(--text-primary);cursor:pointer;appearance:none;outline:none;padding:9px 12px 9px 32px;font-family:Space Grotesk,sans-serif;font-size:.8rem;font-weight:600;transition:all .2s}.conf-select:focus{border-color:var(--accent);box-shadow:0 0 0 2px #14b8a526}.conf-select option{background:var(--bg-primary);color:var(--text-primary);padding:6px 8px;font-size:.78rem}.conf-custom-dropdown{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);max-height:280px;box-shadow:var(--shadow-md);z-index:200;scrollbar-width:thin;-webkit-backdrop-filter:blur(30px)saturate(200%);padding:4px 0;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto}.conf-custom-dropdown::-webkit-scrollbar{width:4px}.conf-custom-dropdown::-webkit-scrollbar-thumb{background:var(--text-tertiary);border-radius:4px}.conf-dropdown-item{color:var(--text-primary);cursor:pointer;white-space:nowrap;text-overflow:ellipsis;padding:8px 12px;font-family:Space Grotesk,sans-serif;font-size:.78rem;font-weight:500;transition:background .15s;overflow:hidden}.conf-dropdown-item:hover{background:var(--bg-hover)}.conf-dropdown-item.selected{color:var(--accent);font-weight:700}.conf-dropdown-backdrop{z-index:199;position:fixed;inset:0}.conf-select-arrow{pointer-events:none;color:var(--text-tertiary);position:absolute;top:50%;right:10px;transform:translateY(-50%)}.conf-pills{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:6px;margin-bottom:12px;padding-bottom:4px;display:flex;overflow-x:auto}.conf-pills::-webkit-scrollbar{display:none}.conf-pill{border-radius:var(--radius-full);border:1px solid var(--border-color);background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);cursor:pointer;color:var(--text-secondary);text-transform:capitalize;flex-shrink:0;padding:5px 14px;font-family:Space Grotesk,sans-serif;font-size:.75rem;font-weight:600;transition:all .2s}.conf-pill:hover{border-color:var(--accent);color:var(--accent)}.conf-pill.active{background:var(--gradient-primary);color:#fff;border-color:#0000;box-shadow:0 3px 10px #14b8a54d}
.hack-page{width:100%;padding:0 16px 120px}.hack-topbar{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.hack-topbar__count{color:var(--text-tertiary);font-family:Plus Jakarta Sans,Inter,sans-serif;font-size:.78rem;font-weight:600}.hack-topbar__num{color:var(--accent);font-family:Space Grotesk,sans-serif;font-weight:800}.hack-grid{grid-template-columns:1fr;gap:10px;display:grid}@media (min-width:720px){.hack-grid{grid-template-columns:repeat(2,1fr)}}.hack-card{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-lg);border-left:3px solid var(--accent);transition:all .2s;overflow:hidden}.hack-card:hover{border-color:#14b8a559;box-shadow:0 2px 12px #14b8a514}.hack-card__img-wrap{border-radius:var(--radius-md);background:var(--bg-hover);border:1px solid var(--border-color);flex-shrink:0;width:44px;height:44px;overflow:hidden}.hack-card__img{object-fit:cover;width:100%;height:100%}.hack-card__img-fallback{width:100%;height:100%;color:var(--accent);background:#14b8a514;justify-content:center;align-items:center;display:flex}.hack-card__chip{border-radius:var(--radius-full);color:#14b8a5;text-transform:uppercase;letter-spacing:.03em;background:#14b8a51a;align-items:center;gap:3px;padding:2px 7px;font-size:.62rem;font-weight:700;display:inline-flex}.hack-empty{text-align:center;color:var(--text-secondary);padding:48px 20px;font-size:.88rem}
.tn-source-toggle{margin-bottom:16px}.tn-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;padding:0 4px;display:grid}@media (max-width:600px){.tn-grid{grid-template-columns:1fr;gap:10px;padding:0}}.tn-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:transform var(--transition-base),box-shadow var(--transition-base);overflow:hidden}.tn-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.tn-card-img-wrap{background:var(--bg-tertiary);width:100%;padding-top:52%;position:relative;overflow:hidden}.tn-card-img-wrap img{object-fit:cover;width:100%;height:100%;transition:transform .4s;position:absolute;inset:0}.tn-card:hover .tn-card-img-wrap img{transform:scale(1.04)}.tn-card-img-placeholder{background:linear-gradient(135deg,var(--bg-tertiary),var(--bg-secondary));color:var(--text-tertiary);justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.tn-card-body{flex-direction:column;gap:8px;padding:14px 16px 16px;display:flex}.tn-card-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.tn-category-chip{border-radius:var(--radius-full);letter-spacing:.04em;text-transform:uppercase;color:var(--accent);white-space:nowrap;background:#f59f0a1a;align-items:center;gap:4px;padding:2px 8px;font-size:.68rem;font-weight:600;display:inline-flex}.tn-card-date{color:var(--text-tertiary);white-space:nowrap;font-size:.72rem}.tn-card-title{color:var(--text-primary);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.9rem;font-weight:700;line-height:1.4;display:-webkit-box;overflow:hidden}.tn-card-author{color:var(--text-secondary);font-size:.75rem;font-weight:500}@media (max-width:600px){.tn-card-img-wrap{padding-top:48%}.tn-card-body{gap:6px;padding:10px 12px 12px}.tn-card-title{-webkit-line-clamp:2;font-size:.82rem}.tn-card-author{font-size:.7rem}.tn-category-chip{padding:1px 6px;font-size:.6rem}.tn-card-date{font-size:.65rem}}.tn-article-wrapper{grid-column:1/-1;width:100%;scroll-margin-top:16px}.tn-article-inline{background:var(--bg-secondary);border-radius:var(--radius-xl);border:1px solid var(--border-color);width:100%;margin-bottom:16px;position:relative;overflow:hidden;box-shadow:0 8px 32px #0000001f,0 0 0 1px #ffffff0a}.tn-article-topbar{z-index:10;pointer-events:none;justify-content:flex-end;padding:12px 14px;display:flex;position:absolute;top:0;right:0}.tn-article-close{background:var(--bg-tertiary);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),transform var(--transition-fast);pointer-events:auto;box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.tn-article-close:hover{background:var(--bg-hover);color:var(--text-primary);transform:scale(1.08)}.tn-article-hero-wrap{width:100%;position:relative}.tn-article-hero-img{object-fit:cover;width:100%;max-height:380px;display:block}.tn-article-hero-fade{background:linear-gradient(to top,var(--bg-secondary),transparent);pointer-events:none;height:60px;position:absolute;bottom:0;left:0;right:0}.tn-article-header{padding:20px 32px 16px}.tn-article-category{border-radius:var(--radius-full);letter-spacing:.04em;text-transform:uppercase;color:var(--accent);background:#f59f0a1a;align-items:center;gap:5px;margin-bottom:12px;padding:3px 10px;font-size:.7rem;font-weight:600;display:inline-flex}.tn-article-title{color:var(--text-primary);letter-spacing:-.02em;margin-bottom:12px;font-size:1.55rem;font-weight:800;line-height:1.35}.tn-article-byline{color:var(--text-tertiary);flex-wrap:wrap;align-items:center;gap:10px;font-size:.82rem;display:flex}.tn-article-byline-author{color:var(--text-primary);font-weight:600}.tn-article-byline-dot{background:var(--text-tertiary);border-radius:50%;flex-shrink:0;width:3px;height:3px}.tn-article-divider{background:var(--border-color);height:1px;margin:0 32px}.tn-article-content{flex-direction:column;gap:18px;padding:20px 32px 32px;display:flex}.tn-article-content p{color:var(--text-secondary);text-align:justify;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:1rem;line-height:1.8}.tn-article-content p:first-of-type:first-letter{float:left;color:var(--text-primary);margin-top:4px;margin-right:6px;font-size:2.2em;font-weight:800;line-height:1}.tn-article-source-link{border-radius:var(--radius-md);background:var(--bg-tertiary);color:var(--accent);border:1px solid var(--border-color);transition:all var(--transition-fast);align-items:center;gap:6px;width:fit-content;margin-top:8px;padding:10px 18px;font-size:.82rem;font-weight:600;text-decoration:none;display:inline-flex}.tn-article-source-link:hover{border-color:var(--accent);background:#f59f0a1a}.tn-article-loading{color:var(--text-tertiary);flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:80px 28px;font-size:.85rem;display:flex}.tn-article-loading .tn-spinner{border:2.5px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;width:28px;height:28px;animation:.7s linear infinite spin}@media (max-width:768px){.tn-article-inline{border-radius:var(--radius-lg)}.tn-article-hero-img{max-height:280px}.tn-article-header{padding:18px 20px 14px}.tn-article-title{font-size:1.3rem}.tn-article-divider{margin:0 20px}.tn-article-content{padding:16px 20px 24px}.tn-article-topbar{padding:10px}}@media (max-width:480px){.tn-article-inline{border-radius:var(--radius-md);margin-bottom:16px}.tn-article-header{padding:14px 16px 10px}.tn-article-title{font-size:1.15rem}.tn-article-divider{margin:0 16px}.tn-article-content{gap:14px;padding:14px 16px 20px}.tn-article-content p{font-size:.92rem;line-height:1.72}.tn-article-hero-img{max-height:200px}.tn-article-topbar{padding:8px}.tn-article-close{width:32px;height:32px}}.tn-empty{color:var(--text-tertiary);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:64px 24px;display:flex}.tn-empty-icon{background:var(--bg-tertiary);width:56px;height:56px;color:var(--text-tertiary);border-radius:50%;justify-content:center;align-items:center;display:flex}
.dashboard-scroll-col{scrollbar-width:none;-ms-overflow-style:none}.dashboard-scroll-col::-webkit-scrollbar{display:none}@media (max-width:768px){.dashboard-main{padding-bottom:calc(110px + env(safe-area-inset-bottom,0px))}}.dashboard-page-clip{flex:1;position:relative;overflow:hidden}
