:root{--primary:#4f46e5;--primary-light:#6366f1;--primary-dark:#4338ca;--primary-bg:#eef2ff;--bg:#f8fafc;--bg-secondary:#f1f5f9;--card-bg:#fff;--card-border:#e2e8f0;--text-primary:#1e293b;--text-secondary:#64748b;--text-muted:#94a3b8;--text-inverse:#fff;--success:#10b981;--warning:#f59e0b;--error:#ef4444;--info:#3b82f6;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000001a;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--nav-width:240px;--header-height:60px;--bottom-nav-height:64px;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.35s ease;--font-sans:-apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;--font-mono:"SF Mono", "Fira Code", "Fira Mono", "Roboto Mono", monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-sans);background-color:var(--bg);color:var(--text-primary);width:100vw;height:100vh;line-height:1.6;overflow:hidden}#root{width:100vw;height:100vh;overflow:hidden}a{color:var(--primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--primary-dark)}button{font-family:var(--font-sans);cursor:pointer;font-size:inherit;background:0 0;border:none}input,textarea,select{font-family:var(--font-sans);font-size:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes typingDot{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.app-container{width:100vw;height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--nav-width);background:var(--card-bg);border-right:1px solid var(--card-border);transition:transform var(--transition-normal);z-index:100;flex-direction:column;flex-shrink:0;display:flex}.sidebar-header{border-bottom:1px solid var(--card-border);align-items:center;gap:12px;padding:20px;display:flex}.sidebar-logo{background:linear-gradient(135deg, var(--primary), var(--primary-light));border-radius:var(--radius-md);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;font-weight:700;display:flex}.sidebar-title{color:var(--text-primary);font-size:18px;font-weight:700}.sidebar-subtitle{color:var(--text-muted);font-size:12px}.nav-list{flex:1;padding:12px 8px;list-style:none;overflow-y:auto}.nav-item{margin-bottom:2px}.nav-link{border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast);align-items:center;gap:12px;padding:10px 14px;font-size:14px;font-weight:500;text-decoration:none;display:flex}.nav-link:hover{background:var(--bg-secondary);color:var(--text-primary)}.nav-link.active{background:var(--primary-bg);color:var(--primary);font-weight:600}.nav-link .nav-icon{flex-shrink:0;width:20px;height:20px}.main-content{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.top-header{height:var(--header-height);background:var(--card-bg);border-bottom:1px solid var(--card-border);flex-shrink:0;align-items:center;gap:12px;padding:0 24px;display:flex}.top-header-title{color:var(--text-primary);font-size:16px;font-weight:600}.top-header-subtitle{color:var(--text-muted);font-size:13px}.page-content{flex:1;overflow:hidden auto}.bottom-nav{height:var(--bottom-nav-height);background:var(--card-bg);border-top:1px solid var(--card-border);z-index:100;padding:4px 0;padding-bottom:env(safe-area-inset-bottom,4px);display:none;position:fixed;bottom:0;left:0;right:0}.bottom-nav-list{justify-content:space-around;align-items:center;height:100%;padding:0 8px;list-style:none;display:flex}.bottom-nav-link{border-radius:var(--radius-md);color:var(--text-muted);transition:all var(--transition-fast);flex-direction:column;justify-content:center;align-items:center;gap:2px;min-width:56px;padding:6px 12px;font-size:11px;font-weight:500;text-decoration:none;display:flex}.bottom-nav-link:hover{color:var(--text-secondary)}.bottom-nav-link.active{color:var(--primary)}.bottom-nav-link .nav-icon{width:22px;height:22px}.chat-container{flex-direction:column;height:100%;display:flex}.chat-messages{flex-direction:column;flex:1;gap:16px;padding:24px;display:flex;overflow-y:auto}.welcome-section{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:40px 20px;animation:.5s fadeIn;display:flex}.welcome-avatar{background:linear-gradient(135deg, var(--primary), var(--primary-light));border-radius:var(--radius-xl);color:#fff;width:72px;height:72px;box-shadow:var(--shadow-lg);justify-content:center;align-items:center;margin-bottom:16px;font-size:32px;font-weight:700;display:flex}.welcome-title{color:var(--text-primary);margin-bottom:8px;font-size:24px;font-weight:700}.welcome-desc{color:var(--text-secondary);max-width:400px;font-size:14px;line-height:1.6}.quick-actions{flex-wrap:wrap;justify-content:center;gap:8px;max-width:500px;margin-top:24px;display:flex}.quick-action-btn{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-full);color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;align-items:center;gap:6px;padding:8px 16px;font-size:13px;display:flex}.quick-action-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-bg);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.quick-action-btn .btn-icon{width:16px;height:16px}.message{gap:12px;max-width:85%;animation:.3s slideUp;display:flex}.message.user{flex-direction:row-reverse;align-self:flex-end}.message.assistant{align-self:flex-start}.message-avatar{border-radius:var(--radius-full);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:600;display:flex}.message.user .message-avatar{background:var(--primary);color:#fff}.message.assistant .message-avatar{background:linear-gradient(135deg, var(--primary), var(--primary-light));color:#fff}.message-bubble{border-radius:var(--radius-lg);word-break:break-word;padding:12px 16px;font-size:14px;line-height:1.7}.message.user .message-bubble{background:var(--primary);color:var(--text-inverse);border-bottom-right-radius:var(--radius-sm)}.message.assistant .message-bubble{background:var(--card-bg);color:var(--text-primary);border:1px solid var(--card-border);border-bottom-left-radius:var(--radius-sm);box-shadow:var(--shadow-sm)}.typing-indicator{align-items:center;gap:4px;padding:12px 16px;display:flex}.typing-indicator span{background:var(--text-muted);border-radius:var(--radius-full);width:8px;height:8px;animation:1.4s infinite typingDot}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}.chat-input-area{background:var(--card-bg);border-top:1px solid var(--card-border);align-items:flex-end;gap:12px;padding:16px 24px;display:flex}.chat-input-wrapper{flex:1;position:relative}.chat-input{border:1px solid var(--card-border);border-radius:var(--radius-lg);background:var(--bg);width:100%;color:var(--text-primary);resize:none;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;min-height:44px;max-height:120px;padding:12px 16px;font-size:14px;line-height:1.5}.chat-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.chat-input::placeholder{color:var(--text-muted)}.send-btn{background:var(--primary);color:#fff;border-radius:var(--radius-md);width:44px;height:44px;transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.send-btn:hover{background:var(--primary-dark);transform:scale(1.05)}.send-btn:disabled{background:var(--text-muted);cursor:not-allowed;transform:none}.send-btn .btn-icon{width:20px;height:20px}.campus-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;padding:24px;display:grid}.service-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-normal);color:inherit;padding:24px;text-decoration:none;display:block}.service-card:hover{box-shadow:var(--shadow-lg);border-color:var(--primary-light);transform:translateY(-4px)}.service-card-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:16px;font-size:24px;display:flex}.service-card-title{color:var(--text-primary);margin-bottom:8px;font-size:16px;font-weight:600}.service-card-desc{color:var(--text-secondary);font-size:13px;line-height:1.5}.page-header{padding:24px 24px 0}.page-title{color:var(--text-primary);margin-bottom:4px;font-size:22px;font-weight:700}.page-desc{color:var(--text-secondary);font-size:14px}.map-container{flex-direction:column;gap:16px;padding:24px;display:flex}.map-search{gap:12px;display:flex}.map-search-input{border:1px solid var(--card-border);border-radius:var(--radius-md);background:var(--card-bg);color:var(--text-primary);transition:border-color var(--transition-fast);outline:none;flex:1;padding:10px 16px;font-size:14px}.map-search-input:focus{border-color:var(--primary)}.map-canvas{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);height:400px;position:relative;overflow:hidden}.map-svg{width:100%;height:100%}.poi-list{flex-direction:column;gap:8px;display:flex}.poi-item{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:12px;padding:12px 16px;display:flex}.poi-item:hover{border-color:var(--primary-light);background:var(--primary-bg)}.poi-item.active{border-color:var(--primary);background:var(--primary-bg)}.poi-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.poi-info{flex:1}.poi-name{color:var(--text-primary);font-size:14px;font-weight:600}.poi-address{color:var(--text-muted);font-size:12px}.schedule-container{padding:24px}.schedule-week-selector{gap:8px;margin-bottom:20px;padding-bottom:4px;display:flex;overflow-x:auto}.week-btn{border-radius:var(--radius-full);color:var(--text-secondary);background:var(--card-bg);border:1px solid var(--card-border);transition:all var(--transition-fast);white-space:nowrap;padding:8px 20px;font-size:13px;font-weight:500}.week-btn:hover{border-color:var(--primary-light);color:var(--primary)}.week-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.schedule-table{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);overflow:hidden}.schedule-table-header{background:var(--bg-secondary);grid-template-columns:80px repeat(5,1fr);display:grid}.schedule-table-header .header-cell{text-align:center;color:var(--text-secondary);border-right:1px solid var(--card-border);padding:12px 8px;font-size:13px;font-weight:600}.schedule-table-header .header-cell:last-child{border-right:none}.schedule-table-body{grid-template-columns:80px repeat(5,1fr);display:grid}.time-cell{text-align:center;color:var(--text-muted);border-right:1px solid var(--card-border);border-bottom:1px solid var(--card-border);flex-direction:column;justify-content:center;align-items:center;padding:16px 8px;font-size:12px;display:flex}.course-cell{border-right:1px solid var(--card-border);border-bottom:1px solid var(--card-border);min-height:80px;padding:4px}.course-cell:last-child{border-right:none}.course-card{border-radius:var(--radius-sm);cursor:pointer;height:100%;transition:transform var(--transition-fast);flex-direction:column;justify-content:center;padding:8px;font-size:12px;display:flex}.course-card:hover{transform:scale(1.02)}.course-card .course-name{margin-bottom:4px;font-weight:600}.course-card .course-info{opacity:.8;font-size:11px}.course-card.current{box-shadow:0 0 0 2px var(--primary)}.grades-container{padding:24px}.grades-stats{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);text-align:center;padding:20px}.stat-value{color:var(--primary);margin-bottom:4px;font-size:28px;font-weight:700}.stat-label{color:var(--text-secondary);font-size:13px}.grades-filter{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.filter-btn{border-radius:var(--radius-full);color:var(--text-secondary);background:var(--card-bg);border:1px solid var(--card-border);transition:all var(--transition-fast);padding:6px 16px;font-size:13px}.filter-btn:hover{border-color:var(--primary-light);color:var(--primary)}.filter-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.grades-table{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);overflow:hidden}.grade-row{border-bottom:1px solid var(--card-border);transition:background var(--transition-fast);grid-template-columns:2fr 1fr 1fr 1fr 1fr;align-items:center;padding:14px 20px;font-size:14px;display:grid}.grade-row:last-child{border-bottom:none}.grade-row:hover{background:var(--bg-secondary)}.grade-row.header{background:var(--bg-secondary);color:var(--text-secondary);font-size:13px;font-weight:600}.grade-row.header:hover{background:var(--bg-secondary)}.grade-badge{border-radius:var(--radius-full);padding:2px 10px;font-size:12px;font-weight:600;display:inline-block}.grade-badge.excellent{color:#065f46;background:#d1fae5}.grade-badge.good{color:#1e40af;background:#dbeafe}.grade-badge.pass{color:#92400e;background:#fef3c7}.grade-badge.fail{color:#991b1b;background:#fee2e2}.grade-distribution{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);margin-top:24px;padding:20px}.grade-distribution-title{color:var(--text-primary);margin-bottom:16px;font-size:15px;font-weight:600}.bar-chart{flex-direction:column;gap:12px;display:flex}.bar-item{align-items:center;gap:12px;display:flex}.bar-label{width:60px;color:var(--text-secondary);text-align:right;flex-shrink:0;font-size:13px}.bar-track{background:var(--bg-secondary);border-radius:var(--radius-full);flex:1;height:24px;overflow:hidden}.bar-fill{border-radius:var(--radius-full);color:#fff;align-items:center;height:100%;padding-left:8px;font-size:11px;font-weight:600;transition:width .8s;display:flex}.library-container{flex-direction:column;gap:20px;padding:24px;display:flex}.library-search{gap:12px;display:flex}.library-search-input{border:1px solid var(--card-border);border-radius:var(--radius-md);background:var(--card-bg);color:var(--text-primary);transition:border-color var(--transition-fast);outline:none;flex:1;padding:10px 16px;font-size:14px}.library-search-input:focus{border-color:var(--primary)}.library-section-title{color:var(--text-primary);align-items:center;gap:8px;margin-bottom:12px;font-size:16px;font-weight:600;display:flex}.book-list{flex-direction:column;gap:8px;display:flex}.book-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-md);transition:all var(--transition-fast);gap:16px;padding:16px;display:flex}.book-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-light)}.book-cover{border-radius:var(--radius-sm);background:var(--bg-secondary);width:60px;height:80px;color:var(--text-muted);flex-shrink:0;justify-content:center;align-items:center;display:flex}.book-info{flex:1;min-width:0}.book-title{color:var(--text-primary);margin-bottom:4px;font-size:14px;font-weight:600}.book-author{color:var(--text-secondary);margin-bottom:8px;font-size:12px}.book-meta{align-items:center;gap:12px;display:flex}.book-status{border-radius:var(--radius-full);align-items:center;gap:4px;padding:2px 10px;font-size:11px;font-weight:600;display:inline-flex}.book-status.borrowed{color:#1e40af;background:#dbeafe}.book-status.due-soon{color:#92400e;background:#fef3c7}.book-status.returned,.book-status.available{color:#065f46;background:#d1fae5}.news-container{padding:24px}.news-categories{gap:8px;margin-bottom:20px;padding-bottom:4px;display:flex;overflow-x:auto}.category-btn{border-radius:var(--radius-full);color:var(--text-secondary);background:var(--card-bg);border:1px solid var(--card-border);transition:all var(--transition-fast);white-space:nowrap;padding:6px 16px;font-size:13px}.category-btn:hover{border-color:var(--primary-light);color:var(--primary)}.category-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.news-list{flex-direction:column;gap:12px;display:flex}.news-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-normal);padding:20px}.news-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.news-card-header{align-items:center;gap:8px;margin-bottom:8px;display:flex}.news-tag{border-radius:var(--radius-full);padding:2px 8px;font-size:11px;font-weight:600}.news-tag.notice{color:#1e40af;background:#dbeafe}.news-tag.activity{color:#9d174d;background:#fce7f3}.news-tag.academic{color:#065f46;background:#d1fae5}.news-date{color:var(--text-muted);font-size:12px}.news-card-title{color:var(--text-primary);margin-bottom:8px;font-size:16px;font-weight:600;line-height:1.4}.news-card-summary{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:13px;line-height:1.6;display:-webkit-box;overflow:hidden}.news-modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.news-modal{background:var(--card-bg);border-radius:var(--radius-lg);width:100%;max-width:600px;max-height:80vh;padding:32px;animation:.3s scaleIn;overflow-y:auto}.news-modal-close{border-radius:var(--radius-full);width:32px;height:32px;color:var(--text-muted);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex;position:absolute;top:16px;right:16px}.news-modal-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.news-modal-title{color:var(--text-primary);margin-bottom:12px;font-size:20px;font-weight:700;line-height:1.4}.news-modal-meta{color:var(--text-muted);align-items:center;gap:12px;margin-bottom:20px;font-size:13px;display:flex}.news-modal-content{color:var(--text-primary);font-size:14px;line-height:1.8}.markdown-content{color:var(--text-primary);font-size:14px;line-height:1.7}.markdown-content p{margin-bottom:8px}.markdown-content p:last-child{margin-bottom:0}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4{margin-top:16px;margin-bottom:8px;font-weight:600}.markdown-content h1{font-size:20px}.markdown-content h2{font-size:18px}.markdown-content h3{font-size:16px}.markdown-content ul,.markdown-content ol{margin:8px 0;padding-left:24px}.markdown-content li{margin-bottom:4px}.markdown-content code{background:var(--bg-secondary);border-radius:var(--radius-sm);font-family:var(--font-mono);padding:2px 6px;font-size:13px}.markdown-content pre{color:#e2e8f0;border-radius:var(--radius-md);background:#1e293b;margin:12px 0;padding:16px;overflow-x:auto}.markdown-content pre code{color:inherit;background:0 0;padding:0;font-size:13px}.markdown-content blockquote{border-left:3px solid var(--primary);color:var(--text-secondary);margin:12px 0;padding-left:12px}.markdown-content a{color:var(--primary);text-decoration:underline}.markdown-content table{border-collapse:collapse;width:100%;margin:12px 0}.markdown-content th,.markdown-content td{border:1px solid var(--card-border);text-align:left;padding:8px 12px;font-size:13px}.markdown-content th{background:var(--bg-secondary);font-weight:600}.markdown-content hr{border:none;border-top:1px solid var(--card-border);margin:16px 0}.markdown-content strong{font-weight:600}.markdown-content em{font-style:italic}.message.user .markdown-content{color:var(--text-inverse)}.message.user .markdown-content code{background:#fff3}.message.user .markdown-content a{color:#c7d2fe}@media (width<=1024px){.sidebar{width:200px}.campus-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}}@media (width<=768px){.sidebar{display:none}.bottom-nav{display:block}.top-header{padding:0 16px}.chat-messages{padding:16px}.chat-input-area{padding:12px 16px;padding-bottom:calc(12px + var(--bottom-nav-height))}.message{max-width:90%}.campus-grid{grid-template-columns:1fr;padding:16px}.map-canvas{height:280px}.schedule-table-header,.schedule-table-body{grid-template-columns:50px repeat(5,1fr)}.grade-row{grid-template-columns:1.5fr 1fr 1fr 1fr;font-size:13px}.grade-row .grade-credit{display:none}.page-header{padding:16px 16px 0}.page-content{padding-bottom:var(--bottom-nav-height)}.library-container,.grades-container,.schedule-container,.news-container,.map-container{padding:16px}.news-modal{margin:16px;padding:20px}.welcome-title{font-size:20px}.welcome-desc{font-size:13px}.quick-actions{gap:6px}.quick-action-btn{padding:6px 12px;font-size:12px}}@media (width<=375px){.schedule-table-header,.schedule-table-body{grid-template-columns:40px repeat(5,1fr)}.time-cell{font-size:10px}.course-card{padding:4px;font-size:10px}}.text-center{text-align:center}.text-muted{color:var(--text-muted)}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.edu-login-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.edu-login-modal{text-align:center;background:#fff;border-radius:16px;width:90%;max-width:400px;padding:32px;animation:.2s scaleIn;position:relative;box-shadow:0 20px 60px #00000026}.edu-login-title{color:var(--text-primary);margin-bottom:8px;font-size:20px;font-weight:700}.edu-login-desc{color:var(--text-muted);margin-bottom:24px;font-size:14px}.edu-login-qr-container{border:1px solid var(--card-border);background:#f9fafb;border-radius:12px;justify-content:center;align-items:center;width:280px;height:280px;margin:0 auto 16px;display:flex;overflow:hidden}.edu-login-qr-container img{object-fit:contain;width:100%;height:100%}.edu-login-hint{color:var(--text-muted);margin-bottom:20px;font-size:13px}.edu-login-actions{justify-content:center;gap:12px;display:flex}.edu-login-btn{border:1px solid var(--card-border);color:var(--text-secondary);cursor:pointer;background:#fff;border-radius:8px;align-items:center;gap:6px;padding:8px 20px;font-size:14px;transition:all .2s;display:flex}.edu-login-btn:hover{background:var(--bg-secondary)}.edu-login-btn.primary{background:var(--primary);color:#fff;border-color:var(--primary)}.edu-login-btn.primary:hover{background:#4338ca}.edu-login-status{flex-direction:column;align-items:center;gap:12px;padding:24px;display:flex}.edu-login-status.success{color:#059669}.edu-login-status.success svg{width:48px;height:48px}.data-source-tag{border-radius:4px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-flex}.data-source-tag.live{color:#065f46;background:#d1fae5}.data-source-tag.mock{color:#92400e;background:#fef3c7}.data-source-tag.real{color:#065f46;background:#d1fae5}.edu-connect-btn{border:1px solid var(--card-border);color:var(--text-secondary);cursor:pointer;background:#fff;border-radius:8px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;transition:all .2s;display:inline-flex}.edu-connect-btn:hover{border-color:var(--primary);color:var(--primary)}.edu-connect-btn.connected{color:#4338ca;background:#eef2ff;border-color:#c7d2fe}.news-card-with-image{align-items:flex-start;gap:16px;display:flex}.news-card-image{object-fit:cover;border-radius:8px;flex-shrink:0;width:120px;height:80px}.news-card-content{flex:1;min-width:0}.refresh-btn{border:1px solid var(--card-border);color:var(--text-muted);cursor:pointer;background:#fff;border-radius:6px;align-items:center;gap:4px;padding:4px 12px;font-size:12px;transition:all .2s;display:inline-flex}.refresh-btn:hover{border-color:var(--primary);color:var(--primary)}.refresh-btn.spinning svg{animation:1s linear infinite spin}
