:root{--bg: #eef2f8;--bg-deep: #d9e2ed;--card-bg: #ffffff;--text: #1a2c3e;--text-secondary: #4f6f8f;--text-muted: #7d97b3;--blue: #1A4D8C;--green: #2B7A4B;--blue-light: rgba(26, 77, 140, .08);--gold-accent: #f5b042;--gold-bg: #fefcf7;--border: #cfdfed;--radius: 1.8rem;--radius-sm: .9rem;--font-serif: "Songti SC", "STSong", "Noto Serif CJK SC", "SimSun", serif;--font-sans: "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif}*{margin:0;padding:0;box-sizing:border-box}html{height:100%;-webkit-text-size-adjust:100%}body{min-height:100vh;font-family:var(--font-sans);background:linear-gradient(145deg,#f4f9ff,#eef2f8);color:var(--text);-webkit-tap-highlight-color:transparent;position:relative;padding-bottom:2rem}.bg-decor{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}.bg-decor .orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.28}.bg-decor .orb-1{width:460px;height:460px;background:radial-gradient(circle,rgba(26,77,140,.14) 0%,transparent 70%);top:-180px;right:-120px}.bg-decor .orb-2{width:320px;height:320px;background:radial-gradient(circle,rgba(43,122,75,.1) 0%,transparent 70%);bottom:-140px;left:-100px}.bg-decor .orb-3{width:260px;height:260px;background:radial-gradient(circle,rgba(245,176,66,.06) 0%,transparent 70%);top:50%;left:50%}.hero{position:relative;z-index:2;text-align:center;padding:22px 20px 14px;background:transparent;overflow-x:hidden}.logo-wrap{display:flex;justify-content:center;align-items:center;margin-bottom:10px;animation:fadeUp .55s ease both}.logo{height:52px;width:auto;max-width:100%;object-fit:contain;filter:drop-shadow(0 2px 6px rgba(0,0,0,.1))}.hero-title-row{display:flex;align-items:center;justify-content:center;gap:12px;animation:fadeUp .55s .15s ease both}.hero h1{font-family:var(--font-serif);font-size:clamp(1.5rem,4vw,2.2rem);font-weight:800;background:linear-gradient(135deg,var(--blue),var(--green));background-clip:text;-webkit-background-clip:text;color:transparent;letter-spacing:.04em;line-height:1.25}.hero .badge{display:inline-block;padding:4px 14px;border-radius:99px;background:var(--blue-light);color:var(--blue);font-size:.7rem;font-weight:600;letter-spacing:.06em;white-space:nowrap}.hero-sub{position:relative;z-index:2;font-size:.78rem;color:var(--text-muted);margin-top:4px;display:flex;align-items:center;justify-content:center;gap:10px;padding-bottom:8px}.hero-sub:after{content:"";width:36px;height:2px;border-radius:99px;background:linear-gradient(90deg,transparent,var(--border),var(--blue),var(--border),transparent);position:absolute;bottom:0;left:50%;transform:translate(-50%)}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.students-grid{position:relative;z-index:1;display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;max-width:1400px;margin:0 auto;padding:1.5rem 2rem 2rem}.student-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:0 12px 28px -10px #00204014,0 2px 8px #0000000a;display:flex;flex-direction:column;transition:transform .3s ease,box-shadow .3s ease;overflow:hidden;cursor:pointer}.student-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px -12px #00204024,0 4px 14px #0000000f}.card-top{display:flex;flex-direction:row;position:relative}.card-photo{width:140px;min-width:140px;height:140px;position:relative;flex-shrink:0;background:transparent;display:flex;align-items:center;justify-content:center;overflow:hidden}.card-avatar{width:90px;height:90px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #00204026;border:2px solid white;overflow:visible;z-index:2}.card-avatar .avatar-img{width:100%;height:100%;object-fit:contain;border-radius:50%;display:none}.card-avatar .avatar-placeholder{display:flex;flex-direction:column;align-items:center;gap:4px;opacity:.45}.card-avatar .avatar-placeholder svg{width:32px;height:32px;color:var(--blue)}.card-avatar.has-photo .avatar-placeholder{display:none}.card-avatar.has-photo .avatar-img{display:block}.card-uni-badge{padding:2px 0;color:var(--blue);font-size:.9rem;font-weight:700;letter-spacing:.04em;line-height:1.3;white-space:nowrap;transition:color .3s ease;margin-bottom:8px}.student-card:hover .card-uni-badge{color:#1a4d8c}.card-info{flex:1;padding:12px 14px;display:flex;flex-direction:column;justify-content:center}.card-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.card-name{font-family:var(--font-serif);font-size:1.2rem;font-weight:800;color:var(--text);letter-spacing:.04em;line-height:1.2}.card-badge-tag{flex-shrink:0;padding:3px 10px;border-radius:99px;background:var(--blue-light);color:var(--blue);font-size:.68rem;font-weight:600;letter-spacing:.04em;border:1px solid rgba(26,77,140,.12)}.card-title{font-size:.9rem;font-weight:600;color:var(--green);letter-spacing:.03em;line-height:1.4}.card-preview-text{margin:0 16px 10px;padding:10px 14px;font-size:.9rem;color:var(--text-secondary);line-height:1.6;max-height:calc(.9rem * 1.6 * 3 + 20px);overflow:hidden;background:#fff;border-left:3px solid var(--gold-accent);border-radius:0 var(--radius-sm) var(--radius-sm) 0;box-shadow:0 1px 3px #00000008}.card-click-hint{padding:6px 16px 12px;font-size:.7rem;color:var(--text-muted);display:flex;align-items:center;gap:4px}.card-click-hint svg{width:12px;height:12px}.modal-overlay{position:fixed;inset:0;background:#1a2c3e8c;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:100;display:flex;align-items:center;justify-content:center;padding:2rem;opacity:0;visibility:hidden;transition:opacity .35s ease,visibility .35s ease}.modal-overlay.active{opacity:1;visibility:visible}.modal-container{background:var(--card-bg);border-radius:var(--radius);box-shadow:0 24px 60px -16px #00204033,0 8px 24px #0000001a;width:100%;max-width:720px;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;transform:translateY(30px) scale(.96);transition:transform .4s cubic-bezier(.23,.82,.44,1)}.modal-overlay.active .modal-container{transform:translateY(0) scale(1)}.modal-header{display:flex;align-items:center;gap:28px;padding:24px 28px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.modal-photo{width:140px;height:140px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:visible;border:3px solid white;box-shadow:0 6px 18px #00204026}.modal-photo img{width:100%;height:100%;object-fit:contain;border-radius:50%}.modal-photo .avatar-placeholder{display:flex;flex-direction:column;align-items:center;gap:4px;opacity:.45}.modal-photo .avatar-placeholder svg{width:52px;height:52px;color:var(--blue)}.modal-header-info{flex:1}.modal-header-info .modal-name{font-family:var(--font-serif);font-size:1.6rem;font-weight:800;color:var(--text);letter-spacing:.04em;line-height:1.2;margin-bottom:10px}.modal-header-info .modal-uni{font-size:.9rem;font-weight:700;color:var(--blue);letter-spacing:.03em;margin-bottom:8px}.modal-header-info .modal-title{font-size:.9rem;font-weight:600;color:var(--green);letter-spacing:.03em}.modal-close{position:absolute;top:16px;right:20px;width:36px;height:36px;border-radius:50%;background:#0000000f;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s;z-index:10}.modal-close:hover{background:#0000001f}.modal-close svg{width:18px;height:18px;color:var(--text-secondary)}.modal-body{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:0 28px 24px}.modal-body::-webkit-scrollbar{width:4px}.modal-body::-webkit-scrollbar-track{background:transparent}.modal-body::-webkit-scrollbar-thumb{background:#1a4d8c33;border-radius:99px}.modal-block{margin:16px 0 0;padding:16px 20px;background:var(--gold-bg);border-left:4px solid var(--gold-accent);border-radius:0 var(--radius-sm) var(--radius-sm) 0;box-shadow:0 1px 3px #00000008}.modal-block h3{display:flex;align-items:center;gap:6px;font-family:var(--font-serif);font-size:.95rem;font-weight:700;color:#bc6f2c;margin-bottom:10px;letter-spacing:.04em}.modal-block h3 svg{width:15px;height:15px;flex-shrink:0}.modal-block p{font-size:.95rem;color:var(--text-secondary);line-height:1.8;letter-spacing:.02em;margin-bottom:8px;text-align:justify}.modal-block p:last-child{margin-bottom:0}.modal-block ul{list-style:none;display:flex;flex-direction:column;gap:6px}.modal-block ul li{font-size:.9rem;color:var(--text-secondary);line-height:1.6;padding-left:18px;position:relative}.modal-block ul li:before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;border-radius:50%;background:var(--gold-accent)}.modal-ending{margin:16px 0 0;padding:14px 20px;background:linear-gradient(135deg,var(--gold-bg) 0%,#FDFAF3 100%);border-left:4px solid var(--gold-accent);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.modal-ending p{font-size:.9rem;color:#8b7a5a;line-height:1.8;letter-spacing:.03em}.page-footer{position:relative;z-index:2;text-align:center;padding:1.5rem 1rem;font-size:.75rem;color:var(--text-muted);border-top:1px solid var(--border);margin-top:1rem}@media(max-width:1200px){.students-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem;padding:1rem 1.5rem 1.5rem;max-width:1100px}}@media(max-width:768px){.students-grid{grid-template-columns:1fr;gap:1.25rem;padding:1rem 1.5rem 1.5rem;max-width:700px}.modal-overlay{padding:1rem}.modal-container{max-height:90vh;border-radius:1.2rem}.modal-header{padding:18px 20px 12px;gap:14px}.modal-photo{width:90px;height:90px}.modal-header-info .modal-name{font-size:1.3rem}.modal-body{padding:0 20px 18px}.modal-block{padding:12px 16px;margin-top:12px}.modal-block h3,.modal-block p{font-size:.88rem}.modal-block ul li{font-size:.84rem}}@media(max-width:768px){.hero{padding:20px 18px 14px}.logo{height:48px;max-width:100%}.hero-title-row{gap:10px}.hero h1{font-size:1.35rem;overflow-wrap:break-word}.hero .badge{font-size:.65rem;padding:4px 12px}.hero-sub{font-size:.7rem}.students-grid{gap:1rem;padding:.75rem 1rem 1rem}.card-photo{width:120px;min-width:120px;height:120px}.card-avatar{width:65px;height:65px}.card-avatar .avatar-placeholder svg{width:26px;height:26px}.card-info{padding:10px 12px}.card-name{font-size:1.1rem}.card-title{font-size:.82rem}.card-preview-text{margin:0 14px 8px;padding:8px 12px;font-size:.82rem}.card-uni-badge{font-size:.82rem;padding:2px 0;margin-bottom:6px}}@media(max-width:480px){.hero{padding:18px 16px 20px;text-align:center;border-bottom:1px solid rgba(207,223,237,.5)}.logo-wrap{margin-bottom:8px}.logo{height:44px;max-width:100%;filter:drop-shadow(0 2px 8px rgba(26,77,140,.18))}.hero-title-row{flex-direction:column;align-items:center;gap:4px;animation-delay:.1s}.hero h1{font-size:clamp(1.15rem,5.5vw,1.5rem);letter-spacing:.06em;line-height:1.2}.hero .badge{font-size:.6rem;padding:3px 10px;letter-spacing:.08em;background:linear-gradient(135deg,var(--blue-light),rgba(43,122,75,.08));border:1px solid rgba(26,77,140,.1)}.hero-sub{font-size:.65rem;gap:6px;margin-top:6px}.students-grid{gap:.875rem;padding:.5rem .75rem .75rem}.card-photo{width:110px;min-width:110px;height:120px}.card-avatar{width:75px;height:75px}.card-avatar .avatar-placeholder svg{width:30px;height:30px}.card-info{padding:6px 10px}.card-name{font-size:.95rem}.card-title{font-size:.75rem}.card-uni-badge{font-size:.75rem;padding:2px 0;margin-bottom:5px}.card-preview-text{margin:0 12px 8px;padding:8px 10px;font-size:.75rem}.modal-overlay{padding:.5rem}.modal-header{flex-direction:column;align-items:center;text-align:center;padding:16px 16px 12px}.modal-photo{width:100px;height:100px}.modal-header-info{padding-top:0}.modal-body{padding:0 16px 16px}}@media(hover:none){.student-card:hover{transform:none}}@media(prefers-reduced-motion:reduce){.student-card,.modal-overlay,.modal-container{transition:none}}
