:root{--bg: #f5f8ff;--card: rgba(255, 255, 255, .92);--line: rgba(78, 110, 199, .22);--text: #1c2746;--muted: #5f6f97;--accent: #5f8cff;--accent2: #8c6bff}*{box-sizing:border-box}html,body,#app{margin:0;min-height:100%;background:var(--bg);color:var(--text);font-family:Inter,Segoe UI,system-ui,sans-serif}a{color:#2e57c7}body:before,body:after{content:"";position:fixed;inset:auto;width:38rem;height:38rem;pointer-events:none;z-index:0;filter:blur(40px)}body:before{top:-12rem;left:-10rem;background:radial-gradient(circle,rgba(126,168,255,.28),transparent 68%)}body:after{right:-10rem;bottom:-14rem;background:radial-gradient(circle,rgba(181,144,255,.24),transparent 68%)}.page{position:relative;z-index:1;display:grid;grid-template-columns:260px minmax(0,1fr);gap:1rem;max-width:1400px;margin:0 auto;padding:1.2rem}.side-nav{position:sticky;top:1rem;height:calc(100vh - 2rem);overflow:auto;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.side-title{font-weight:700;margin-bottom:.6rem;color:#3a4f85}.side-nav button{width:100%;margin:.35rem 0;padding:.58rem .65rem;border:1px solid var(--line);color:var(--text);border-radius:10px;background:#fffffff2;text-align:left;cursor:pointer}.side-nav button:hover{border-color:var(--accent);transform:translateY(-1px)}.content{display:grid;gap:1rem}.card{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:1rem 1.1rem;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 10px 24px #344f9a14}.hero{display:grid;grid-template-columns:1fr 220px;gap:1rem}.hero h1{margin:0 0 .5rem}.hero-kicker{display:inline-flex;align-items:center;gap:.45rem;margin-bottom:.8rem;padding:.28rem .72rem;border-radius:999px;border:1px solid rgba(117,153,245,.3);background:#ffffffd6;color:#264aa8;font-size:.8rem;font-weight:700;letter-spacing:.02em}.hero-kicker:before{content:"";width:.45rem;height:.45rem;border-radius:999px;background:linear-gradient(180deg,var(--accent),var(--accent2));box-shadow:0 0 0 3px #5f8cff1f}.subtitle{margin:.25rem 0;color:#41588f}.intro{color:#3f5284;line-height:1.6}.ps{color:var(--muted)}.pillar-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem;margin:1rem 0 .9rem}.pillar-card{border:1px solid rgba(169,198,255,.3);border-radius:16px;padding:.85rem .9rem;background:#ffffffe6;box-shadow:0 10px 20px #445ea414}.pillar-card h3{margin:0 0 .3rem;font-size:.98rem}.pillar-card p{margin:0;color:#516488;line-height:1.55;font-size:.92rem}.section-intro{margin:-.05rem 0 .7rem;color:#5a6c95;line-height:1.45;font-size:.92rem}.avatar{width:100%;aspect-ratio:1 / 1;object-fit:cover;border-radius:18px;border:2px solid rgba(103,132,208,.28);box-shadow:0 12px 28px #425fac33}.grid3{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.8rem}.numbers-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:.7rem}.stat-card{border:1px solid rgba(169,198,255,.3);border-radius:14px;background:#fffffff2;padding:.75rem .8rem}.stat-value{font-size:1.35rem;font-weight:800;color:#264aa8;line-height:1.1}.stat-label{margin-top:.25rem;color:#506493;font-size:.88rem}.project-card,.entry{border:1px solid rgba(169,198,255,.3);border-radius:14px;padding:.85rem;margin:.65rem 0;background:#ffffffeb}.cover-band{height:58px;border-radius:12px;border:1px solid rgba(125,156,235,.35);margin-bottom:.65rem;display:flex;align-items:end;padding:.45rem .55rem}.cover-band span{font-size:.76rem;color:#2b3f74;background:#ffffffb8;border:1px solid rgba(108,142,227,.35);border-radius:999px;padding:.08rem .45rem}.tone-1{background:linear-gradient(120deg,#ebf2ff,#dbe8ff)}.tone-2{background:linear-gradient(120deg,#f1ecff,#e1d8ff)}.tone-3{background:linear-gradient(120deg,#e8faff,#d6f0ff)}.tone-4{background:linear-gradient(120deg,#fff1e5,#ffe6d0)}.clickable{cursor:pointer;transition:transform .18s ease,box-shadow .2s ease,border-color .2s ease}.clickable:hover{transform:translateY(-2px);border-color:#5f8cff8c;box-shadow:0 12px 24px #445ea424}.project-card h3,.entry h3{margin-top:0}.role{font-size:.8rem;border:1px solid var(--line);border-radius:999px;padding:.1rem .45rem;color:#405684}.badge{display:inline-block;font-size:.78rem;border-radius:8px;padding:.12rem .42rem;margin-bottom:.5rem;background:linear-gradient(90deg,#7ea8ff33,#b590ff33);border:1px solid var(--line)}.muted{color:var(--muted)}.links{display:flex;gap:.6rem;flex-wrap:wrap}.os-group{margin-top:.85rem}.os-group-title{margin:.3rem 0 .1rem;color:#3b4f82;font-size:1rem}.timeline{list-style:none;margin:0;padding:0}.timeline li{position:relative;margin:.52rem 0;padding:.1rem 0 .7rem 1rem;border-left:2px solid rgba(126,168,255,.32)}.timeline li:before{content:"";position:absolute;left:-.4rem;top:.33rem;width:.62rem;height:.62rem;border-radius:999px;background:linear-gradient(180deg,var(--accent),var(--accent2))}.isolated{scroll-margin-top:12px}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1b274a47;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:15}.drawer{position:fixed;top:0;right:0;width:min(560px,92vw);height:100vh;background:#fff;border-left:1px solid rgba(75,109,202,.25);box-shadow:-16px 0 40px #263b752e;z-index:20;display:flex;flex-direction:column}.drawer-header{display:flex;justify-content:space-between;gap:.6rem;align-items:flex-start;padding:1rem 1rem .7rem;border-bottom:1px solid rgba(75,109,202,.18)}.drawer-header h2{margin:.3rem 0 0;font-size:1.18rem}.drawer-close{border:1px solid rgba(75,109,202,.28);border-radius:10px;background:#fff;color:#2b3d6f;padding:.28rem .56rem;cursor:pointer}.drawer-body{padding:1rem;overflow:auto}.drawer-body p{line-height:1.6;color:#304572}.drawer-body .links{margin-top:.75rem}.drawer-body .links a{border:1px solid rgba(95,140,255,.35);border-radius:999px;padding:.2rem .58rem;text-decoration:none;background:#f5f9ffe6}.drawer-fade-enter-active,.drawer-fade-leave-active{transition:opacity .26s ease}.drawer-fade-enter-from,.drawer-fade-leave-to{opacity:0}.drawer-slide-enter-active,.drawer-slide-leave-active{transition:transform .34s cubic-bezier(.22,1,.36,1),opacity .28s ease}.drawer-slide-enter-from,.drawer-slide-leave-to{transform:translate(100%);opacity:.85}@media(max-width:1100px){.page{grid-template-columns:1fr}.side-nav{position:relative;height:auto}}@media(max-width:760px){.hero{grid-template-columns:1fr}.hero-right{max-width:220px}}
