:root{color-scheme:light;font-family:PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;color:#1f2937}*{box-sizing:border-box}html,body{margin:0;min-height:100%}body{min-width:320px}button,input{font:inherit}button{border:0;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.6}#app,.page{min-height:100vh}.page-home{background:#e0f3ff}.page-report{background:linear-gradient(180deg,#f5f7fb,#eef2f9)}.page-preview{background:#eef2f6}.home-page,.quiz-page{width:min(100%,480px);margin:0 auto}.home-page{padding:0 0 6.5rem}.home-page-account{padding:calc(env(safe-area-inset-top,0) + 1.25rem) 1rem 3rem}.home-page-user{padding:calc(env(safe-area-inset-top,0) + 1rem) 1rem 6.5rem}.banner-section{padding-top:env(safe-area-inset-top,0)}.banner-card{position:relative;overflow:hidden}.banner-image{display:block;width:100%;height:auto}.entry-card{width:calc(100% - 2rem);margin:1rem;padding:1.25rem 1.125rem;border-radius:1.5rem;background:#fffffff5;box-shadow:0 1rem 2rem #36231214;display:flex;align-items:center;justify-content:space-between;color:inherit}.entry-title{display:block;font-size:1.125rem;font-weight:700;color:#24180e}.entry-subtitle{display:block;margin-top:.375rem;font-size:.8125rem;color:#64748b}.entry-link{display:inline-flex;align-items:center;gap:.375rem;color:#0f766e}.entry-link-arrow{font-size:1.25rem;line-height:1}.user-card{margin-top:.5rem;border-radius:1.5rem;background:#fffffff5;box-shadow:0 1rem 2rem #17203314;overflow:hidden}.user-row{display:flex;align-items:center;gap:1rem;padding:1.125rem 1rem}.user-row+.user-row{border-top:1px solid #e5edf9}.user-row-main{flex:1 1 auto;min-width:0}.user-row-label{font-size:.875rem;color:#64748b}.user-row-value{margin-top:.25rem;font-size:1rem;font-weight:700;color:#172033}.user-inline-input{width:100%;margin-top:.375rem;height:2.5rem;padding:0 .75rem;border:1px solid #d6e4ff;border-radius:.85rem;background:#f7faff;outline:none;font-size:1rem}.user-inline-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f624}.text-action-btn{flex:0 0 auto;min-width:3rem;padding:.25rem 0;background:transparent;color:#2563eb;font-size:.9375rem;font-weight:600}.user-empty-card{margin-top:.5rem;padding:1.5rem 1.25rem;border-radius:1.5rem;background:#fffffff5;box-shadow:0 1rem 2rem #17203314}.user-empty-title{font-size:1rem;font-weight:700;color:#172033}.user-login-btn{width:100%;margin-top:1rem}.user-nav-card{width:100%;margin-top:1rem;padding:1.125rem 1rem;display:flex;align-items:center;justify-content:space-between;background:#fffffff5;color:#172033;text-align:left}.user-nav-label{font-size:1rem;font-weight:700}.user-nav-arrow{font-size:1.25rem;line-height:1;color:#94a3b8}.account-signout-btn{width:100%;margin-top:1rem}.bottom-tabbar{position:fixed;left:50%;bottom:0;transform:translate(-50%);z-index:20;width:min(100%,480px);display:grid;grid-template-columns:repeat(2,1fr);padding:.625rem 1rem calc(env(safe-area-inset-bottom,0) + .75rem);background:#fffffff5;border-top:1px solid rgba(148,163,184,.18);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.tabbar-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;min-height:3rem;background:transparent;color:#94a3b8}.tabbar-item-active{color:#2563eb}.tabbar-icon{font-size:1.125rem;line-height:1}.tabbar-label{font-size:.75rem;font-weight:600}.hero-card,.account-card{border-radius:1.5rem;background:#fffffff5;box-shadow:0 1rem 2rem #17203314}.hero-card{display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:center;padding:1.25rem}.hero-eyebrow{font-size:.8125rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#2563eb}.hero-title{margin:.5rem 0 0;font-size:1.75rem;line-height:1.1;color:#172033}.hero-desc{margin:.75rem 0 0;font-size:.9375rem;line-height:1.7;color:#64748b}.hero-image{width:6.5rem;height:6.5rem;object-fit:cover;border-radius:1.25rem;box-shadow:0 .75rem 1.5rem #2563eb29}.account-card{margin-top:1rem;padding:1.25rem}.account-row+.account-row{margin-top:1rem}.account-label{font-size:.875rem;font-weight:600;color:#475569}.account-input{width:100%;margin-top:.5rem;height:3rem;padding:0 .875rem;border-radius:.95rem;border:1px solid #d6e4ff;background:#f7faff;outline:none;font-size:1rem}.account-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f624}.account-value{margin-top:.5rem;font-size:1rem;font-weight:700;color:#172033}.account-status{margin-top:.5rem;display:inline-flex;align-items:center;min-height:2rem;padding:0 .75rem;border-radius:999px;background:#fff7ed;color:#c2410c;font-size:.875rem;font-weight:600}.account-status-bound{background:#ecfdf5;color:#047857}.account-message{margin-top:1rem;font-size:.875rem;color:#2563eb}.user-card .account-message{margin:0;padding:0 1rem 1rem}.login-method-card{margin-top:1rem}.login-method-status{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;min-width:3.75rem;min-height:2rem;padding:0 .75rem;border-radius:999px;background:#fff7ed;color:#c2410c;font-size:.8125rem;font-weight:700}.login-method-status-bound{background:#ecfdf5;color:#047857}.account-actions{display:flex;flex-direction:column;gap:.75rem;margin-top:1.25rem}.account-btn{width:100%}.quiz-page{padding:calc(env(safe-area-inset-top,0) + 1.5rem) 1rem calc(env(safe-area-inset-bottom,0) + 3rem)}.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}.page-eyebrow{font-size:.875rem;letter-spacing:.08em;text-transform:uppercase;color:#64748b}.page-title{margin:.375rem 0 0;font-size:2rem;line-height:1.1;color:#172033}.text-btn{padding:.5rem 0;background:transparent;color:#2563eb}.query-card,.empty-state,.exam-card{border-radius:1.25rem;background:#fffffff5;box-shadow:0 1rem 2rem #17203312}.query-card{padding:1rem 1.125rem;margin-bottom:1rem}.query-label{font-size:.875rem;color:#64748b}.query-phone{flex:1 1 auto;min-width:0;font-size:1.125rem;font-weight:700;line-height:1.2;color:#1d4ed8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.student-tabs{display:flex;gap:.75rem;overflow-x:auto;padding:.25rem 0 1rem;margin-bottom:.25rem;scrollbar-width:none}.student-tabs::-webkit-scrollbar{display:none}.student-tab{flex:0 0 auto;padding:.875rem 1.25rem;border-radius:999px;background:#fff;color:#4b5563;box-shadow:0 .75rem 1.5rem #1118270f}.student-tab-active{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff}.exam-list{display:flex;flex-direction:column;gap:1rem}.exam-card{padding:1.125rem 1rem}.exam-head{width:100%;display:flex;align-items:center;justify-content:space-between;background:transparent;padding:0;color:inherit}.exam-title{text-align:left;font-size:1.0625rem;font-weight:700;color:#162033}.exam-arrow{width:0;height:0;border-top:.35rem solid transparent;border-bottom:.35rem solid transparent;border-left:.5rem solid #475569;transition:transform .2s ease}.exam-arrow-expanded{transform:rotate(90deg)}.subject-list{margin-top:.5rem}.subject-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding-top:1rem}.subject-row+.subject-row{margin-top:.25rem;border-top:1px solid #eef2f7}.subject-name{flex:1;font-size:.95rem;color:#334155}.subject-actions{display:flex;gap:.625rem;flex-wrap:wrap;justify-content:flex-end}.pill-btn{display:inline-flex;align-items:center;justify-content:center;min-height:2.25rem;padding:0 .875rem;border-radius:999px;background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;font-size:.875rem}.pill-btn-secondary{background:#eff6ff;color:#2563eb;border:1px solid #bfdbfe}.empty-state{padding:1.5rem 1.125rem;text-align:center;font-size:.95rem;line-height:1.7;color:#667085}.preview-page{min-height:100vh;width:100%;max-width:none;margin:0;padding:0 .25rem calc(env(safe-area-inset-bottom,0) + .5rem)}.preview-topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:.25rem;height:calc(env(safe-area-inset-top,0) + 3rem);padding:env(safe-area-inset-top,0) .375rem 0;background:#eef2f6f5;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.preview-back{display:inline-flex;align-items:center;gap:.25rem;min-height:2.5rem;padding:0 .5rem;background:transparent;color:#0f172a;font-size:1rem}.preview-back-arrow{font-size:1.25rem;line-height:1}.preview-status{display:flex;align-items:center;justify-content:center;gap:.75rem;margin:.5rem auto .75rem;width:min(100%,28rem);padding:.875rem 1rem;border-radius:1rem;background:#ffffffeb;color:#475569;text-align:center}.pdf-viewer{display:flex;flex-direction:column;gap:.375rem;width:100%}.pdf-viewer-hidden{display:none}.pdf-page-card{overflow:hidden;background:#fff;border-radius:0;box-shadow:none}.pdf-page-card canvas{display:block;width:100%;height:auto;background:#fff}.modal-backdrop{position:fixed;inset:0;z-index:20;display:flex;align-items:flex-end;justify-content:center;padding:1rem;background:#0f172a52}.modal-panel{width:min(100%,480px);border-radius:1.75rem;background:#fffdf8;box-shadow:0 1.5rem 3rem #0f172a38;padding:1.25rem}.modal-title{font-size:1.25rem;font-weight:700;color:#20170e}.modal-desc{margin-top:.5rem;font-size:.875rem;line-height:1.6;color:#6b7280}.phone-input{width:100%;margin-top:1rem;height:3.25rem;padding:0 1rem;border-radius:1rem;border:1px solid #d6e4ff;background:#f7faff;outline:none;font-size:1.0625rem}.phone-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f624}.code-row{display:flex;gap:.75rem;align-items:stretch;flex-wrap:nowrap;margin-top:1rem}.code-row .phone-input{width:auto;margin-top:0}.code-input{flex:1 1 auto;min-width:0}.code-btn{flex:0 0 9.5rem;width:9.5rem;height:3.25rem;min-height:3.25rem;margin-top:0;padding:0 .75rem;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;border-radius:1rem;text-align:center;line-height:1.2;font-variant-numeric:tabular-nums}.form-error{margin-top:.625rem;min-height:1.4em;font-size:.875rem;color:#dc2626}.modal-tip{margin-top:.625rem;min-height:1.6em;font-size:.8125rem;line-height:1.6;color:#64748b}.modal-actions{display:flex;gap:.75rem;margin-top:1rem}.primary-btn,.ghost-btn{flex:1;min-height:2.875rem;border-radius:999px}.primary-btn{color:#fff;background:linear-gradient(135deg,#2563eb,#60a5fa)}.ghost-btn{color:#475569;background:#eef2ff}@keyframes spin{to{transform:rotate(360deg)}}@media(min-width:768px){.modal-backdrop{align-items:center}.preview-page{padding-left:.375rem;padding-right:.375rem}.account-actions{flex-direction:row}}.preview-topbar{justify-content:space-between}.preview-topbar-actions{margin-left:auto;display:flex;align-items:center}.preview-download{min-height:2.25rem;padding:0 .875rem;border-radius:999px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;font-size:.875rem;box-shadow:0 .75rem 1.5rem #2563eb29}.preview-download:disabled{cursor:not-allowed;opacity:.55;box-shadow:none}.browser-guide-backdrop{position:fixed;inset:0;z-index:30;padding:calc(env(safe-area-inset-top,0) + .75rem) 1rem 1rem;background:#0f172acc}.browser-guide-shell{display:flex;flex-direction:column;align-items:flex-end;width:min(100%,30rem);height:100%;margin:0 auto}.browser-guide-image{display:block;width:min(100%,26rem);height:auto;margin-left:auto}.query-card-head{display:flex;align-items:center;gap:.75rem;flex-wrap:nowrap}.query-filter{flex:0 0 auto;display:flex;align-items:center;gap:.375rem}.query-filter-label{font-size:.9375rem;font-weight:600;color:#64748b;white-space:nowrap}.query-select{min-width:5.75rem;min-height:2.25rem;padding:0 .625rem;border-radius:.9rem;border:1px solid #d6e4ff;background:#f7faff;color:#1d4ed8;font-size:.875rem;outline:none}.query-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f624}@media(max-width:380px){.query-card-head{gap:.5rem}.query-phone{font-size:1rem}.query-filter{gap:.25rem}.query-filter-label{font-size:.875rem}.query-select{min-width:5.25rem;padding:0 .5rem;font-size:.8125rem}}
