:root{--color-primary:#0a1628;--color-primary-light:#152238;--color-primary-medium:#1e3a5f;--color-accent:#c8963e;--color-accent-light:#e0b866;--color-accent-glow:#c8963e26;--color-bg:#fff;--color-bg-alt:#f5f7fa;--color-bg-alt2:#eef1f5;--color-surface:#fff;--color-surface-hover:#f8fafc;--color-text:#1a202c;--color-text-secondary:#4a5568;--color-text-muted:#718096;--color-border:#e2e8f0;--color-border-light:#edf2f7;--color-success:#38a169;--color-gold-light:#fef9f0;--font-sans:"Outfit", system-ui, -apple-system, sans-serif;--font-serif:"Playfair Display", Georgia, "Times New Roman", serif;--container-max:1200px;--navbar-h:72px;--section-pad:5rem;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--shadow-sm:0 1px 3px #0a16280f;--shadow-md:0 4px 12px #0a162814;--shadow-lg:0 8px 30px #0a16281a;--shadow-xl:0 20px 60px #0a16281f;--shadow-glow:0 0 40px var(--color-accent-glow);--transition-fast:.15s ease;--transition-base:.3s cubic-bezier(.4, 0, .2, 1);--transition-slow:.6s cubic-bezier(.4, 0, .2, 1)}.dark-theme{--color-bg:#0a0f1a;--color-bg-alt:#111827;--color-bg-alt2:#1a2235;--color-surface:#151d2e;--color-surface-hover:#1c2740;--color-text:#e8ecf2;--color-text-secondary:#a0aec0;--color-text-muted:#718096;--color-border:#2d3748;--color-border-light:#1e2d45;--color-gold-light:#1a1820;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #00000059;--shadow-lg:0 8px 30px #0006;--shadow-xl:0 20px 60px #00000080}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);color:var(--color-text);background:var(--color-bg);font-size:16px;line-height:1.6;overflow-x:hidden}img,svg{max-width:100%;display:block}a{color:inherit;text-decoration:none}button{cursor:pointer;font:inherit;background:0 0;border:none}ul,ol{list-style:none}address{font-style:normal}.container{max-width:var(--container-max);margin:0 auto;padding:0 1.5rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.gap-4{gap:2rem}.text-center{text-align:center}.mt-2{margin-top:1rem}.mt-4{margin-top:2rem}.mb-2{margin-bottom:1rem}.mb-4{margin-bottom:2rem}.section-header{text-align:center;margin-bottom:3.5rem}.section-title{font-family:var(--font-serif);color:var(--color-primary);margin-bottom:.75rem;font-size:2.5rem;font-weight:700;display:inline-block;position:relative}.section-title:after{content:"";background:var(--color-accent);border-radius:2px;width:60px;height:3px;position:absolute;bottom:-10px;left:50%;transform:translate(-50%)}.section-subtitle{color:var(--color-text-secondary);max-width:600px;margin:0 auto;font-size:1.1rem;line-height:1.5}.dark-theme .section-title{color:#e8ecf2}section{padding:var(--section-pad) 0}.section-hero{padding:0}.section-about,.section-staff,.section-grad,.section-international{background:var(--color-bg)}.section-undergrad,.section-research,.section-contact{background:var(--color-bg-alt)}.navbar{z-index:1000;height:var(--navbar-h);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border-light);transition:background var(--transition-base);background:#ffffffd9;position:fixed;top:0;left:0;right:0}.dark-theme .navbar{border-bottom-color:var(--color-border);background:#0f1624d9}.navbar-inner{justify-content:space-between;align-items:center;height:100%;display:flex}.navbar-logo{white-space:nowrap;align-items:center;gap:.75rem;font-size:1rem;font-weight:600;display:flex}.logo-deu{color:var(--color-primary);font-weight:700}.logo-divider{color:var(--color-accent);margin:0 2px;font-weight:300}.logo-dept{color:var(--color-text-secondary);font-size:.9rem;font-weight:500}.navbar-links{align-items:center;gap:.25rem;display:flex}.nav-link{border-radius:var(--radius-sm);color:var(--color-text-secondary);transition:all var(--transition-fast);white-space:nowrap;padding:.4rem .75rem;font-size:.875rem;font-weight:500}.nav-link:hover{color:var(--color-primary);background:var(--color-bg-alt2)}.nav-link.active{color:var(--color-accent);background:var(--color-gold-light)}.dark-theme .nav-link:hover{background:var(--color-surface-hover)}.dark-theme .nav-link.active{background:#c8963e1a}.navbar-actions{align-items:center;gap:.5rem;display:flex}.lang-toggle{background:var(--color-bg-alt2);border-radius:20px;align-items:center;padding:2px;display:flex}.lang-btn{color:var(--color-text-muted);transition:all var(--transition-fast);border-radius:18px;padding:4px 10px;font-size:.75rem;font-weight:600}.lang-btn.active{background:var(--color-primary);color:#fff}.theme-toggle{width:36px;height:36px;color:var(--color-text-secondary);transition:all var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;display:flex}.theme-toggle:hover{background:var(--color-bg-alt2);color:var(--color-accent)}.hamburger{flex-direction:column;gap:5px;padding:4px;display:none}.hamburger span{background:var(--color-text);width:22px;height:2px;transition:all var(--transition-base);border-radius:2px;display:block}.hamburger.open span:first-child{transform:rotate(45deg)translate(5px,5px)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:rotate(-45deg)translate(5px,-5px)}.section-hero{background:var(--color-primary);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.hero-bg{z-index:0;position:absolute;inset:0}.hero-gradient{background:radial-gradient(ellipse 80% 60% at 30% 20%, #c8963e1f 0%, transparent 60%), radial-gradient(ellipse 60% 50% at 70% 60%, #4169e11a 0%, transparent 60%), linear-gradient(180deg, var(--color-primary) 0%, #162447 40%, var(--color-primary-light) 100%);position:absolute;inset:0}.hero-pattern{opacity:.04;background-image:linear-gradient(#ffffff4d 1px,#0000 1px),linear-gradient(90deg,#ffffff4d 1px,#0000 1px);background-size:60px 60px;position:absolute;inset:0}.hero-content{z-index:1;text-align:center;padding:6rem 1.5rem;position:relative}.hero-eyebrow{color:var(--color-accent-light);letter-spacing:.08em;text-transform:uppercase;margin-bottom:1.5rem;font-size:1rem;font-weight:500}.hero-title{font-family:var(--font-serif);color:#fff;margin-bottom:1.5rem;font-size:clamp(3rem,8vw,5rem);font-weight:700;line-height:1.1}.hero-title-sub{color:var(--color-accent-light);font-style:italic}.hero-desc{color:#ffffffb3;max-width:650px;margin:0 auto 3rem;font-size:1.2rem;line-height:1.6}.hero-stats{flex-wrap:wrap;justify-content:center;align-items:center;gap:3rem;margin-bottom:3rem;display:flex}.hero-stat-divider{background:#ffffff26;width:1px;height:40px}.hero-cta{background:var(--color-accent);color:#fff;transition:all var(--transition-base);border-radius:50px;align-items:center;gap:.75rem;padding:.875rem 2rem;font-size:1rem;font-weight:600;display:inline-flex;box-shadow:0 4px 20px #c8963e4d}.hero-cta:hover{background:var(--color-accent-light);transform:translateY(-2px);box-shadow:0 8px 30px #c8963e66}.hero-cta svg{animation:2s infinite bounce-down}.stat-counter{text-align:center}.stat-value{font-family:var(--font-serif);color:#fff;font-size:2.5rem;font-weight:700;line-height:1.2}.stat-suffix{color:var(--color-accent-light);margin-left:2px;font-size:1.5rem}.stat-label{color:#fff9;margin-top:.25rem;font-size:.875rem;font-weight:500}.about-grid{grid-template-columns:1fr 1fr;align-items:start;gap:3rem;display:grid}.about-heading{font-family:var(--font-serif);color:var(--color-primary);margin-bottom:1.25rem;font-size:1.5rem;font-weight:600}.about-text{color:var(--color-text-secondary);font-size:1.05rem;line-height:1.7}.about-highlights{flex-direction:column;gap:.75rem;display:flex}.about-highlights li{color:var(--color-text-secondary);align-items:flex-start;gap:.75rem;font-size:1rem;line-height:1.5;display:flex}.about-highlights li svg{flex-shrink:0;margin-top:2px}.timeline{padding-left:2rem;position:relative}.timeline:before{content:"";background:var(--color-accent);opacity:.3;width:2px;position:absolute;top:8px;bottom:8px;left:7px}.timeline-item{margin-bottom:1.5rem;position:relative}.timeline-dot{background:var(--color-accent);width:12px;height:12px;box-shadow:0 0 0 4px var(--color-accent-glow);border-radius:50%;position:absolute;top:6px;left:-2rem}.timeline-year{color:var(--color-accent);margin-bottom:.25rem;font-size:.875rem;font-weight:700;display:inline-block}.timeline-content p{color:var(--color-text-secondary);font-size:.95rem;line-height:1.5}.staff-filters{flex-wrap:wrap;gap:1rem;margin-bottom:2.5rem;display:flex}.staff-search{background:var(--color-surface);border:1px solid var(--color-border);min-width:250px;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);border-radius:50px;flex:1;align-items:center;gap:.75rem;padding:.75rem 1.25rem;display:flex}.staff-search:focus-within{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-glow)}.staff-search svg{color:var(--color-text-muted);flex-shrink:0}.staff-search input{color:var(--color-text);background:0 0;border:none;outline:none;flex:1;font-size:.95rem}.staff-search input::placeholder{color:var(--color-text-muted)}.staff-program-filter{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);cursor:pointer;border-radius:50px;outline:none;padding:.75rem 1.25rem;font-size:.9rem}.staff-program-filter:focus{border-color:var(--color-accent)}.staff-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;display:grid}.staff-empty{text-align:center;color:var(--color-text-muted);padding:2rem}.staff-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);transition:all var(--transition-base);height:100%;padding:1.5rem}.staff-card:hover{box-shadow:var(--shadow-lg);border-color:var(--color-accent);transform:translateY(-4px)}.staff-card-avatar{background:var(--color-bg-alt2);border-radius:50%;flex-shrink:0;width:64px;height:64px;margin-bottom:1rem;overflow:hidden}.staff-card-avatar img{object-fit:cover;width:100%;height:100%}.staff-card-initials{width:100%;height:100%;color:var(--color-accent);justify-content:center;align-items:center;font-size:1.25rem;font-weight:700;display:flex}.staff-badge{border-radius:20px;margin-bottom:.5rem;padding:.2rem .6rem;font-size:.7rem;font-weight:600;display:inline-block}.badge-prof{color:#2563eb;background:#ebf5ff}.badge-assoc{color:#16a34a;background:#f0fdf4}.badge-dr{color:#ca8a04;background:#fefce8}.badge-research{color:#db2777;background:#fdf2f8}.dark-theme .badge-prof{color:#60a5fa;background:#2563eb26}.dark-theme .badge-assoc{color:#4ade80;background:#16a34a26}.dark-theme .badge-dr{color:#facc15;background:#ca8a0426}.dark-theme .badge-research{color:#f472b6;background:#db277726}.staff-name{color:var(--color-text);margin-bottom:.25rem;font-size:1.05rem;font-weight:600;line-height:1.3}.staff-program{color:var(--color-text-muted);margin-bottom:.75rem;font-size:.8rem}.staff-metrics{border-top:1px solid var(--color-border-light);border-bottom:1px solid var(--color-border-light);grid-template-columns:repeat(4,1fr);gap:.5rem;margin-bottom:.75rem;padding:.75rem 0;display:grid}.staff-metric{text-align:center}.metric-value{color:var(--color-primary);font-size:.95rem;font-weight:700;display:block}.metric-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em;font-size:.65rem}.dark-theme .metric-value{color:var(--color-text)}.staff-links{gap:.5rem;display:flex}.staff-link{width:32px;height:32px;color:var(--color-text-muted);transition:all var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;font-size:0;display:flex}.staff-link:hover{background:var(--color-bg-alt2);color:var(--color-accent)}.ug-tabs{flex-wrap:wrap;justify-content:center;gap:.5rem;margin-bottom:2rem;display:flex}.ug-tab{color:var(--color-text-secondary);border:1px solid var(--color-border);transition:all var(--transition-fast);white-space:nowrap;border-radius:50px;padding:.5rem 1.25rem;font-size:.85rem;font-weight:500}.ug-tab:hover{border-color:var(--color-accent);color:var(--color-accent)}.ug-tab.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.ug-overview-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.25rem;display:grid}.ug-info-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:1.25rem}.ug-info-card h4{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:.5rem;font-size:.75rem;font-weight:600}.ug-info-card p{color:var(--color-text);font-size:.95rem;font-weight:500}.ug-outcomes h3,.grad-outcomes h3{font-family:var(--font-serif);color:var(--color-primary);margin-bottom:1.5rem;font-size:1.25rem}.outcomes-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:.75rem;display:grid}.outcome-item{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-md);transition:border-color var(--transition-fast);align-items:flex-start;gap:.75rem;padding:.75rem 1rem;display:flex}.outcome-item:hover{border-color:var(--color-accent)}.outcome-number{background:var(--color-bg-alt2);min-width:28px;height:28px;color:var(--color-accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;display:flex}.outcome-item p{color:var(--color-text-secondary);font-size:.9rem;line-height:1.5}.outcome-ds{border-left:3px solid var(--color-accent)}.outcome-badge{background:var(--color-accent-glow);color:var(--color-accent);border-radius:4px;flex-shrink:0;margin-left:auto;padding:2px 6px;font-size:.65rem;font-weight:700}.courses-table-wrap{border-radius:var(--radius-md);border:1px solid var(--color-border-light);overflow-x:auto}.courses-table{border-collapse:collapse;width:100%;font-size:.9rem}.courses-table thead{background:var(--color-primary)}.courses-table thead th{text-align:left;color:#fff;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;padding:.75rem 1rem;font-size:.8rem;font-weight:600}.courses-table tbody tr{border-bottom:1px solid var(--color-border-light);transition:background var(--transition-fast)}.courses-table tbody tr:hover{background:var(--color-surface-hover)}.courses-table tbody td{color:var(--color-text-secondary);white-space:nowrap;padding:.65rem 1rem}.course-code{font-family:SF Mono,Fira Code,monospace;font-size:.8rem;font-weight:600;color:var(--color-accent)!important}.course-name{min-width:200px;white-space:normal!important}.course-type{font-size:.8rem}.course-ects{font-weight:700;color:var(--color-primary)!important}.grad-program-tabs{flex-wrap:wrap;justify-content:center;gap:.75rem;margin-bottom:2rem;display:flex}.grad-program-tab{border-radius:var(--radius-md);border:2px solid var(--color-border);transition:all var(--transition-base);text-align:left;flex-direction:column;align-items:flex-start;min-width:200px;padding:.875rem 1.5rem;display:flex}.grad-program-tab:hover{border-color:var(--color-accent)}.grad-program-tab.active{border-color:var(--color-accent);background:var(--color-gold-light);box-shadow:var(--shadow-md)}.grad-tab-level{text-transform:uppercase;letter-spacing:.06em;color:var(--color-accent);margin-bottom:.25rem;font-size:.7rem;font-weight:700}.grad-tab-name{color:var(--color-text);font-size:.9rem;font-weight:500}.grad-tabs{background:var(--color-bg-alt2);border-radius:12px;gap:.25rem;margin-bottom:2rem;padding:4px;display:flex}.grad-tab{color:var(--color-text-secondary);transition:all var(--transition-fast);border-radius:8px;flex:1;padding:.6rem 1rem;font-size:.85rem;font-weight:500}.grad-tab.active{background:var(--color-surface);color:var(--color-primary);box-shadow:var(--shadow-sm);font-weight:600}.grad-info-row{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.grad-info-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:1rem 1.25rem}.grad-info-card h4{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:.4rem;font-size:.7rem}.grad-info-card p{color:var(--color-text);font-size:.9rem;font-weight:600}.grad-description,.grad-requirements{margin-bottom:1.5rem}.grad-description h4,.grad-requirements h4{font-family:var(--font-serif);color:var(--color-primary);margin-bottom:.5rem;font-size:1.1rem}.grad-description p,.grad-requirements p{color:var(--color-text-secondary);line-height:1.7}.grad-empty,.grad-empty-text{text-align:center;color:var(--color-text-muted);padding:2rem}.grad-semester{margin-bottom:2rem}.grad-semester-title{font-family:var(--font-serif);color:var(--color-primary);justify-content:space-between;align-items:center;margin-bottom:.75rem;font-size:1.1rem;display:flex}.sem-course-count{font-family:var(--font-sans);color:var(--color-text-muted);font-size:.8rem;font-weight:500}.research-stats-row{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.25rem;margin-bottom:3rem;display:grid}.research-stat-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);text-align:center;transition:all var(--transition-base);padding:1.5rem}.research-stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.research-stat-num{font-family:var(--font-serif);color:var(--color-accent);font-size:2.25rem;font-weight:700;line-height:1.2;display:block}.research-stat-lbl{color:var(--color-text-muted);margin-top:.25rem;font-size:.85rem}.research-stat-sub{color:var(--color-accent);margin-top:.2rem;font-size:.72rem;font-weight:500;display:block}.research-charts-grid{grid-template-columns:1fr 1fr;gap:2rem;display:grid}.research-chart-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);flex-direction:column;min-height:360px;padding:1.5rem;display:flex}.research-chart-card h4{font-family:var(--font-serif);color:var(--color-primary);margin-bottom:.25rem;font-size:1.05rem}.research-chart-card .chart-outer,.research-chart-card .chart-donut-outer{flex:1;align-items:center;display:flex}.chart-container{width:100%}.chart-svg{width:100%;height:100%}.chart-bar-label{fill:var(--color-text);font-family:var(--font-sans);font-weight:500}.chart-bar-value{fill:var(--color-primary);font-family:var(--font-sans);font-weight:600}.chart-vbar-label{fill:var(--color-text-secondary);font-family:var(--font-sans)}.chart-vbar-value{fill:var(--color-accent);font-family:var(--font-sans);font-weight:700}.chart-bar-label-inside{fill:#fff;font-family:var(--font-sans);font-weight:600}.dark-theme .chart-bar-label{fill:#cbd5e0}.dark-theme .chart-bar-value{fill:#e2e8f0}.dark-theme .chart-vbar-label{fill:#a0aec0}.dark-theme .chart-vbar-value{fill:var(--color-accent-light)}.chart-outer{width:100%}.chart-legend-h{flex-wrap:wrap;justify-content:center;gap:.35rem .9rem;margin-top:.6rem;display:flex}.legend-2row{grid-template-columns:repeat(2,1fr);gap:.3rem 1rem;max-width:500px;margin-left:auto;margin-right:auto;display:grid}.legend-dot-item{color:var(--color-text-secondary);white-space:nowrap;align-items:center;gap:.35rem;font-size:.75rem;display:flex}.chart-card-sub{color:var(--color-text-muted);margin-bottom:.5rem;font-size:.78rem}.chart-donut-outer{flex-wrap:wrap;justify-content:center;align-items:center;gap:1.5rem;display:flex}.chart-donut-visual{flex-shrink:0;position:relative}.donut-center{text-align:center;pointer-events:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.donut-total{font-family:var(--font-serif);color:var(--color-primary);font-size:1.5rem;font-weight:700;line-height:1.1;display:block}.donut-unit{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.68rem}.donut-legend-vert{flex-direction:column;gap:.35rem;min-width:140px;display:flex}.donut-legend-vert .legend-dot-item{font-size:.78rem}.donut-legend-vert .legend-label{color:var(--color-text-secondary);flex:1}.donut-legend-vert .legend-val{color:var(--color-primary);font-size:.72rem;font-weight:600}.dark-theme .donut-total{color:#e2e8f0}.dark-theme .donut-legend-vert .legend-val{color:#cbd5e0}.legend-rank{color:var(--color-accent);min-width:16px;font-size:.7rem;font-weight:700}.chart-doughnut-wrap{margin:0 auto;position:relative}.doughnut-center{text-align:center;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.doughnut-total{font-family:var(--font-serif);color:var(--color-primary);font-size:1.5rem;font-weight:700;display:block}.doughnut-label{color:var(--color-text-muted);text-transform:uppercase;font-size:.7rem}.doughnut-legend{flex-wrap:wrap;justify-content:center;gap:.75rem;margin-top:1rem;display:flex}.legend-item{color:var(--color-text-secondary);align-items:center;gap:.4rem;font-size:.8rem;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.intl-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-bottom:3rem;display:grid}.intl-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);text-align:center;transition:all var(--transition-base);padding:2rem}.intl-card:hover{box-shadow:var(--shadow-lg);border-color:var(--color-accent);transform:translateY(-4px)}.intl-icon{background:var(--color-gold-light);width:72px;height:72px;color:var(--color-accent);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 1.25rem;display:flex}.intl-title{font-family:var(--font-serif);color:var(--color-primary);margin-bottom:.75rem;font-size:1.2rem;font-weight:600}.intl-desc{color:var(--color-text-secondary);font-size:.95rem;line-height:1.6}.intl-expand{color:var(--color-accent);margin-top:.75rem;font-size:.8rem;font-weight:600;display:inline-block}.erasmus-table-wrap{margin-top:1.5rem}.erasmus-table-wrap h4{font-family:var(--font-serif);color:var(--color-primary);margin-bottom:.75rem;font-size:1.1rem}.section-software{background:var(--color-bg)}.software-summary{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem;margin-bottom:2rem;display:grid}.software-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);text-align:center;transition:all var(--transition-base);padding:1.75rem;text-decoration:none;display:block}.software-card:hover{box-shadow:var(--shadow-lg);border-color:var(--color-accent);transform:translateY(-3px)}.software-card-icon{color:var(--color-accent);justify-content:center;margin-bottom:.75rem;display:flex}.software-card-num{font-family:var(--font-serif);color:var(--color-primary);font-size:2rem;font-weight:700;line-height:1.1}.software-card-lbl{color:var(--color-text-secondary);margin-top:.25rem;font-size:.9rem;font-weight:500}.software-card-sub{color:var(--color-text-muted);margin-top:.25rem;font-size:.75rem}.software-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.75rem;display:grid}.software-item{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-md);transition:border-color var(--transition-fast);padding:.85rem 1rem}.software-item:hover{border-color:var(--color-accent)}.software-item-header{justify-content:space-between;align-items:baseline;margin-bottom:.3rem;display:flex}.software-item-name{color:var(--color-primary);font-size:.88rem;font-weight:600}.software-item-dl{color:var(--color-accent);white-space:nowrap;font-size:.72rem;font-weight:600}.software-item-desc{color:var(--color-text-muted);font-size:.78rem;line-height:1.5}.section-infographics{background:var(--color-bg-alt)}.infographics-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;display:grid}.infographic-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);transition:all var(--transition-base);overflow:hidden}.infographic-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.infographic-img-wrap{aspect-ratio:1.4;background:var(--color-bg-alt2);width:100%;overflow:hidden}.infographic-img-wrap img{object-fit:contain;width:100%;height:100%;padding:.75rem}.infographic-info{padding:1rem 1.25rem 1.25rem}.infographic-info h4{font-family:var(--font-serif);color:var(--color-primary);margin-bottom:.3rem;font-size:1rem;font-weight:600}.infographic-info p{color:var(--color-text-muted);font-size:.82rem;line-height:1.4}.lightbox-overlay{z-index:3000;cursor:pointer;background:#000000e6;justify-content:center;align-items:center;padding:2rem;animation:.2s fade-in;display:flex;position:fixed;inset:0}.lightbox-content{cursor:default;max-width:90vw;max-height:90vh;position:relative}.lightbox-content img{object-fit:contain;border-radius:8px;max-width:90vw;max-height:85vh}.lightbox-close{cursor:pointer;opacity:.7;transition:opacity var(--transition-fast);background:0 0;border:none;padding:4px;position:absolute;top:-40px;right:0}.lightbox-close:hover{opacity:1}.lightbox-caption{text-align:center;color:#fff9;margin-top:.75rem;font-size:.85rem}.footer-aesop{color:#ffffff4d;margin-top:.35rem;font-size:.68rem}.footer-aesop a{color:#ffffff73;transition:color var(--transition-fast);text-decoration:underline}.footer-aesop a:hover{color:var(--color-accent-light)}.intl-badges{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.intl-badge{background:var(--color-surface);border:1px solid var(--color-border-light);color:var(--color-text-secondary);border-radius:50px;align-items:center;gap:.5rem;padding:.6rem 1.25rem;font-size:.85rem;font-weight:500;display:flex}.badge-icon{font-size:1.1rem}.contact-grid{grid-template-columns:1fr 1fr;gap:2rem;display:grid}.contact-info{flex-direction:column;gap:1rem;display:flex}.contact-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-md);gap:1rem;padding:1.25rem;display:flex}.contact-icon{color:var(--color-accent);flex-shrink:0;align-items:flex-start;margin-top:2px;display:flex}.contact-card h4{color:var(--color-primary);margin-bottom:.4rem;font-size:.95rem;font-weight:600}.contact-card p,.contact-card address p{color:var(--color-text-secondary);font-size:.9rem;line-height:1.5}.contact-map{border-radius:var(--radius-lg);border:1px solid var(--color-border-light);overflow:hidden}.map-caption{text-align:center;color:var(--color-text-muted);margin-top:.5rem;font-size:.8rem}.footer{background:var(--color-primary);color:#ffffffb3;padding:3rem 0 1.5rem}.footer-grid{grid-template-columns:2fr 1fr 1.5fr;gap:2rem;margin-bottom:2rem;display:grid}.footer-heading{font-family:var(--font-serif);color:#fff;margin-bottom:1rem;font-size:1.1rem;font-weight:600}.footer-desc{max-width:300px;font-size:.9rem;line-height:1.6}.footer-links{flex-direction:column;gap:.5rem;display:flex}.footer-links a{transition:color var(--transition-fast);font-size:.9rem}.footer-links a:hover{color:var(--color-accent-light)}.footer-address{font-size:.85rem;line-height:1.6}.footer-bottom{text-align:center;color:#fff6;border-top:1px solid #ffffff1a;padding-top:1.5rem;font-size:.8rem}.reveal-fade-up,.reveal-fade-left,.reveal-fade-right,.reveal-scale-in{opacity:0;transition:opacity var(--transition-slow), transform var(--transition-slow)}.reveal-fade-up{transform:translateY(40px)}.reveal-fade-left{transform:translate(-40px)}.reveal-fade-right{transform:translate(40px)}.reveal-scale-in{transform:scale(.9)}.is-visible.reveal-fade-up,.is-visible.reveal-fade-left,.is-visible.reveal-fade-right,.is-visible.reveal-scale-in{opacity:1;transform:translate(0)scale(1)}@keyframes bounce-down{0%,to{transform:translateY(0)}50%{transform:translateY(5px)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.staff-card.clickable{cursor:pointer}.staff-card.clickable:hover{border-color:var(--color-accent)}.staff-link-more{opacity:0;transition:opacity var(--transition-fast);color:var(--color-accent);margin-left:auto}.staff-card:hover .staff-link-more{opacity:1}.modal-staff{max-width:900px}.staff-modal-header{border-bottom:1px solid var(--color-border-light);background:var(--color-surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;justify-content:space-between;align-items:flex-start;padding:2rem;display:flex}.staff-modal-profile{align-items:center;gap:1.5rem;display:flex}.staff-modal-avatar{background:var(--color-bg-alt2);border-radius:50%;flex-shrink:0;width:80px;height:80px;overflow:hidden}.staff-modal-avatar img{object-fit:cover;width:100%;height:100%}.staff-modal-initials{width:100%;height:100%;color:var(--color-accent);justify-content:center;align-items:center;font-size:1.5rem;font-weight:700;display:flex}.staff-modal-name{font-family:var(--font-serif);color:var(--color-primary);margin:.25rem 0;font-size:1.5rem;font-weight:700}.staff-modal-dept{color:var(--color-text-secondary);font-size:.9rem}.staff-modal-email{color:var(--color-accent);margin-top:.25rem;font-size:.85rem}.staff-detail-links{flex-wrap:wrap;gap:.5rem;display:flex}.staff-detail-link{border:1px solid var(--color-border);color:var(--color-text-secondary);transition:all var(--transition-fast);border-radius:50px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.83rem;font-weight:500;display:inline-flex}.staff-detail-link:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-gold-light)}.staff-metrics-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.5rem;display:grid}.staff-metric-item{background:var(--color-bg-alt);border-radius:var(--radius-md);text-align:center;padding:.75rem}.staff-metric-val{color:var(--color-primary);font-size:1.25rem;font-weight:700;display:block}.staff-metric-key{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em;font-size:.7rem}.staff-tags{flex-wrap:wrap;gap:.5rem;display:flex}.staff-tag{background:var(--color-accent-glow);color:var(--color-accent);border-radius:50px;padding:.3rem .8rem;font-size:.8rem;font-weight:500}.pub-category{margin-bottom:1.25rem}.pub-cat-title{color:var(--color-accent);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--color-border-light);margin-bottom:.5rem;padding-bottom:.25rem;font-size:.85rem;font-weight:600}.pub-list{flex-direction:column;gap:.5rem;list-style:none;display:flex}.pub-item{background:var(--color-bg-alt);border-radius:var(--radius-sm);border-left:3px solid var(--color-accent);padding:.6rem .75rem}.pub-title{color:var(--color-text);font-size:.9rem;font-weight:600;line-height:1.4;display:block}.pub-desc{color:var(--color-text-muted);margin-top:.15rem;font-size:.8rem;display:block}.course-row.clickable{cursor:pointer;transition:background var(--transition-fast)}.course-row.clickable:hover{background:var(--color-gold-light)!important}.course-detail-icon{opacity:0;transition:opacity var(--transition-fast);color:var(--color-accent);margin-left:4px;font-size:.7rem}.course-row.clickable:hover .course-detail-icon{opacity:1}.modal-overlay{z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0a162899;justify-content:center;align-items:flex-start;padding:2rem 1rem;animation:.2s fade-in;display:flex;position:fixed;inset:0;overflow-y:auto}.modal-container{background:var(--color-surface);border-radius:var(--radius-xl);width:100%;max-width:800px;max-height:calc(100vh - 4rem);box-shadow:var(--shadow-xl);animation:.3s cubic-bezier(.4,0,.2,1) modal-slide-up;overflow-y:auto}.modal-header{border-bottom:1px solid var(--color-border-light);background:var(--color-surface);z-index:1;border-radius:var(--radius-xl) var(--radius-xl) 0 0;justify-content:space-between;align-items:flex-start;padding:1.5rem 2rem;display:flex;position:sticky;top:0}.modal-code{color:var(--color-accent);letter-spacing:.05em;font-family:SF Mono,Fira Code,monospace;font-size:.75rem;font-weight:700}.modal-title{font-family:var(--font-serif);color:var(--color-primary);margin:.25rem 0 .5rem;font-size:1.4rem;font-weight:600;line-height:1.3}.modal-meta{flex-wrap:wrap;gap:.5rem;display:flex}.modal-badge{background:var(--color-accent-glow);color:var(--color-accent);border-radius:20px;padding:.2rem .7rem;font-size:.72rem;font-weight:600;display:inline-block}.modal-badge-outline{border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:20px;padding:.2rem .7rem;font-size:.72rem;font-weight:500;display:inline-block}.modal-close{background:var(--color-bg-alt2);width:40px;height:40px;color:var(--color-text-muted);transition:all var(--transition-fast);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--color-bg-alt2);color:var(--color-text)}.modal-body{padding:1.5rem 2rem 2rem}.modal-section{margin-bottom:1.75rem}.modal-section h4{font-family:var(--font-serif);color:var(--color-primary);border-bottom:2px solid var(--color-accent-glow);margin-bottom:.6rem;padding-bottom:.4rem;font-size:1.05rem;font-weight:600}.modal-section p{color:var(--color-text-secondary);font-size:.93rem;line-height:1.7}.modal-sm{color:var(--color-text-muted);font-size:.85rem}.modal-list{color:var(--color-text-secondary);flex-direction:column;gap:.3rem;padding-left:1.25rem;font-size:.93rem;list-style:outside;display:flex}.modal-list-numbered{color:var(--color-text-secondary);flex-direction:column;gap:.5rem;padding-left:1.25rem;font-size:.93rem;display:flex}.modal-list-numbered li{line-height:1.5}.weekly-topics{flex-direction:column;gap:.5rem;display:flex}.weekly-topic-item{background:var(--color-bg-alt);border-radius:var(--radius-sm);border-left:3px solid var(--color-accent);gap:1rem;padding:.6rem .75rem;display:flex}.week-num{color:var(--color-accent);flex-shrink:0;min-width:60px;font-size:.78rem;font-weight:700}.weekly-topic-item p{color:var(--color-text-secondary);font-size:.9rem}.workload-grid{flex-direction:column;gap:1.25rem;display:flex}.workload-cat h5{color:var(--color-text);margin-bottom:.5rem;font-size:.85rem;font-weight:600}.workload-table{border-collapse:collapse;width:100%;font-size:.82rem}.workload-table thead{background:var(--color-bg-alt2)}.workload-table thead th{text-align:left;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em;padding:.4rem .6rem;font-size:.7rem;font-weight:600}.workload-table tbody td{border-bottom:1px solid var(--color-border-light);color:var(--color-text-secondary);padding:.4rem .6rem}.workload-total{background:var(--color-gold-light);border-radius:var(--radius-md);color:var(--color-text);gap:2rem;margin-top:1rem;padding:.75rem 1rem;font-size:.9rem;display:flex}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-slide-up{0%{opacity:0;transform:translateY(30px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@media (width<=1024px){.about-grid,.research-charts-grid,.contact-grid{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr 1fr}.navbar-links{top:var(--navbar-h);background:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-lg);flex-direction:column;gap:.25rem;padding:1rem;display:none;position:absolute;left:0;right:0}.navbar-links.open{display:flex}.nav-link{border-radius:var(--radius-sm);padding:.75rem 1rem;font-size:.9rem}.hamburger{display:flex}.hero-stats{gap:1.5rem}}@media (width<=768px){:root{--section-pad:3rem;--navbar-h:64px}.section-title{font-size:2rem}.hero-title{font-size:2.5rem}.hero-stats{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}.hero-stat-divider{display:none}.staff-grid{grid-template-columns:1fr}.staff-metrics{grid-template-columns:repeat(4,1fr)}.outcomes-grid{grid-template-columns:1fr}.ug-tabs{gap:.25rem}.ug-tab{padding:.4rem .75rem;font-size:.75rem}.research-stats-row{grid-template-columns:1fr 1fr}.intl-grid{grid-template-columns:1fr}.grad-program-tabs{flex-direction:column}.grad-program-tab{flex-direction:row;align-items:center;gap:.5rem;min-width:auto}.grad-tab-level{margin-bottom:0}.grad-tabs{flex-direction:column}.footer-grid{grid-template-columns:1fr}.footer-col{text-align:center}.footer-desc{max-width:none}.staff-filters{flex-direction:column}}@media (width<=480px){.hero-stats,.research-stats-row{grid-template-columns:1fr}.stat-value{font-size:2rem}.courses-table{font-size:.75rem}}
