@import"https://fonts.googleapis.com/css2?family=EB+Garamond:ital,wght@0,400;0,500;1,400&family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap";:root{--ink: #14171a;--ink-soft: #3d4651;--ink-muted: #5d6975;--ink-faint: #a8adb3;--paper: #fdfdfb;--paper-2: #f5f4f1;--paper-3: #ecebe6;--accent: #EA426A;--accent-dim: #f06b8a;--accent-bg: rgba(234, 66, 106, .08);--accent-2: #5B6770;--accent-2-bg: rgba(91, 103, 112, .08);--accent-hot: #EA426A;--accent-hot-dim: #f06b8a;--accent-hot-bg: rgba(234, 66, 106, .08);--gradient-brand: linear-gradient(135deg, #5B6770 0%, #C077DB 100%);--gradient-title: linear-gradient(90deg, #5B6770 0%, #C077DB 100%);--border: #d6dadd;--border-soft:#e4e7ea;--font-sans: "Pretendard", -apple-system, BlinkMacSystemFont, "Apple SD Gothic Neo", "Segoe UI", Roboto, Arial, sans-serif;--font-serif: "Pretendard", -apple-system, BlinkMacSystemFont, "Apple SD Gothic Neo", "Helvetica Neue", sans-serif;--font-mono: ui-monospace, SFMono-Regular, "JetBrains Mono", "Fira Code", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-md: 1.125rem;--text-lg: 1.3rem;--text-xl: 1.6rem;--text-2xl: 2rem;--text-3xl: 2.6rem;--text-4xl: 3.5rem;--weight-normal: 400;--weight-medium: 500;--weight-semibold: 600;--leading-tight: 1.25;--leading-normal: 1.6;--leading-relaxed: 1.8;--sp-1: .25rem;--sp-2: .5rem;--sp-3: .75rem;--sp-4: 1rem;--sp-5: 1.25rem;--sp-6: 1.5rem;--sp-8: 2rem;--sp-10: 2.5rem;--sp-12: 3rem;--sp-16: 4rem;--sp-20: 5rem;--sp-24: 6rem;--r-sm: 4px;--r-md: 8px;--r-lg: 12px;--shadow-sm: 0 1px 2px rgba(20, 23, 26, .04), 0 1px 3px rgba(20, 23, 26, .06);--shadow-md: 0 2px 4px rgba(20, 23, 26, .04), 0 4px 12px rgba(20, 23, 26, .08);--shadow-lg: 0 4px 8px rgba(20, 23, 26, .04), 0 12px 24px rgba(20, 23, 26, .1);--ease: .24s cubic-bezier(.4, 0, .2, 1);--nav-h: 4rem;--max-w: 47.5rem;--max-w-wide: 62.5rem;--color-purple: var(--accent);--color-purple-dark: #e63d65;--bg-primary: var(--paper);--bg-secondary: var(--paper-2);--bg-tertiary: var(--paper-3);--bg-card: #ffffff;--text-primary: var(--ink);--text-secondary: var(--ink-soft);--text-tertiary: var(--ink-muted);--text-inverse: #ffffff;--border-color: var(--border);--font-primary: var(--font-sans);--font-display: var(--font-serif);--font-mono: var(--font-mono);--spacing-sm: var(--sp-2);--spacing-md: var(--sp-4);--spacing-lg: var(--sp-6);--spacing-xl: var(--sp-8);--spacing-2xl: var(--sp-12);--spacing-3xl: var(--sp-16);--spacing-4xl: var(--sp-24);--radius-sm: var(--r-sm);--radius-md: var(--r-md);--radius-lg: var(--r-lg);--shadow-card: var(--shadow-md);--shadow-card-hover: var(--shadow-lg);--transition-base: var(--ease);--transition-fast: .16s cubic-bezier(.4, 0, .2, 1);--gradient-purple: linear-gradient(135deg, var(--accent) 0%, #e63d65 100%);--header-height: var(--nav-h)}@media(prefers-color-scheme:dark){:root{--ink: #f0ede8;--ink-soft: #c8c4bc;--ink-muted: #8a8680;--ink-faint: #4a4844;--paper: #141412;--paper-2: #1e1d1a;--paper-3: #272520;--accent: #FF6B8F;--accent-dim: #ff8faa;--accent-bg: rgba(255, 107, 143, .1);--accent-2: #9aa5ad;--accent-2-bg: rgba(154, 165, 173, .1);--accent-hot: #FF6B8F;--accent-hot-dim: #ff8faa;--accent-hot-bg: rgba(255, 107, 143, .1);--gradient-brand: linear-gradient(135deg, #9aa5ad 0%, #e0a4f7 100%);--gradient-title: linear-gradient(90deg, #9aa5ad 0%, #e0a4f7 100%);--border: #2e2c28;--border-soft:#252320;--bg-primary: var(--paper);--bg-secondary: var(--paper-2);--bg-tertiary: var(--paper-3);--bg-card: var(--paper-2);--text-primary: var(--ink);--text-secondary: var(--ink-soft);--text-tertiary: var(--ink-muted);--border-color: var(--border);--shadow-card: 0 4px 12px rgba(0,0,0,.3);--shadow-card-hover: 0 8px 24px rgba(0,0,0,.4)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-up{animation:fadeUp .5s var(--ease) both}.fade-in{animation:fadeIn .4s var(--ease) both}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.container{max-width:var(--max-w);margin:0 auto;padding:0 var(--sp-6)}.container--wide{max-width:var(--max-w-wide);margin:0 auto;padding:0 var(--sp-6)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px;overflow-x:hidden}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--ink);background-color:var(--paper);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;letter-spacing:-.005em;overflow-x:hidden}#root{min-height:100vh;display:flex;flex-direction:column}a{color:var(--accent);text-decoration:none;transition:color var(--ease)}a:hover{color:var(--accent-dim)}h1,h2,h3,h4{font-family:var(--font-serif);font-weight:var(--weight-normal);line-height:var(--leading-tight);color:var(--ink)}p{color:var(--ink-soft);line-height:var(--leading-relaxed)}button{font-family:var(--font-sans);cursor:pointer}img{max-width:100%;display:block}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:var(--r-sm)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--paper-2)}::-webkit-scrollbar-thumb{background:var(--ink-faint);border-radius:3px}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--spacing-xl);background:var(--bg-color)}.error-boundary-content{text-align:center;max-width:600px}.error-boundary-title{font-size:2.5rem;margin-bottom:var(--spacing-lg);color:var(--danger-color)}.error-boundary-message{font-size:1.125rem;color:var(--text-secondary);margin-bottom:var(--spacing-xl);line-height:1.6}.error-boundary-details{text-align:left;margin:var(--spacing-lg) 0;padding:var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md)}.error-boundary-details summary{cursor:pointer;font-weight:600;margin-bottom:var(--spacing-sm);color:var(--text-color)}.error-boundary-details pre{margin:var(--spacing-sm) 0;padding:var(--spacing-sm);background:var(--bg-color);border-radius:var(--radius-sm);overflow-x:auto;font-size:.875rem;color:var(--text-secondary)}.error-boundary-button{padding:.75rem 2rem;background:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:500;cursor:pointer;transition:all var(--transition-base)}.error-boundary-button:hover{background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 4px 12px #007bff4d}@media(max-width:768px){.error-boundary-title{font-size:2rem}.error-boundary-message{font-size:1rem}}.nav{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-h);background:transparent;transition:background var(--ease),border-color var(--ease),box-shadow var(--ease);border-bottom:1px solid transparent}.nav--scrolled{background:#fafaf8eb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom-color:var(--border-soft);box-shadow:0 1px 0 var(--border-soft)}@media(prefers-color-scheme:dark){.nav--scrolled{background:#141412eb}}.nav__inner{max-width:var(--max-w-wide);margin:0 auto;padding:0 var(--sp-6);height:100%;display:flex;align-items:center;justify-content:space-between}.nav__logo{font-family:var(--font-serif);font-size:var(--text-lg);font-weight:var(--weight-normal);background:var(--gradient-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:.01em;text-decoration:none;transition:opacity var(--ease)}.nav__logo:hover{opacity:.75}.nav__links{display:flex;align-items:center;gap:var(--sp-8)}.nav__link{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--ink-muted);text-decoration:none;letter-spacing:.02em;transition:color var(--ease);position:relative;padding-bottom:2px}.nav__link:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:1px;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform var(--ease)}.nav__link:hover:after,.nav__link--active:after{transform:scaleX(1)}.nav__link[href="/"]:hover,.nav__link[href="/"].nav__link--active{background:linear-gradient(90deg,#5b6770,#c077db);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav__link[href="/"]:hover:after,.nav__link[href="/"].nav__link--active:after{background:linear-gradient(90deg,#5b6770,#c077db)}.nav__link[href="/research"]:hover,.nav__link[href="/research"].nav__link--active{color:#9b74b0}.nav__link[href="/foundations"]:hover,.nav__link[href="/foundations"].nav__link--active{color:#5b6770}.nav__link[href="/works"]:hover,.nav__link[href="/works"].nav__link--active{color:#c077db}.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:var(--sp-2);cursor:pointer}.nav__burger span{display:block;width:22px;height:1.5px;background:var(--ink);transition:transform var(--ease),opacity var(--ease);transform-origin:center}.nav__burger--open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}.nav__burger--open span:nth-child(2){opacity:0}.nav__burger--open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}.nav__mobile{display:none;flex-direction:column;padding:var(--sp-4) var(--sp-6) var(--sp-6);background:var(--paper);border-top:1px solid var(--border-soft);gap:var(--sp-1)}.nav__mobile-link{font-size:var(--text-base);color:var(--ink-soft);padding:var(--sp-3) 0;border-bottom:1px solid var(--border-soft);text-decoration:none;transition:color var(--ease)}.nav__mobile-link:last-child{border-bottom:none}.nav__mobile-link[href="/"]:hover,.nav__mobile-link[href="/"].nav__mobile-link--active{background:linear-gradient(90deg,#5b6770,#c077db);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav__mobile-link[href="/research"]:hover,.nav__mobile-link[href="/research"].nav__mobile-link--active{color:#9b74b0}.nav__mobile-link[href="/foundations"]:hover,.nav__mobile-link[href="/foundations"].nav__mobile-link--active{color:#5b6770}.nav__mobile-link[href="/works"]:hover,.nav__mobile-link[href="/works"].nav__mobile-link--active{color:#c077db}@media(max-width:640px){.nav__links{display:none}.nav__burger,.nav__mobile{display:flex}}.footer{margin-top:auto;border-top:1px solid var(--border-soft);padding:var(--sp-12) 0}.footer__inner{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--sp-4)}.footer__name{font-family:var(--font-serif);font-size:var(--text-base);background:var(--gradient-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.footer__tagline{font-size:var(--text-sm);color:var(--ink-faint);margin:0}.footer__contact{display:flex;align-items:center;gap:var(--sp-3);flex-wrap:wrap;font-size:var(--text-sm)}.footer__link{color:var(--ink-soft);text-decoration:none;transition:color var(--ease)}.footer__link:hover{color:#ea426a}.footer__sep{color:var(--ink-faint)}@media(max-width:480px){.footer__inner{align-items:center}}.intro{padding-bottom:0;min-height:calc(100vh - var(--nav-h));display:flex;flex-direction:column}.intro__hero{padding-top:var(--sp-24);padding-bottom:var(--sp-10);text-align:center}.intro__eyebrow{font-size:var(--text-xs);font-weight:var(--weight-medium);letter-spacing:.12em;text-transform:uppercase;color:var(--accent-hot);margin-bottom:var(--sp-4)}.intro__title{font-family:var(--font-serif);font-size:clamp(2.8rem,6vw,var(--text-4xl));font-weight:var(--weight-normal);background:var(--gradient-title);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--sp-5);letter-spacing:-.01em}.intro__tagline{font-size:var(--text-md);color:var(--ink);max-width:36rem;margin:0 auto;line-height:var(--leading-relaxed)}.highlight--gray{color:#5b6770;font-weight:600}.highlight--purple{color:#c077db;font-weight:600}.highlight--gradient{background:linear-gradient(90deg,#5b6770,#c077db);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:600}.intro__bio{flex:1;display:flex;flex-direction:column;justify-content:center;max-width:52rem;margin-left:auto;margin-right:auto;margin-top:-45px}.intro__bio-content{display:flex;align-items:center;gap:var(--sp-10)}.intro__photo{width:216px;height:192px;border-radius:var(--r-lg);object-fit:cover;object-position:center top;flex-shrink:0;filter:saturate(.85) contrast(.95);box-shadow:0 1px 2px #14171a0a,0 8px 24px #14171a14;transition:filter var(--ease),transform var(--ease)}.intro__photo:hover{filter:saturate(1) contrast(1);transform:translateY(-2px)}.intro__bio-text{flex:1}@media(max-width:640px){.intro__bio-content{flex-direction:column;align-items:center;gap:var(--sp-6);text-align:center}.intro__photo{width:140px;height:130px}.intro__bio-line{text-align:center}}.intro__bio-line{font-family:var(--font-sans);font-size:1.3rem;color:var(--ink);line-height:var(--leading-relaxed);margin-bottom:var(--sp-2);text-align:left}.intro__bio-line:last-child{margin-bottom:0}.intro__info{margin-top:auto;max-width:52rem;margin-left:auto;margin-right:auto;text-align:center;padding-bottom:var(--sp-6)}.info-card{background:transparent;border:none;border-radius:0;padding:0;max-width:52rem;margin:0 auto;text-align:center}.info-card__affiliation{font-size:var(--text-base);color:var(--ink);margin-bottom:var(--sp-2)}.info-card__email{font-size:var(--text-sm);color:var(--ink);margin-bottom:var(--sp-3)}.info-card__links{display:flex;gap:var(--sp-4);flex-wrap:wrap;justify-content:center}.info-card__link{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--ink);text-decoration:none;border-bottom:1px solid var(--ink-muted);padding-bottom:1px;transition:border-color var(--ease),color var(--ease)}.info-card__link:hover{border-color:#ea426a;color:#ea426a}@media(max-width:768px){.intro__hero{padding-top:var(--sp-16);padding-bottom:var(--sp-10)}.intro__title{font-size:clamp(2rem,8vw,2.8rem)}.intro__tagline{font-size:var(--text-base);margin-bottom:var(--sp-6)}.intro__bio,.intro__info{margin-top:var(--sp-6)}.info-card{padding:var(--sp-4)}}.status-badge{display:inline-block;padding:var(--sp-1) var(--sp-3);background:#5b67701a;color:#5b6770;font-family:var(--font-mono);font-size:var(--text-xs);font-weight:var(--weight-semibold);border-radius:var(--r-sm);border:1px solid rgba(91,103,112,.2);white-space:nowrap;line-height:var(--leading-normal)}.status-badge--in-progress{background:#ea426a1a;color:#ea426a;border-color:#ea426a40}.tag-list{display:flex;flex-wrap:wrap;gap:var(--sp-2)}.tag-list__tag{display:inline-block;padding:var(--sp-1) var(--sp-3);background:#5b67701a;color:#5b6770;font-family:var(--font-sans);font-size:var(--text-xs);font-weight:var(--weight-semibold);border-radius:var(--r-sm);border:1px solid rgba(91,103,112,.2);white-space:nowrap;line-height:var(--leading-normal)}.tag-list__tag--music{background:#c077db1a;color:#c077db;border-color:#c077db40}.placeholder{display:inline-flex;align-items:center;gap:var(--sp-1);color:var(--ink-muted);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:var(--weight-medium);border:1px dashed var(--ink-muted);border-radius:var(--r-sm);padding:var(--sp-1) var(--sp-3);background:#717e870f;cursor:default;-webkit-user-select:none;user-select:none;white-space:nowrap}.placeholder__icon{font-size:var(--text-xs);opacity:.8}.placeholder__label{color:var(--ink-soft)}.research-card{background:var(--paper-2);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--sp-6);display:flex;flex-direction:column;gap:var(--sp-4);transition:border-color var(--ease),box-shadow var(--ease)}.research-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--sp-4);flex-wrap:wrap}.research-card__title{font-family:var(--font-serif);font-size:var(--text-lg);font-weight:var(--weight-semibold);color:var(--ink);line-height:var(--leading-tight);margin:0}.research-card__meta{display:flex;align-items:center;gap:var(--sp-3);flex-wrap:wrap}.research-card__venue{font-family:var(--font-sans);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--ink-soft)}.research-card__type{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--ink-muted)}.research-card__venue-type{font-family:var(--font-sans);font-size:var(--text-sm);font-weight:var(--weight-medium);color:#5b6770}.research-card__description{font-family:var(--font-sans);font-size:var(--text-base);color:var(--ink-soft);line-height:var(--leading-relaxed);margin:0}.research-card__fields{display:flex;flex-direction:column;gap:var(--sp-4)}.research-card__field{display:flex;flex-direction:column;gap:var(--sp-1)}.research-card__field-label{font-family:var(--font-sans);font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--ink-muted);text-transform:uppercase;letter-spacing:.06em}.research-card__field-value{font-family:var(--font-sans);font-size:var(--text-base);color:var(--ink);line-height:var(--leading-relaxed)}.research-card__field-value--title{font-size:var(--text-lg);font-weight:var(--weight-semibold);line-height:var(--leading-tight)}.research-card__field-value--authors{color:var(--ink-soft);font-size:var(--text-sm)}.research-card__field-value--abstract{color:var(--ink-soft);font-size:var(--text-sm);line-height:var(--leading-relaxed)}.research-card__field a{color:#9b74b0;font-weight:var(--weight-medium);text-decoration:none;border-bottom:1px solid rgba(155,116,176,.3);transition:color var(--ease),border-color var(--ease)}.research-card__field a:hover{color:#9b74b0;border-color:#9b74b0}.research-card__footer{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--sp-4);margin-top:auto}.research-card__pdf-link{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--ink);text-decoration:none;border-bottom:1px solid var(--ink-muted);padding-bottom:1px;white-space:nowrap;transition:color var(--ease),border-color var(--ease)}.research-card__pdf-link:hover{color:#9b74b0;border-color:#9b74b0}.research-card__author-me{color:#5b6770;font-weight:var(--weight-semibold)}.page-eyebrow{font-size:var(--text-xs);font-weight:var(--weight-medium);letter-spacing:.12em;text-transform:uppercase;color:var(--accent-hot);margin-bottom:var(--sp-3)}.page-title{font-family:var(--font-serif);font-size:clamp(2rem,4vw,var(--text-3xl));font-weight:var(--weight-normal);color:var(--ink);margin-bottom:var(--sp-4)}.page-desc{font-size:var(--text-base);color:var(--ink-soft);max-width:33.75rem;line-height:var(--leading-relaxed)}.research{background:var(--paper);min-height:calc(100vh - var(--nav-h));display:flex;flex-direction:column}.research__header{padding-top:var(--sp-24);padding-bottom:var(--sp-10);text-align:center}.research__title{font-family:var(--font-serif);font-size:clamp(2.8rem,6vw,var(--text-4xl));font-weight:var(--weight-normal);color:#9b74b0;margin-bottom:var(--sp-5);letter-spacing:-.01em}.research__desc{font-size:var(--text-md);color:var(--ink);max-width:36rem;margin:0 auto;line-height:var(--leading-relaxed)}.research__desc strong{font-weight:var(--weight-semibold)}.research__desc-purple{color:#c077db}.research__desc-gray{color:#5b6770}.research__body{padding-top:var(--sp-20);padding-bottom:var(--sp-24)}.research__subsection-heading{font-family:var(--font-serif);font-size:var(--text-xl);font-weight:var(--weight-normal);color:var(--ink);margin-top:var(--sp-12);margin-bottom:var(--sp-6);padding-bottom:var(--sp-3);border-bottom:1px solid var(--border-soft)}.research__subsection-heading:first-child{margin-top:0}.research__empty{color:var(--ink-muted);font-size:var(--text-base);padding:var(--sp-8) 0}.research__tag-filter{display:flex;flex-wrap:wrap;gap:var(--sp-2);margin-top:var(--sp-8);margin-bottom:var(--sp-10)}.research__filter-btn{padding:var(--sp-1) var(--sp-3);font-family:var(--font-sans);font-size:var(--text-xs);font-weight:var(--weight-medium);color:#5b6770;background:#5b677014;border:1px solid rgba(91,103,112,.2);border-radius:var(--r-sm);cursor:pointer;transition:all var(--ease)}.research__filter-btn:hover{background:#9b74b01a;color:#9b74b0;border-color:#9b74b04d}.research__filter-btn--active{background:#9b74b026;color:#9b74b0;border-color:#9b74b0}.research__filter-btn--music{color:#c077db;background:#c077db14;border-color:#c077db33}.research__filter-btn--music:hover{background:#c077db26;color:#c077db;border-color:#c077db66}.research__filter-btn--music.research__filter-btn--active{background:#c077db33;color:#c077db;border-color:#c077db}.research__list{display:flex;flex-direction:column;gap:var(--sp-8)}.research__list--grid{display:grid;grid-template-columns:1fr;gap:var(--sp-8)}@media(min-width:768px){.research__list--grid{grid-template-columns:repeat(2,1fr)}}.research-card{padding:var(--sp-8);background:var(--paper);border:1px solid var(--border);border-radius:var(--r-lg);transition:box-shadow var(--ease),border-color var(--ease)}.research-card:hover{border-color:#9b74b0;box-shadow:0 4px 12px #9b74b01f}.research-card__meta{display:flex;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-3);flex-wrap:wrap}.research-card__type{font-size:var(--text-xs);font-weight:var(--weight-semibold);letter-spacing:.08em;text-transform:uppercase;color:var(--accent-hot)}.research-card__year{font-size:var(--text-xs);color:var(--ink-muted);font-family:var(--font-mono)}.research-card__status{font-size:var(--text-xs);color:var(--ink-muted);background:var(--paper-3);padding:2px var(--sp-2);border-radius:var(--r-sm);border:1px solid var(--border)}.research-card__title{font-family:var(--font-serif);font-size:var(--text-xl);font-weight:var(--weight-normal);color:var(--ink);margin-bottom:var(--sp-3);line-height:var(--leading-tight)}.research-card__title a{color:var(--ink);text-decoration:none;transition:color var(--ease)}.research-card__title a:hover{color:var(--accent-hot)}.research-card__desc{font-size:var(--text-base);color:var(--ink-soft);line-height:var(--leading-relaxed);max-width:38.75rem;margin-bottom:var(--sp-4)}.research-card__tags{display:flex;flex-wrap:wrap;gap:var(--sp-2)}.tag{font-size:var(--text-xs);font-family:var(--font-mono);color:var(--accent);background:#ff4f791a;border:1px solid rgba(255,79,121,.2);padding:var(--sp-1) var(--sp-3);border-radius:var(--r-sm);font-weight:var(--weight-medium);letter-spacing:.01em}.foundations{background:var(--paper);min-height:calc(100vh - var(--nav-h))}.foundations__header{padding-top:var(--sp-24);padding-bottom:var(--sp-10);text-align:center}.foundations__title{font-family:var(--font-serif);font-size:clamp(2.8rem,6vw,var(--text-4xl));font-weight:var(--weight-normal);color:#5b6770;margin-bottom:var(--sp-5);letter-spacing:-.01em}.foundations__desc{font-size:var(--text-md);color:var(--ink);max-width:36rem;margin:0 auto;line-height:var(--leading-relaxed)}.foundations__desc strong{font-weight:var(--weight-semibold)}.foundations__desc-purple{color:#c077db}.foundations__desc-gray{color:#5b6770}.foundations__body{padding-top:var(--sp-8);padding-bottom:var(--sp-24);max-width:52rem;margin:0 auto}.foundations__section-heading{font-family:var(--font-serif);font-size:var(--text-xl);font-weight:var(--weight-normal);margin-top:var(--sp-12);margin-bottom:var(--sp-6);padding-bottom:var(--sp-3);border-bottom:1px solid var(--border-soft)}.foundations__section-heading:first-child{margin-top:0}.foundations__section-heading--major{color:#5b6770}.foundations__section-heading--mfk,.foundations__section-heading--elective{color:#c077db}.foundations__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(14rem,1fr));gap:var(--sp-4)}.foundations__semester-group{margin-bottom:var(--sp-6)}.foundations__semester-label{display:inline-block;font-family:var(--font-mono);font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--ink-muted);margin-bottom:var(--sp-3);letter-spacing:.04em}.course-card{background:var(--paper-2);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--sp-4) var(--sp-5);transition:border-color var(--ease),box-shadow var(--ease)}.course-card:hover{border-color:#5b6770;box-shadow:0 2px 8px #5b67701a}.course-card__header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--sp-2);margin-bottom:var(--sp-2)}.course-card__name{font-family:var(--font-sans);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--ink);line-height:var(--leading-tight)}.course-card__grade{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:var(--weight-semibold);color:#5b6770;white-space:nowrap}.course-card__badge{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:var(--weight-semibold);color:#ea426a;background:#ea426a14;border:1px solid rgba(234,66,106,.2);border-radius:var(--r-sm);padding:1px var(--sp-2);white-space:nowrap}.course-card--in-progress{border-color:#ea426a33}.course-card__meta{display:flex;gap:var(--sp-3);align-items:center}.course-card__semester{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--ink-muted)}.course-card__desc{font-size:var(--text-xs);color:var(--ink-soft)}.course-card__credits{font-size:var(--text-xs);color:var(--ink-muted)}.course-card--mfk{border-color:#c077db40}.course-card--mfk:hover{border-color:#c077db;box-shadow:0 2px 8px #c077db1f}@media(max-width:768px){.foundations__grid{grid-template-columns:1fr}}.works{background:var(--paper);min-height:calc(100vh - var(--nav-h))}.works__header{padding-top:var(--sp-24);padding-bottom:var(--sp-10);text-align:center}.works__title{font-family:var(--font-serif);font-size:clamp(2.8rem,6vw,var(--text-4xl));font-weight:var(--weight-normal);color:#c077db;margin-bottom:var(--sp-5);letter-spacing:-.01em}.works__desc{font-size:var(--text-md);color:var(--ink);max-width:36rem;margin:0 auto;line-height:var(--leading-relaxed)}.works__desc strong{color:#c077db;font-weight:var(--weight-semibold)}.works__body{padding-top:var(--sp-8);padding-bottom:var(--sp-24);max-width:52rem;margin:0 auto}.works__mosaic{display:grid;grid-template-columns:repeat(6,1fr);grid-template-rows:repeat(6,minmax(5.5rem,auto));gap:var(--sp-2);max-width:52rem;margin:0 auto}.works__piece--0{grid-column:1 / 3;grid-row:1 / 3}.works__piece--1{grid-column:1 / 2;grid-row:4 / 5}.works__piece--2{grid-column:4 / 5;grid-row:2 / 3}.works__piece--3{grid-column:5 / 7;grid-row:1 / 3}.works__piece--4{grid-column:3 / 5;grid-row:1 / 2}.works__piece--5{grid-column:3 / 4;grid-row:2 / 3}.works__piece--6{grid-column:1 / 3;grid-row:5 / 7}.works__piece--7{grid-column:1 / 3;grid-row:3 / 4}.works__piece--8{grid-column:2 / 3;grid-row:4 / 5}.works__piece--9{grid-column:5 / 7;grid-row:5 / 7}.works__piece--10{grid-column:5 / 7;grid-row:3 / 4}.works__piece--11{grid-column:5 / 7;grid-row:4 / 5}.works__piece--12{grid-column:3 / 5;grid-row:3 / 5}.works__piece--13{grid-column:3 / 5;grid-row:6 / 7}.works__piece--14{grid-column:3 / 5;grid-row:5 / 6}.works__piece{background:var(--paper);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--sp-2) var(--sp-3);display:flex;flex-direction:column;gap:2px;min-width:0;min-height:0;transition:border-color var(--ease),box-shadow var(--ease),transform var(--ease)}.works__piece:hover{border-color:#c077db;box-shadow:0 6px 20px #c077db1f;transform:translateY(-2px)}.works__piece-top{display:flex;justify-content:space-between;align-items:center;gap:var(--sp-1)}.works__piece-category{font-family:var(--font-mono);font-size:.55rem;font-weight:var(--weight-semibold);color:#c077db;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.works__piece-year{font-family:var(--font-mono);font-size:.55rem;color:var(--ink-muted);white-space:nowrap}.works__piece-title{font-family:var(--font-sans);font-size:.8rem;font-weight:var(--weight-semibold);color:var(--ink);margin:0;line-height:1.2}.works__piece-desc{font-size:.7rem;color:var(--ink-soft);line-height:1.35;margin:0}.works__piece-bottom{margin-top:auto;display:flex;justify-content:space-between;align-items:flex-end;gap:var(--sp-1);padding-top:var(--sp-1)}.works__piece-tags{display:flex;flex-wrap:nowrap;gap:2px;align-items:center;flex:1;min-width:0;overflow:hidden}.works__piece-footer{display:flex;flex-wrap:wrap;gap:var(--sp-2);justify-content:flex-end;align-items:center;flex-shrink:0}.works__piece-tag{font-size:.6rem;font-weight:var(--weight-medium);color:#c077db;background:#c077db14;border:1px solid rgba(192,119,219,.2);border-radius:var(--r-sm);padding:1px var(--sp-1)}.works__piece-pdf{font-family:var(--font-mono);font-size:.6rem;font-weight:var(--weight-medium);color:var(--ink);text-decoration:none;border-bottom:1px solid var(--ink-muted);padding-bottom:1px;white-space:nowrap;transition:color var(--ease),border-color var(--ease)}.works__piece-pdf:hover{color:#ea426a;border-color:#ea426a}@media(max-width:768px){.works__mosaic{display:flex;flex-direction:column;gap:var(--sp-4);aspect-ratio:unset}.works__piece{padding:var(--sp-4)}.works__header{padding-top:var(--sp-16)}}.notfound{padding-top:var(--sp-24);padding-bottom:var(--sp-24)}.notfound__code{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--ink-muted);margin-bottom:var(--sp-4)}.notfound__title{font-family:var(--font-serif);font-size:var(--text-3xl);font-weight:var(--weight-normal);color:var(--ink);margin-bottom:var(--sp-4)}.notfound__msg{color:var(--ink-soft);margin-bottom:var(--sp-8)}.notfound__back{font-size:var(--text-sm);color:var(--accent);text-decoration:none;transition:color var(--ease)}.notfound__back:hover{color:var(--accent-dim)}.admin-login{display:flex;align-items:center;justify-content:center;min-height:70vh;padding:var(--spacing-xl)}.admin-login-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-2xl);max-width:450px;width:100%;box-shadow:var(--shadow-lg)}.admin-login-card h1{margin:0 0 var(--spacing-sm) 0;text-align:center;color:var(--text-primary);font-family:var(--font-display);font-weight:var(--font-bold);font-size:var(--text-4xl);background:var(--gradient-mixed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.admin-login-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:var(--spacing-xl)}.admin-login-form,.form-group{margin-bottom:var(--spacing-lg)}.form-group input{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:1rem;background:var(--bg-primary);color:var(--text-primary);transition:all var(--transition-base)}.form-group input:focus{outline:none;border-color:var(--color-purple);box-shadow:0 0 0 3px #9b87f51a}.error-message{padding:var(--spacing-md);background:#ef44441a;border:1px solid #ef4444;border-radius:var(--radius-md);color:#dc2626;margin-bottom:var(--spacing-lg);text-align:center;font-weight:var(--font-medium)}.login-button{width:100%;padding:.875rem;background:var(--gradient-purple);color:var(--text-inverse);border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:var(--font-semibold);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.login-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.admin-login-note{text-align:center;font-size:.875rem;color:var(--text-tertiary);margin:0;padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-md)}@media(max-width:768px){.admin-login-card{padding:var(--spacing-xl)}}.admin-dashboard{min-height:70vh;padding:var(--spacing-lg)}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:2px solid var(--border-color)}.admin-header h1{margin:0;color:var(--text-primary);font-family:var(--font-display);font-weight:var(--font-bold);font-size:var(--text-4xl);background:var(--gradient-mixed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.logout-button{padding:.5rem 1.5rem;background:linear-gradient(135deg,#ef4444,#dc2626);color:var(--text-inverse);border:none;border-radius:var(--radius-md);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.logout-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.admin-content{display:grid;grid-template-columns:250px 1fr;gap:var(--spacing-xl)}.admin-sidebar{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);height:fit-content;position:sticky;top:var(--spacing-lg);box-shadow:var(--shadow-sm)}.admin-nav{display:flex;flex-direction:column;gap:var(--spacing-sm)}.admin-nav-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);text-align:left;color:var(--text-secondary);font-size:1rem;font-weight:var(--font-medium)}.admin-nav-item:hover{background:var(--bg-secondary);color:var(--text-primary);transform:translate(4px)}.admin-nav-item.active{background:var(--gradient-purple);color:var(--text-inverse);box-shadow:var(--shadow-sm)}.nav-icon{font-size:1.5rem}.nav-text{font-weight:var(--font-medium)}.admin-main{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-2xl);box-shadow:var(--shadow-sm)}.admin-section h2{margin:0 0 var(--spacing-md) 0;color:var(--text-primary);font-family:var(--font-display);font-weight:var(--font-bold)}.section-description{color:var(--text-secondary);margin-bottom:var(--spacing-xl);line-height:1.6}.edit-button{padding:.75rem 2rem;background:var(--gradient-blue);color:var(--text-inverse);border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:var(--font-semibold);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.edit-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}@media(max-width:768px){.admin-content{grid-template-columns:1fr}.admin-sidebar{position:static}.admin-nav{flex-direction:row;overflow-x:auto}.admin-nav-item{flex-direction:column;min-width:80px;text-align:center}.nav-text{font-size:.875rem}.admin-main{padding:var(--spacing-lg)}}.header-actions{display:flex;gap:var(--spacing-md);align-items:center}.reset-button{padding:.5rem 1.5rem;background:linear-gradient(135deg,#f59e0b,#d97706);color:var(--text-inverse);border:none;border-radius:var(--radius-md);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.reset-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.storage-info{margin-top:var(--spacing-xl);padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-md);border-left:3px solid var(--color-purple)}.info-text{margin:0 0 var(--spacing-xs) 0;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary)}.info-subtext{margin:0;font-size:var(--text-xs);color:var(--text-tertiary);line-height:1.4}.admin-edit{min-height:70vh;padding:var(--spacing-2xl);max-width:1400px;margin:0 auto}.admin-edit-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2xl);padding-bottom:var(--spacing-xl);border-bottom:2px solid var(--border-color)}.admin-edit-header h1{margin:0;color:var(--text-primary);font-size:var(--text-4xl);font-family:var(--font-display);font-weight:var(--font-bold);background:var(--gradient-mixed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.back-button{padding:var(--spacing-sm) var(--spacing-lg);background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);font-weight:var(--font-medium)}.back-button:hover{background:var(--border-color);transform:translateY(-2px);box-shadow:var(--shadow-md)}.create-button{padding:var(--spacing-sm) var(--spacing-xl);background:var(--gradient-purple);color:var(--text-inverse);border:none;border-radius:var(--radius-lg);font-weight:var(--font-semibold);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.create-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.admin-edit-content{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xl)}.items-list{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);max-height:80vh;overflow-y:auto}.items-list h2{margin:0 0 var(--spacing-lg) 0;color:var(--text-primary);position:sticky;top:0;background:var(--bg-card);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-color)}.item-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md);display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-md)}.item-info{flex:1}.item-info h3{margin:0 0 var(--spacing-sm) 0;font-size:1.125rem;color:var(--text-primary)}.item-info p{margin:0 0 var(--spacing-sm) 0;color:var(--text-secondary);font-size:.9375rem;line-height:1.4}.item-meta{display:flex;gap:var(--spacing-md);font-size:.875rem;color:var(--text-tertiary)}.item-actions{display:flex;gap:var(--spacing-sm)}.btn-edit,.btn-delete{padding:.375rem .75rem;border:none;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-base)}.btn-edit{background:var(--gradient-blue);color:var(--text-inverse);box-shadow:var(--shadow-sm)}.btn-edit:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-delete{background:linear-gradient(135deg,#ef4444,#dc2626);color:var(--text-inverse);box-shadow:var(--shadow-sm)}.btn-delete:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.edit-form{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-xl);max-height:80vh;overflow-y:auto}.edit-form h2{margin:0 0 var(--spacing-xl) 0;color:var(--text-primary);font-family:var(--font-display);font-weight:var(--font-bold)}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{display:block;margin-bottom:var(--spacing-sm);font-weight:var(--font-semibold);color:var(--text-primary)}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:1rem;font-family:inherit;background:var(--bg-primary);color:var(--text-primary);transition:all var(--transition-base)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-purple);box-shadow:0 0 0 3px #9b87f51a}.form-group textarea{resize:vertical;min-height:80px}.form-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-xl)}.btn-save,.btn-cancel{padding:.75rem 2rem;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-base)}.btn-save{background:linear-gradient(135deg,#10b981,#059669);color:var(--text-inverse);flex:1;box-shadow:var(--shadow-sm)}.btn-save:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-cancel{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-cancel:hover{background:var(--bg-tertiary);transform:translateY(-1px)}.form-note{margin-top:var(--spacing-lg);padding:var(--spacing-md);background:var(--bg-secondary);border-left:4px solid var(--color-blue);border-radius:var(--radius-sm);font-size:.875rem;color:var(--text-secondary);line-height:1.6}.form-note code{background:var(--bg-primary);padding:.125rem .375rem;border-radius:var(--radius-sm);font-family:var(--font-mono);color:var(--color-purple)}@media(max-width:1024px){.admin-edit-content{grid-template-columns:1fr}.items-list,.edit-form{max-height:none}}@media(max-width:768px){.admin-edit-header{flex-direction:column;gap:var(--spacing-md);align-items:stretch}.admin-edit-header h1{text-align:center}.item-card{flex-direction:column}.item-actions{width:100%}.btn-edit,.btn-delete{flex:1}.form-actions{flex-direction:column}}.section-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-color)}.section-header h2{margin:0;color:var(--text-primary);font-family:var(--font-display)}.section-actions{display:flex;gap:var(--spacing-sm)}.btn-download{padding:.5rem 1rem;background:var(--gradient-orange);color:var(--text-inverse);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.btn-download:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.bio-preview{padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-md)}.bio-preview p{margin:var(--spacing-sm) 0;color:var(--text-primary);line-height:1.6}.bio-preview strong{color:var(--text-primary);font-weight:var(--font-semibold)}.form-group select{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:1rem;font-family:inherit;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:all var(--transition-base)}.form-group select:focus{outline:none;border-color:var(--color-purple);box-shadow:0 0 0 3px #9b87f51a}@media(max-width:768px){.section-header{flex-direction:column;gap:var(--spacing-md);align-items:stretch}.section-actions{width:100%}.section-actions button{flex:1}}.form-note-container{margin-top:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-warning{padding:var(--spacing-md);background:#ef44441a;border-left:4px solid #ef4444;border-radius:var(--radius-sm);font-size:.875rem;color:#dc2626;line-height:1.6;margin:0}.btn-save:disabled,.btn-cancel:disabled,.btn-download:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.app{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1;padding-top:var(--nav-h)}
