*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}h1,h2,h3,h4,h5,h6{color:#fff}body{background:#092f73;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}#root{min-height:100vh}.app{background:#092f73;min-height:100vh;display:flex}.brand{letter-spacing:.02em;background:linear-gradient(90deg,#fff 0%,#a8c6ff 50%,#fff 100%);-webkit-text-fill-color:transparent;color:#fff;white-space:nowrap;-webkit-background-clip:text;background-clip:text;flex-shrink:0;padding-left:4px;font-size:15px;font-weight:800}.nav-group{-webkit-user-select:none;user-select:none;margin-bottom:4px}.nav-group-header{cursor:pointer;letter-spacing:.04em;color:#ffffff73;-webkit-user-select:none;user-select:none;border-left:3px solid #0000;align-items:center;gap:10px;padding:10px 16px 10px 18px;font-size:12px;font-weight:600;transition:color .15s,background .15s;display:flex}.nav-group-icon{text-align:center;flex-shrink:0;width:22px;font-size:16px}.nav-group-name{flex:1}.nav-group-arrow{color:#fff9;flex-shrink:0;font-size:10px;transition:transform .2s,color .15s}.nav-group.open .nav-group-arrow{color:#fffc;transform:rotate(90deg)}.nav-group-body{opacity:0;max-height:0;transition:max-height .28s cubic-bezier(0,1,.3,1),opacity .2s;overflow:hidden}.nav-group.open .nav-group-body{opacity:1;max-height:480px}.nav-item.active{color:#fff;background:linear-gradient(90deg,#143b8459,#0000)}.nav-item.active:before{content:"";background:#0b2950;border-radius:0 2px 2px 0;width:3px;position:absolute;top:0;bottom:0;left:0}.btn{cursor:pointer;border:none;border-radius:10px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .2s}.btn-primary{color:#fff;letter-spacing:.02em;background:linear-gradient(135deg,#165dff 0%,#0ea5e9 100%);transition:all .2s;box-shadow:0 4px 14px #165dff59}.btn-primary:hover{background:linear-gradient(135deg,#5a95ff,#0b2950);box-shadow:0 6px 16px #143b8485}.btn-outline{color:#42c7fd;cursor:pointer;background:0 0;border:1px solid #42c7fd80;border-radius:10px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .2s}.btn-outline:hover{background:#143b8433;border-color:#0b2950;box-shadow:0 0 0 3px #42c7fd2e}.btn-ghost{color:#ffffffd9;background:0 0}.btn-ghost:hover{color:#fff;background:#143b8433}.btn-secondary{color:#fff;cursor:pointer;background:#0b2950cc;border:1px solid #42c7fd59;border-radius:10px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .2s}.btn-secondary:hover{background:#ffffff40}.btn-warning{color:#fff;background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:10px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .2s;box-shadow:0 4px 12px #f59e0b4d}.btn-warning:hover{background:linear-gradient(135deg,#fbbf24,#f59e0b)}.btn-info{color:#fff;background:linear-gradient(135deg,#42c7fd,#0b99fd);border-radius:10px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .2s;box-shadow:0 4px 12px #42c7fd4d}.btn-info:hover{background:linear-gradient(135deg,#6dd5ff,#42c7fd)}.btn-sm{cursor:pointer;border:none;border-radius:8px;padding:6px 12px;font-size:13px;font-weight:600;transition:all .2s}.btn-sm.info{color:#42c7fd;background:#42c7fd26;border:1px solid #42c7fd4d}.btn-sm.info:hover{background:#42c7fd4d}.btn-sm.danger{color:#fca5a5;background:#fd79a826;border:1px solid #fd79a84d}.btn-sm.danger:hover{background:#fd79a84d}.btn-xs{padding:3px 8px;font-size:11px}.btn-icon{border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;padding:0;display:flex}.form-group{margin-bottom:20px}label,.form-label{color:#fff;letter-spacing:.01em;margin-bottom:6px;font-size:14px;font-weight:600;display:block}.form-input,select,textarea{box-sizing:border-box;color:#fff;background:#092f738c;border:1px solid #42c7fd59;border-radius:10px;width:100%;padding:12px 16px;font-size:14px;transition:all .2s}.form-input:focus,select:focus,textarea:focus{background:#092f73b3;border-color:#42c7fd;outline:none;box-shadow:0 0 0 3px #42c7fd33,0 0 12px #42c7fd26}.form-input::placeholder,textarea::placeholder{color:#ffffff73}textarea{resize:vertical;min-height:80px;line-height:1.5}select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2342C7FD' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.form-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.form-hint{color:#ffffff73;margin-top:4px;font-size:11px}.table-wrap{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#1a4a8a80;border:1px solid #143b8433;border-radius:12px;overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13px}thead{background:#143b841f}th{text-align:left;color:#fffc;letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid #143b8433;padding:10px 14px;font-size:11px;font-weight:700}td{color:#ffffffd9;border-bottom:1px solid #143b841a;padding:10px 14px}tr:last-child td{border-bottom:none}tr:hover td{background:#143b841a}.card{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#1a4a8aa6;border:1px solid #143b8433;border-radius:12px;margin-bottom:16px;padding:20px;box-shadow:0 4px 20px #0000004d,inset 0 1px #ffffff0d}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{color:#fff;font-size:15px;font-weight:700}.card-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;display:grid}.stat-card{background:linear-gradient(135deg,#143b842b,#1a4a8a14);border:1px solid #143b841f;border-radius:10px;padding:16px}.stat-grid{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:16px;display:grid}.stat-card .label{color:#ffffffbf;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;font-size:11px;font-weight:600}.stat-card .value{color:#fff;font-size:24px;font-weight:800}.stat-label{color:#ffffffbf;margin-bottom:4px;font-size:12px;font-weight:600}.stat-value{color:#fff;font-size:22px;font-weight:800}select option{color:#fff;background:#092f73;padding:8px}.badge{letter-spacing:.04em;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.badge-blue{color:#2563eb;background:#143b8426}.badge-green{color:#34d399;background:#10b9814d}.badge-red{color:#f87171;background:#ef44444d}.badge-yellow{color:#fbbf24;background:#f59e0b4d}.badge-gray{color:#fff9;background:#ffffff1a}.modal-overlay{z-index:9999;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#092f73c7;justify-content:center;align-items:center;padding:20px;animation:.2s modalOverlayIn;display:flex;position:fixed;inset:0}@keyframes modalOverlayIn{0%{opacity:0}to{opacity:1}}.modal{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0b2950f2;border:1px solid #42c7fd38;border-radius:16px;width:100%;max-width:680px;max-height:88vh;animation:.28s cubic-bezier(.34,1.56,.64,1) modalSlideIn;overflow-y:auto;box-shadow:0 24px 80px #0009,0 0 0 1px #42c7fd1f}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.92)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#143b8480;border-bottom:1px solid #42c7fd2e;border-radius:16px 16px 0 0;justify-content:space-between;align-items:center;padding:22px 28px 18px;display:flex}.modal-title{color:#fff;letter-spacing:.01em;align-items:center;gap:10px;font-size:17px;font-weight:800;display:flex}.modal-title:before{content:"";background:#3b82f6;border-radius:3px;width:4px;height:18px}.modal-body{color:#ffffffeb;background:#0f377866;padding:24px 28px}.modal-footer{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#143b8480;border-top:1px solid #42c7fd2e;border-radius:0 0 16px 16px;justify-content:flex-end;gap:10px;padding:18px 28px;display:flex}.toast-container{flex-direction:column;gap:8px;display:flex;position:fixed;top:20px;right:20px;z-index:999999!important}.toast{border:1px solid #ffffff1a;border-radius:10px;padding:10px 16px;font-size:13px;font-weight:600;animation:.2s toastIn;box-shadow:0 4px 16px #0000004d}.toast-success{color:#fff;background:linear-gradient(135deg,#10b981e6,#059669e6)}.toast-error{color:#fff;background:linear-gradient(135deg,#ef4444e6,#dc2626e6)}.toast-info{color:#fff;background:linear-gradient(135deg,#143b84e6,#143b84e6)}@keyframes toastIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.chart-wrap{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#1a4a8aa6;border:1px solid #143b8433;border-radius:12px;padding:20px}.chart-title{color:#ffffffe6;margin-bottom:16px;font-size:13px;font-weight:700}.tag{border-radius:6px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-block}.tag-blue{color:#60a5fa;background:#143b843d;border:1px solid #143b8459}.tag-green{color:#34d399;background:#10b98133;border:1px solid #10b9814d}.tag-purple{color:#c4b5fd;background:#1a4a8a33;border:1px solid #1a4a8a4d}.flex{align-items:center;gap:8px;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.text-center{text-align:center}.text-right{text-align:right}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.grid-2{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.empty{text-align:center;color:#ffffff73;padding:40px;font-size:14px}.page-title{color:#fff;margin-bottom:20px;font-size:20px;font-weight:800}.search-bar{gap:8px;margin-bottom:16px;display:flex}.search-bar input{color:#fff;background:#092f7380;border:1px solid #42c7fd33;border-radius:8px;flex:1;padding:8px 12px;font-size:13px;transition:all .2s}.search-bar input:focus{border-color:#42c7fd;outline:none;box-shadow:0 0 0 3px #42c7fd26}.search-bar input::placeholder{color:#fff9}.placeholder{color:#ffffff73;font-size:12px}@media (width<=768px){.sidebar{width:56px;padding:12px 0}.logo{border-bottom:1px solid #ffffff17;padding:0 0 12px;font-size:0}.nav-group-name,.nav-group-arrow,.nav-label{display:none}.nav-item{text-align:center;padding-left:18px;font-size:20px}.nav-group-header{justify-content:center;padding:12px}.nav-group-icon{width:auto;font-size:18px}.card-grid{grid-template-columns:1fr 1fr}.grid-4{grid-template-columns:repeat(2,1fr)}}.topbar{z-index:100;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:linear-gradient(#1a4a8af2 0%,#1a4a8ae6 100%);border-bottom:1px solid #143b8447;justify-content:space-between;align-items:center;padding:14px 32px;display:flex;position:relative}.topbar:before{content:"";background:linear-gradient(90deg,#0000,#143b8480,#1a4a8a80,#143b8480,#0000);height:2px;position:absolute;top:0;left:0;right:0}.topbar-title{color:#fff;letter-spacing:.08em;text-shadow:0 0 20px #ffffff80,0 0 40px #1a4a8a4d;padding-left:16px;font-size:20px;font-weight:800;position:relative}.topbar-title:before{content:"";background:linear-gradient(#0b2950,#1a4a8a);border-radius:2px;width:4px;height:20px;position:absolute;top:50%;left:0;transform:translateY(-50%);box-shadow:0 0 8px #143b8499}.sidebar{background:linear-gradient(#1a4a8afa 0%,#1a4a8af5 100%);border-right:1px solid #143b8433;flex-direction:column;flex-shrink:0;width:200px;height:100vh;padding:16px 0;display:flex;position:sticky;top:0;overflow-y:auto;box-shadow:4px 0 24px #00000080}.sidebar-head{border-bottom:1px solid #143b8426;flex-shrink:0;align-items:center;gap:10px;padding:0 16px 14px;display:flex}.logo{background:linear-gradient(135deg,#0b2950,#1a4a8a);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex;box-shadow:0 4px 14px #143b847a}.logo-icon{color:#fff;font-size:17px}.brand{letter-spacing:.03em;background:linear-gradient(90deg,#fff 0%,#bdd6fb 50%,#fff 100%);-webkit-text-fill-color:transparent;color:#fff;white-space:nowrap;-webkit-background-clip:text;background-clip:text;flex-shrink:0;font-size:14px;font-weight:800}.nav-group-header{cursor:pointer;letter-spacing:.06em;color:#ffffffe6;border-left:3px solid #0000;align-items:center;gap:8px;padding:9px 14px 9px 16px;font-size:11px;font-weight:700;transition:all .2s;display:flex}.nav-group-header:hover{color:#fff;background:#42c7fd1a}.nav-group-header.has-active{color:#42c7fd;background:#42c7fd14;border-left-color:#42c7fd;font-size:13px;font-weight:700}.nav-item{color:#ffffffd9;cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;width:100%;padding:9px 12px 9px 42px;font-size:12px;font-weight:500;transition:all .2s;display:flex;position:relative}.nav-item:hover{color:#ffffffeb;background:#143b841f}.nav-item.active{color:#fff;background:linear-gradient(90deg,#143b8447,#143b840d);font-weight:600}.nav-item.active:before{content:"";background:linear-gradient(#0b2950,#1a4a8a);border-radius:0 2px 2px 0;width:3px;position:absolute;top:0;bottom:0;left:0;box-shadow:0 0 6px #143b8480}.main{background:linear-gradient(#092f73 0%,#0b2950 50%,#092f73 100%);flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.content{flex:1;min-height:0;overflow-y:auto}.page{flex:1;min-height:0;padding:24px;overflow-y:auto}.db-welcome{color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1;background:linear-gradient(135deg,#1a4a8ab8 0%,#1a4a8a80 100%);border:1px solid #143b8438;border-left:3px solid #0b2950;border-radius:10px;justify-content:space-between;align-items:center;margin-bottom:20px;padding:18px 24px;display:flex;position:relative;box-shadow:0 4px 20px #0000004d,inset 0 1px #ffffff0a}.db-welcome-greeting{color:#fff;text-shadow:0 0 10px #ffffff52;margin-bottom:4px;font-size:18px;font-weight:800}.db-welcome-sub{color:#ffffffb8;align-items:center;gap:8px;font-size:12px;display:flex}.db-welcome-sep{opacity:.3}.db-3d-container{perspective:1200px;justify-content:center;align-items:center;margin:0 0 24px;display:flex;position:relative}.db-3d-cube{width:160px;height:160px;transform-style:preserve-3d;animation:18s linear infinite db-cube-rotate;position:relative}.db-3d-face{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:linear-gradient(135deg,#143b841f,#1a4a8a0f);border:1.5px solid #143b847a;width:160px;height:160px;position:absolute;box-shadow:inset 0 0 20px #143b841a,0 0 15px #143b841f}.db-3d-face-front{transform:translateZ(80px)}.db-3d-face-back{transform:rotateY(180deg)translateZ(80px)}.db-3d-face-right{transform:rotateY(90deg)translateZ(80px)}.db-3d-face-left{transform:rotateY(-90deg)translateZ(80px)}.db-3d-face-top{transform:rotateX(90deg)translateZ(80px)}.db-3d-face-bottom{transform:rotateX(-90deg)translateZ(80px)}.db-3d-container:after{content:"";filter:blur(8px);background:radial-gradient(#143b8438,#0000 70%);border-radius:50%;width:200px;height:40px;position:absolute;bottom:-30px;left:50%;transform:translate(-50%)}@keyframes db-cube-rotate{0%{transform:rotateX(-18deg)rotateY(0)}to{transform:rotateX(-18deg)rotateY(360deg)}}.db-stat-grid{grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:20px;display:grid}.db-stat-card{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:linear-gradient(135deg,#1a4a8ad1 0%,#1a4a8a9e 100%);border:1px solid #143b8438;border-radius:10px;padding:18px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 4px 16px #0000004d,inset 0 1px #ffffff08}.db-stat-card:before{content:"";background:linear-gradient(90deg,var(--stat-color),transparent);opacity:.7;width:100%;height:2px;position:absolute;top:0;left:0}.db-stat-card:after{content:"";background:linear-gradient(90deg,#0000,#ffffff08,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.db-stat-card:hover{border-color:#143b846b;transform:translateY(-4px);box-shadow:0 8px 30px #143b8438,0 0 0 1px #143b8461}.db-stat-card:hover:after{left:100%}.db-stat-top{align-items:center;gap:10px;margin-bottom:10px;display:flex}.db-stat-icon{width:40px;height:40px;box-shadow:0 0 12px var(--stat-color), inset 0 0 6px #ffffff0a;background:#00000059;border:1px solid #ffffff0f;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;display:flex;position:relative}.db-stat-label{color:#ffffffe6;text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:600}.db-stat-value{color:#fff;letter-spacing:-.02em;text-shadow:0 0 12px #ffffff38;margin-bottom:0;font-size:26px;font-weight:900;position:relative}.db-chart-row{grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px;display:grid}.db-chart-card{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:linear-gradient(135deg,#1a4a8ad1 0%,#1a4a8a9e 100%);border:1px solid #143b8433;border-radius:10px;padding:20px;transition:all .3s;box-shadow:0 4px 16px #00000040}.db-chart-card:hover{border-color:#143b8452;box-shadow:0 8px 28px #143b8433}.db-chart-card-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.db-chart-title{color:#eff6ff;padding-left:10px;font-size:14px;font-weight:700;position:relative}.db-chart-title:before{content:"";background:linear-gradient(#0b2950,#1a4a8a);border-radius:2px;width:3px;height:14px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.db-chart-tag{color:#bdd6fb;background:#143b8426;border:1px solid #143b8447;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:600}.db-quick-actions{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:linear-gradient(135deg,#1a4a8ad1 0%,#1a4a8a9e 100%);border:1px solid #143b8433;border-radius:10px;padding:20px;box-shadow:0 4px 16px #00000040}.db-qa-title{color:#eff6ff;margin-bottom:14px;padding-left:10px;font-size:14px;font-weight:700;position:relative}.db-qa-title:before{content:"";background:linear-gradient(#0b2950,#1a4a8a);border-radius:2px;width:3px;height:14px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.db-qa-btns{flex-wrap:wrap;gap:10px;display:flex}.db-qa-btn{color:#e2e8f0d9;cursor:pointer;background:#143b8426;border:1px solid #143b8438;border-radius:8px;padding:9px 16px;font-size:12px;font-weight:600;transition:all .2s;position:relative;overflow:hidden}.db-qa-btn:before{content:"";opacity:0;background:linear-gradient(135deg,#0b2950,#1a4a8a);transition:opacity .2s;position:absolute;inset:0}.db-qa-btn:hover{color:#092f73;background:linear-gradient(135deg,#0b2950,#1a4a8a);border-color:#0b2950;transform:translateY(-2px);box-shadow:0 4px 18px #143b846b}.db-qa-btn:hover:before{opacity:1}.db-qa-btn span{z-index:1;position:relative}.search-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000c;justify-content:center;align-items:flex-start;padding-top:100px;display:flex;position:fixed;inset:0;z-index:999999!important}.search-modal{background:linear-gradient(135deg,#1a4a8af7,#143b841a);border:1px solid #143b8459;border-radius:16px;width:560px;padding:24px;box-shadow:0 25px 60px #00000080}.search-hint{color:#fffc;margin-bottom:12px;font-size:12px;font-weight:600}.head-search-row{flex-shrink:0;align-items:center;gap:10px;display:flex}.head-search{box-sizing:border-box;color:#fff;background:#092f738c;border:1px solid #42c7fd59;border-radius:10px;outline:none;width:220px;padding:9px 14px;font-size:14px;transition:border-color .2s}.head-search:focus{border-color:#42c7fd;box-shadow:0 0 0 3px #42c7fd2e}.head-search::placeholder{color:#ffffff80}.head-grade{color:#fff;cursor:pointer;box-sizing:border-box;background:#092f738c;border:1px solid #42c7fd59;border-radius:10px;outline:none;min-width:120px;padding:9px 12px;font-size:14px}.head-grade option{color:#fff;background:#0b2950}.btn-add-student{cursor:pointer;color:#fff;letter-spacing:.02em;background:linear-gradient(135deg,#165dff 0%,#0ea5e9 100%);border:none;border-radius:10px;padding:9px 18px;font-size:14px;font-weight:600;transition:all .2s;box-shadow:0 4px 14px #165dff59}.btn-add-student:hover{transform:translateY(-1px);box-shadow:0 6px 20px #165dff73}.btn-add-student:active{transform:translateY(0)}.search-input:focus{border-color:#0b2950;box-shadow:0 0 0 4px #143b8433}.search-input::placeholder{color:#fff9}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:#ffffff1f}.recharts-text{fill:#ffffff80}.recharts-tooltip-wrapper .recharts-tooltip-wrapper{filter:none}.recharts-default-tooltip{background:#1a4a8af7!important;border:1px solid #143b8459!important;border-radius:10px!important}@media (width<=900px){.db-stat-grid{grid-template-columns:repeat(2,1fr)}.db-chart-row{grid-template-columns:1fr}.db-3d-container{transform:scale(.8)}}.modal-close{color:#fff;cursor:pointer;background:#ffffff1a;border:none;border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;font-size:15px;transition:all .2s;display:flex}.modal-close:hover{color:#fff;background:#42c7fd40;transform:rotate(90deg)}.spinner{justify-content:center;align-items:center;padding:60px;display:flex}.spinner-inner{border:3px solid #143b843d;border-top-color:#0b2950;border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.count-up{transition:all .4s cubic-bezier(.4,0,.2,1)}.sidebar-footer{text-align:center;border-top:1px solid #ffffff17;margin-top:auto;padding:16px 18px 12px}.sidebar-footer small{color:#fffc;letter-spacing:.04em;font-size:11px;font-weight:500}.db-today-panel{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#092f739e;border:1px solid #143b843d;border-radius:12px;margin-bottom:20px;padding:20px}.db-today-title{color:#fff;align-items:center;gap:8px;margin-bottom:16px;font-size:14px;font-weight:700;display:flex}.db-today-grid{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.db-today-item{background:#143b841a;border:1px solid #143b842b;border-radius:8px;flex-direction:column;align-items:center;padding:12px 8px;display:flex}.db-today-label{color:#fff9;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:11px;font-weight:600}.db-today-value{color:#fff;letter-spacing:-.02em;font-size:28px;font-weight:900}.db-stat-card{cursor:pointer;transition:transform .2s,box-shadow .2s}.db-stat-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #ffffff59}.login-bg{background:linear-gradient(135deg,#1a4a8a 0%,#092f73 50%,#1a4a8a 100%);justify-content:center;align-items:center;display:flex;position:fixed;inset:0;overflow:hidden}.login-bg:before{content:"";pointer-events:none;background:radial-gradient(at 50% 0,#143b8433 0%,#0000 60%);position:absolute;inset:0}.login-card{z-index:1;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#092f73de;border:1px solid #143b8447;border-radius:16px;width:420px;padding:48px 40px;position:relative;box-shadow:0 20px 60px #00000080,0 0 40px #ffffff1f}.login-brand{text-align:center;margin-bottom:36px}.login-logo{margin-bottom:8px;font-size:56px;display:block}.login-title{background:linear-gradient(90deg,#0b2950,#1a4a8a);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin:0 0 4px;font-size:28px;font-weight:700}.login-sub{color:#ffffff73;margin:0;font-size:14px}.login-form{flex-direction:column;gap:20px;display:flex}.login-field{flex-direction:column;gap:8px;display:flex}.login-field label{color:#fff9;font-size:13px}.login-field input{color:#fff;background:#092f73a6;border:1px solid #143b843d;border-radius:8px;outline:none;padding:12px 16px;font-size:15px;transition:border-color .2s}.login-field input:focus{border-color:#0b2950}.login-field input::placeholder{color:#ffffff40}.login-error{color:#f87171;background:#ef444426;border:1px solid #ef44444d;border-radius:8px;padding:10px 14px;font-size:13px}.login-btn{color:#fff;cursor:pointer;background:linear-gradient(90deg,#0b2950,#1a4a8a);border:none;border-radius:8px;padding:14px;font-size:16px;font-weight:600;transition:opacity .2s,transform .2s}.login-btn:hover{opacity:.9;transform:translateY(-1px)}.login-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.login-demo{border-top:1px solid #ffffff14;margin-top:28px;padding-top:24px}.login-demo p{color:#ffffff59;text-align:center;margin:0 0 10px;font-size:12px}.demo-accounts{justify-content:center;gap:10px;display:flex}.demo-accounts button{color:#ffffffb3;cursor:pointer;background:#143b8433;border:1px solid #143b8459;border-radius:6px;padding:8px 14px;font-size:12px;transition:all .2s}.demo-accounts button:hover{color:#fff;background:#143b8459}.user-role-badge{align-items:center;gap:10px;display:flex}.role-tag{color:#fff;background:linear-gradient(90deg,#0b2950,#1a4a8a);border-radius:20px;padding:4px 12px;font-size:12px;font-weight:600}.role-org{color:#ffffff80;font-size:12px}.logout-btn{color:#fca5a5;cursor:pointer;background:#ef444440;border:1px solid #f87171b3;border-radius:6px;padding:5px 14px;font-size:13px;font-weight:600;transition:all .2s}.logout-btn:hover{color:#fff;background:#ef444473;border-color:#f87171}.role-switch-wrap{z-index:1000;position:relative}.role-switch-btn{color:#fff;cursor:pointer;background:linear-gradient(90deg,#0b2950,#1a4a8a);border:none;border-radius:20px;align-items:center;gap:4px;padding:4px 12px;font-size:12px;font-weight:600;transition:all .2s;display:flex}.role-switch-btn:hover{opacity:.85}.role-switch-btn.previewing{background:linear-gradient(90deg,#f59e0b,#ef4444)}.role-arrow{margin-left:2px;font-size:8px}.role-switch-dropdown{background:#092f73;border:1px solid #143b8459;border-radius:10px;min-width:140px;max-height:320px;padding:6px;position:fixed;overflow-y:auto;transform:translateZ(999999px);box-shadow:0 8px 24px #0009;z-index:999999!important}.role-switch-item{color:#ffffffbf;cursor:pointer;border-radius:6px;padding:7px 12px;font-size:13px;transition:background .15s}.role-switch-item:hover{color:#42c7fd;background:#42c7fd33}.role-switch-item.active{color:#42c7fd;background:#42c7fd40;font-weight:700}.site-footer{text-align:center;color:#ffffff80;background:linear-gradient(#1a4a8a 0%,#092f73 100%);border-top:1px solid #42c7fd26;flex-shrink:0;margin-top:auto;padding:20px 28px;font-size:12px}.site-footer span{margin-right:10px}.beian-link{color:#ffffff59;text-decoration:none;transition:color .2s}.beian-link:hover{color:#42c7fd}.db-dashboard-stats{display:none!important}.db-v2{padding:20px}.db-header{border-bottom:1px solid #1a4a8a33;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;display:flex}.db-title{color:#fff;letter-spacing:.02em;margin:0;font-size:24px;font-weight:800}.db-time{color:#fff9;font-size:13px}.db-main-grid{grid-template-rows:auto auto;grid-template-columns:1fr 300px 1fr;align-items:stretch;gap:16px;display:grid}.db-quadrant{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#143b8466;border:1px solid #1a4a8a33;border-radius:12px;flex-direction:column;gap:12px;padding:16px;display:flex}.db-quad-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.db-quad-title{color:#fff;font-size:14px;font-weight:700}.chart-view-toggle{background:#092f7399;border-radius:6px;gap:4px;padding:3px;display:flex}.chart-view-btn{color:#ffffffa6;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:5px 14px;font-size:12px;font-weight:600;transition:all .2s}.chart-view-btn:hover{color:#fffc}.chart-view-btn.active{color:#fff;background:#42c7fd;font-weight:700;box-shadow:0 2px 8px #42c7fd66}.db-quad-stats{gap:12px;display:flex}.db-mini-stat{background:#092f7380;border-radius:8px;flex-direction:column;flex:1;gap:4px;padding:10px 12px;display:flex}.db-mini-stat .label{color:#ffffff80;font-size:11px}.db-mini-stat .value{color:#fff;font-size:16px;font-weight:700}.db-mini-stat .value.success{color:#10b981}.db-mini-stat .value.warning{color:#f59e0b}.db-quad-chart{flex:1;min-height:140px}.db-center{flex-direction:column;grid-area:1/2/span 2;justify-content:center;align-items:center;gap:16px;display:flex}.db-center .db-3d-container{perspective:1500px;width:300px;height:300px;margin:0}.db-center .db-3d-cube,.db-center .db-3d-face{width:180px;height:180px}.db-center-label{color:#fffc;letter-spacing:.1em;text-transform:uppercase;font-size:18px;font-weight:800}@media (width<=1200px){.db-main-grid{grid-template-rows:auto auto auto;grid-template-columns:1fr 1fr}.db-center{grid-area:1/1/auto/span 2}.db-quadrant:nth-child(2),.db-quadrant:nth-child(4){grid-row:2}.db-quadrant:nth-child(5),.db-quadrant:nth-child(6){grid-row:3}}@media (width<=768px){.db-main-grid{grid-template-columns:1fr}.db-center{grid-column:1}}.page-head{margin-bottom:20px}.stat-grid{margin-bottom:24px}.data-table{margin-top:16px}.detail-label{min-width:80px;font-size:13px;display:inline-block;color:#8ba4c7!important}.detail-content{color:#fff}.detail-section h4{border-bottom:1px solid #ffffff1a;margin:20px 0 12px;padding-bottom:8px;font-size:16px;color:#fff!important}.detail-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.detail-grid>div{flex-direction:column;gap:4px;display:flex}.detail-grid>div>span:first-child{color:#8ba4c7;font-size:13px}.detail-grid>div>span:last-child{color:#fff;font-size:15px;font-weight:500}.growth-container{padding:20px}.student-selector{align-items:center;gap:12px;margin-bottom:24px;display:flex}.student-selector label{color:#fff;font-size:15px;font-weight:500}.student-selector select{color:#fff;cursor:pointer;background:#0b2950f2;border:1px solid #42c7fd66;border-radius:8px;min-width:200px;padding:8px 16px;font-size:14px}.student-selector select:focus{border-color:#42c7fd;outline:none;box-shadow:0 0 8px #42c7fd66}.growth-content{background:#0b295099;border-radius:16px;padding:24px}.growth-content h3{color:#fff;margin:0 0 24px;font-size:18px;font-weight:600}.radar-chart-container{background:#092f7380;border-radius:12px;margin-bottom:24px;padding:20px}.growth-timeline{margin-top:24px}.growth-timeline h4{margin:0 0 16px;font-size:16px;font-weight:600;color:#fff!important}.growth-timeline .timeline{border-left:2px solid #42c7fd4d;padding-left:24px;position:relative}.growth-timeline .timeline-item{color:#fff;border-radius:6px;flex-wrap:wrap;align-items:flex-start;min-height:20px;margin-left:0;margin-right:0;padding-bottom:16px;padding-left:8px;padding-right:8px;line-height:20px;transition:background .2s;display:flex;position:relative}.growth-timeline .timeline-item:last-child{padding-bottom:0}.growth-timeline .timeline-item:hover{background:#42c7fd1a}.growth-timeline .timeline-item .view-link{color:#42c7fd;opacity:.8;margin-left:8px;font-size:12px;line-height:20px}.growth-timeline .timeline-item:hover .view-link{opacity:1}.growth-timeline .timeline-item:before{content:"";background:#42c7fd;border-radius:50%;width:12px;height:12px;position:absolute;top:50%;left:-29px;transform:translateY(-50%);box-shadow:0 0 6px #42c7fd99}.growth-timeline .timeline-item .date{color:#42c7fd;min-width:70px;margin-right:12px;font-size:13px;font-weight:600;line-height:20px;display:inline-block}.growth-timeline .timeline-item .event{color:#fff;font-size:14px}.growth-timeline .timeline-item .score{color:#8ba4c7;margin-left:8px;font-size:13px}.growth-stats{grid-template-columns:repeat(4,1fr);gap:16px;margin-top:24px;display:grid}.growth-stat-card{background:#0b2950cc;border-left:3px solid #42c7fd;border-radius:12px;padding:16px}.growth-stat-card .label{color:#8ba4c7;margin-bottom:8px;font-size:13px}.growth-stat-card .value{color:#fff;font-size:24px;font-weight:600}.growth-stat-card .sub{color:#42c7fd;margin-top:4px;font-size:12px}.reports-container{flex-direction:column;gap:24px;display:flex}.report-preview-box{background:#092f7380;border:1px solid #42c7fd4d;border-radius:12px;overflow:hidden}.report-preview-header{background:#42c7fd14;border-bottom:1px solid #42c7fd33;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.report-preview-title{color:#fff;font-size:15px;font-weight:600}.btn-download{color:#fff;cursor:pointer;background:linear-gradient(135deg,#165dff,#7b61ff);border:none;border-radius:6px;padding:6px 16px;font-size:13px;transition:opacity .2s}.btn-download:hover{opacity:.85}.report-content-pre{color:#e8f0fe;white-space:pre-wrap;word-break:break-all;max-height:500px;margin:0;padding:16px;font-family:PingFang SC,Microsoft YaHei,sans-serif;font-size:13px;line-height:1.8;overflow-y:auto}.report-content-pre::-webkit-scrollbar{width:6px}.report-content-pre::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.report-content-pre::-webkit-scrollbar-thumb{background:#42c7fd66;border-radius:3px}.report-history{background:#092f734d;border:1px solid #42c7fd33;border-radius:12px;padding:16px}.report-history-title{color:#fff;border-bottom:1px solid #42c7fd26;margin:0 0 12px;padding-bottom:8px;font-size:15px;font-weight:600}.report-history-list{flex-direction:column;gap:6px;display:flex}.report-history-item{background:#ffffff08;border:1px solid #0000;border-radius:6px;justify-content:space-between;align-items:center;padding:8px 12px;transition:background .15s;display:flex}.report-history-item:hover{background:#42c7fd14}.report-history-item.active{background:#42c7fd1f;border-color:#42c7fd66}.report-history-info{cursor:pointer;flex:1;align-items:center;gap:12px;display:flex}.report-history-name{color:#fff;min-width:80px;font-size:13px;font-weight:500}.report-history-period,.report-history-date{color:#8ba4c7;font-size:12px}.report-history-period{color:#42c7fd;font-weight:500}.btn-sm{cursor:pointer;border:none;border-radius:4px;padding:4px 10px;font-size:12px;transition:opacity .2s}.btn-sm:hover{opacity:.8}
