@import "https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600;9..40,700&family=Playfair+Display:wght@600;700&display=swap";@tailwind base;@tailwind components;@tailwind utilities;*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;font-size:15px}body{color:#111827;background:#f8f7ff;font-family:DM Sans,system-ui,sans-serif;line-height:1.6}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ddd6fe;border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#a78bfa}@media print{.no-print{display:none!important}.print-only{display:block!important}body{background:#fff!important}}.label{letter-spacing:.05em;text-transform:uppercase;color:#6b7280;margin-bottom:5px;font-size:11px;font-weight:700;display:block}.table-row-hover:hover{background:#faf5ff}@keyframes _bn_in{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes _bn_pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.bn-item{flex-shrink:0;min-width:76px;transition:all .2s cubic-bezier(.4,0,.2,1)}.bn-item:active{transform:scale(.95)}.bn-active .bn-icon-box{transform:translateY(-2px);background:#7c3aed1a!important}.bn-active .bn-label{color:#6d28d9;font-weight:700;transform:translateY(-1px)}.bn-fab{animation:2s ease-in-out infinite _bn_pulse}.bn-fab:hover{animation:none;transform:scale(1.1)!important}.bn-fab:active{transform:scale(.9)!important}nav::-webkit-scrollbar{display:none}@keyframes sc_pop{0%{opacity:0;transform:scale(.8)translateY(24px)}70%{transform:scale(1.04)translateY(-4px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes sc_shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-8px)}40%,80%{transform:translate(8px)}}@keyframes sc_spin{to{transform:rotate(360deg)}}@keyframes sc_pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes sc_scan{0%{top:0}to{top:100%}}.sc-card{animation:.4s cubic-bezier(.34,1.56,.64,1) forwards sc_pop}.sc-err{animation:.4s sc_shake}#qr-reader{background:#000;position:relative;border:none!important;width:100%!important}#qr-reader video{object-fit:cover;border-radius:20px!important;width:100%!important}.qr-hud{pointer-events:none;z-index:10;border:2px solid #fff3;border-radius:20px;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.qr-line{background:#22c55e80;height:2px;animation:2s linear infinite sc_scan;position:absolute;left:10%;right:10%;box-shadow:0 0 8px #22c55ecc}#qr-reader__dashboard{display:none!important}@keyframes ticker{0%{transform:translate(0)}to{transform:translate(-50%)}}.ticker-content{white-space:nowrap;padding-right:50px;font-size:12px;font-weight:600;animation:80s linear infinite ticker;display:inline-block}.ticker-content:hover{animation-play-state:paused}@keyframes ann_bg_in{0%{opacity:0}to{opacity:1}}@keyframes ann_out{to{opacity:0}}@keyframes ann_card_in{0%{opacity:0;transform:translateY(28px)scale(.95)}to{opacity:1;transform:none}}@keyframes ann_card_slide{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:none}}.ann-btn{cursor:pointer;border:none;transition:all .2s}.ann-btn:hover{filter:brightness(1.1);transform:scale(1.02)}.ann-btn:active{transform:scale(.98)}.ann-close:hover{background:#fff3!important}@keyframes _sp_in{0%{opacity:0;transform:scale(.96)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes _sp_shimmer{0%{background-position:-100%}to{background-position:200%}}@keyframes _sp_icon_float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.sp-container{z-index:9999;justify-content:center;align-items:center;padding:20px;font-family:DM Sans,system-ui,sans-serif;transition:background .5s;display:flex;position:fixed;inset:0;background:0 0!important}body.sp-active{background:0 0!important}@media (width>=1024px){.sp-card{border:1px solid #f1f5f9;box-shadow:0 40px 120px #0003!important}.sp-branding,.sp-footer{opacity:.4}}@media (display-mode:standalone),(display-mode:fullscreen){.sp-container{background:#fff!important}.sp-card{border:none;box-shadow:none!important}.sp-branding,.sp-footer{display:none!important}}.sp-card{text-align:center;background:#fff;border:1px solid #6d28d90d;border-radius:28px;width:100%;max-width:440px;padding:48px 40px;animation:.6s cubic-bezier(.2,.8,.2,1) both _sp_in;position:relative;overflow:hidden;box-shadow:0 25px 60px -12px #6d28d926,0 0 1px #6d28d933}.sp-shimmer{pointer-events:none;background:linear-gradient(90deg,#0000,#7c3aed08,#0000) 0 0/200% 100%;animation:2s linear infinite _sp_shimmer;position:absolute;inset:0}.app-main{padding:28px 32px 80px}@media (width<=600px){.app-main{padding:20px 16px 100px}}.t-page{padding:12px;font-family:DM Sans,system-ui,sans-serif}@media (width>=640px){.t-page{padding:20px}}@media (width>=1024px){.t-page{padding:28px}}.t-header{flex-direction:column;gap:12px;margin-bottom:20px;display:flex}@media (width>=640px){.t-header{flex-direction:row;justify-content:space-between;align-items:flex-start}}.t-header h1,.t-title{color:#111827;margin:0;font-family:Playfair Display,serif;font-size:22px;font-weight:700}@media (width>=640px){.t-header h1,.t-title{font-size:26px}}.t-btn-group{flex-direction:column;gap:8px;width:100%;display:flex}@media (width>=640px){.t-btn-group{flex-direction:row;align-items:center;width:auto}}.t-btn-group>a,.t-btn-group>button{justify-content:center;width:100%}@media (width>=640px){.t-btn-group>a,.t-btn-group>button{width:auto}}.t-kpi-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px;display:grid}@media (width>=640px){.t-kpi-grid{grid-template-columns:repeat(3,1fr);gap:12px}}@media (width>=1024px){.t-kpi-grid{grid-template-columns:repeat(auto-fit,minmax(130px,1fr))}}.t-grid{grid-template-columns:1fr;gap:16px;display:grid}@media (width>=900px){.t-grid{grid-template-columns:1fr 300px;gap:20px}}.t-card{background:#fff;border:1.5px solid #f0eefe;border-radius:16px;overflow:hidden;box-shadow:0 1px 4px #6d28d90f}.t-card-header{border-bottom:1px solid #faf5ff;justify-content:space-between;align-items:center;gap:8px;padding:14px 16px;display:flex}.t-card-body{padding:14px 16px}.t-table-scroll{-webkit-overflow-scrolling:touch;border:1px solid #e5e7eb;border-radius:14px;overflow-x:auto}.t-table-card thead{display:none}.t-table-card tbody tr{border-bottom:1px solid #f0eefe;flex-direction:column;gap:6px;padding:14px 16px;display:flex}.t-table-card tbody tr:last-child{border-bottom:none}.t-table-card td{border:none;justify-content:space-between;align-items:center;padding:0;font-size:13px;display:flex}.t-table-card td:before{content:attr(data-label);color:#9ca3af;text-transform:uppercase;letter-spacing:.06em;min-width:80px;font-size:10px;font-weight:700}@media (width>=640px){.t-table-card thead{display:table-header-group}.t-table-card tbody tr{padding:0;display:table-row}.t-table-card td{justify-content:unset;padding:10px 12px;display:table-cell}.t-table-card td:before{display:none}}.t-sticky-bar{z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff5;border:1.5px solid #ede9fe;border-radius:20px;flex-direction:column;gap:10px;margin:20px 0;padding:14px 16px;display:flex;position:sticky;bottom:16px;box-shadow:0 8px 32px #6d28d92e}@media (width>=640px){.t-sticky-bar{flex-direction:row;justify-content:space-between;align-items:center;padding:14px 20px}}.t-sticky-bar button{width:100%}@media (width>=640px){.t-sticky-bar button{width:auto}}.t-modal-overlay{z-index:300;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#1118278c;justify-content:center;align-items:flex-end;padding:0;display:none;position:fixed;inset:0}.t-modal-overlay.open{animation:.2s tModalIn;display:flex}@media (width>=640px){.t-modal-overlay{align-items:center;padding:20px}}.t-modal-box{background:#fff;border-radius:24px 24px 0 0;width:100%;max-height:92dvh;overflow:auto;box-shadow:0 -8px 40px #00000026}@media (width>=640px){.t-modal-box{border-radius:20px;max-width:540px;max-height:90dvh;box-shadow:0 24px 64px #0000002e}}.t-filter-bar{background:#fff;border:1px solid #e5e7eb;border-radius:14px;flex-direction:column;gap:10px;margin-bottom:18px;padding:14px 16px;display:flex}@media (width>=640px){.t-filter-bar{flex-flow:wrap;align-items:flex-end}}.t-filter-bar select,.t-filter-bar input{background:#fff;border:1px solid #e5e7eb;border-radius:9px;outline:none;width:100%;padding:9px 12px;font-family:DM Sans,sans-serif;font-size:13px}@media (width>=640px){.t-filter-bar select,.t-filter-bar input{flex:180px;width:auto}}.t-score-input{text-align:center;border:1.5px solid #e5e7eb;border-radius:8px;outline:none;width:100%;height:40px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:700}@media (width>=640px){.t-score-input{width:56px;height:32px;font-size:12px}}.t-student-card{background:#fff;border:1.5px solid #f0eefe;border-radius:14px;margin-bottom:10px;padding:14px;box-shadow:0 1px 4px #6d28d90a}.t-student-card-header{align-items:center;gap:10px;margin-bottom:12px;display:flex}.t-student-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:800;display:flex}.t-timetable-wrapper{-webkit-overflow-scrolling:touch;padding-bottom:8px;overflow-x:auto}.t-prof-grid{grid-template-columns:repeat(2,1fr);gap:6px;display:grid}@media (width>=400px){.t-prof-grid{grid-template-columns:repeat(3,1fr)}}.t-touch{align-items:center;min-height:44px;display:flex}@keyframes tModalIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.t-hide-mobile{display:none}.t-hide-desktop{display:block}@media (width>=640px){.t-hide-mobile{display:block}.t-hide-desktop{display:none}}.t-score-card-grid{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}@media (width>=400px){.t-score-card-grid{grid-template-columns:repeat(3,1fr)}}.t-quick-grid{grid-template-columns:repeat(3,1fr);gap:6px;display:grid}@media (width>=480px){.t-quick-grid{grid-template-columns:repeat(4,1fr)}}@media (width>=768px){.t-quick-grid{grid-template-columns:repeat(2,1fr)}}
