*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#333;font-family:Poppins,sans-serif;line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.container{margin:0 auto;max-width:1200px;padding:0 20px}.section{padding:80px 0}.btn{background:#007bff;border-radius:5px;color:#fff;display:inline-block;padding:12px 24px;text-decoration:none;transition:background .3s ease}.btn:hover{background:#0056b3}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{background-color:#282c34;color:#fff;padding:20px}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1e3a8a;box-shadow:0 2px 10px #0000001a;box-shadow:2px 0 10px #0000001a;height:100vh;left:0;position:fixed;right:0;right:auto;top:0;width:auto;z-index:1000}.container{margin:0;max-width:100%;padding:0 1rem;width:100%}.header-content{align-items:center;display:flex;justify-content:space-between;padding:1rem 0;width:100%}.header .header-content{align-items:center;flex-direction:column;gap:2rem;height:100vh;justify-content:flex-start;padding:2rem 0;width:100%}.header .logo{text-align:center;width:100%}.header .container{margin:0;max-width:100%;padding:0;width:100%}.logo a{color:inherit;text-decoration:none}.logo h1{color:#fff;font-size:2rem;font-weight:700;margin:0}.logo span{color:#7f8c8d;display:block;font-size:.9rem}.header .logo h1{font-size:2.5rem;margin-bottom:.5rem}.header .logo span{font-size:1rem;margin-bottom:1rem}.nav-list{display:flex;gap:0;list-style:none;margin:0;padding:0;width:100%}.header .nav-list{flex-direction:column;gap:0;margin-top:1rem;width:100%}.nav-list li{margin:0}.header .dropdown-menu{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:4px;box-shadow:none;left:0;margin:0;max-height:0;padding:0;position:static;right:0;text-align:center;transform:none;width:100%}.header .dropdown-menu.open{max-height:200px;padding:0;transform:none}.header .dropdown-menu a,.header .dropdown-menu li{text-align:center;width:100%}.header .dropdown-menu a{background-color:#3498db1a;box-sizing:border-box;display:block;padding:.75rem 1rem;transition:background-color .3s ease}.header .dropdown-menu a:hover{background-color:#00b6e8;color:#fff}.nav-list a{color:#fff;font-weight:500;text-decoration:none;transition:color .3s ease}.nav-list a:hover{color:#e0e7ff}.nav-item.active,.nav-list a.active{color:#c7d2fe}.nav .nav-item,.nav .nav-item:hover{background-color:#3498db1a}.dropdown{position:relative;width:100%}.nav-item{color:#fff;cursor:pointer;display:block;font-weight:500;padding:1rem 6.5rem;text-align:center;transition:color .3s ease;width:100%}.nav-item:hover{background-color:#ffffff14;color:#e0e7ff}.dropdown-menu{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:4px;box-shadow:0 4px 6px #0000001a;left:0;list-style:none;margin:0;max-height:0;opacity:0;overflow:hidden;padding:0;position:absolute;right:0;top:100%;transform:translateY(-10px);transition:all .3s ease;visibility:hidden;width:100%;z-index:1001}.dropdown-menu.open{max-height:200px;opacity:1;padding:.5rem 0;transform:translateY(0);visibility:visible}.dropdown-menu li{margin:0;width:100%}.dropdown-menu a{box-sizing:border-box;color:#2c3e50;display:block;padding:.5rem 1rem;text-align:center;text-decoration:none;transition:background-color .3s ease;width:100%}.dropdown-menu a:hover{background-color:#3498db1a;color:#3498db}.mobile-menu-btn{background:none;border:none;cursor:pointer;display:none;flex-direction:column;padding:.5rem}.mobile-menu-btn span{background:#2c3e50;height:3px;margin:3px 0;transition:.3s;width:25px}@media (max-width:768px){.header{box-shadow:0 2px 10px #0000001a;height:auto;left:0;position:fixed;right:0;top:0;width:100%}.header .header-content{align-items:center;flex-direction:row;gap:0;height:auto;justify-content:space-between;padding:1rem 0}.header .nav-list{flex-direction:row;gap:1rem;margin-top:0}.hero.home-hero{margin-left:0}.mobile-menu-btn{display:flex}.nav{background:#fff;left:0;opacity:0;position:absolute;right:0;top:100%;transform:translateY(-100%);transition:all .3s ease;visibility:hidden}.nav-open{opacity:1;transform:translateY(0);visibility:visible}.nav-list{flex-direction:column;gap:1rem;padding:1rem 0}.dropdown-menu{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;box-shadow:none;left:0;margin-left:1rem;margin-top:.5rem;max-height:0;opacity:1;overflow:hidden;padding:0;position:static;right:0;transform:none;visibility:visible;width:calc(100% - 1rem)}.dropdown-menu.open{max-height:200px;padding:.5rem 0}.dropdown-menu a{box-sizing:border-box;font-size:.9rem;padding:.75rem 1rem;text-align:center;width:100%}}.footer{background:#282c34;color:#fff;font-size:1rem;margin-top:0;padding:2rem 0;text-align:center}.footer .container{margin-left:500px;width:calc(100% - 500px)}@media (max-width:1200px){.footer .container{margin-left:350px;width:calc(100% - 350px)}}.footer p{color:#bbb;margin:0}@media (max-width:1024px){.footer .container{margin-left:250px;width:calc(100% - 250px)}}@media (max-width:768px){.footer .container{margin-left:0;width:100%}}.hero{align-items:center;color:#fff;display:flex;height:100vh;justify-content:center;margin-left:280px;overflow:hidden;position:relative;text-align:center;transition:margin-left .3s ease,width .3s ease;width:calc(100% - 280px)}.hero-background{background:linear-gradient(135deg,#667eea,#764ba2);z-index:-2}.hero-background,.hero-overlay{bottom:0;left:0;position:absolute;right:0;top:0}.hero-overlay{background:#0000004d;z-index:-1}.hero-content{max-width:800px;z-index:1}.hero .hero-content{margin:0 auto;text-align:center}.hero-title{animation:fadeInUp 1s ease-out;font-size:3.5rem;font-weight:700;margin-bottom:1rem}.hero-subtitle{animation:fadeInUp 1s ease-out .2s both;font-size:1.3rem;margin-bottom:2rem;opacity:.9}.hero-buttons{animation:fadeInUp 1s ease-out .4s both;display:flex;gap:1rem;justify-content:center}.btn-primary{background:#3498db;border-radius:50px;color:#fff;font-weight:600;padding:15px 30px;text-decoration:none;transition:all .3s ease}.btn-primary:hover{background:#2980b9;box-shadow:0 10px 20px #0003;transform:translateY(-2px)}.btn-secondary{background:#0000;border:2px solid #fff;border-radius:50px;color:#fff;font-weight:600;padding:15px 30px;text-decoration:none;transition:all .3s ease}.btn-secondary:hover{background:#fff;color:#2c3e50;transform:translateY(-2px)}.scroll-indicator{animation:bounce 2s infinite;bottom:30px;left:50%;position:absolute;transform:translateX(-50%)}.scroll-arrow{border-bottom:2px solid #fff;border-right:2px solid #fff;height:30px;transform:rotate(45deg);width:30px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateX(-50%) translateY(0)}40%{transform:translateX(-50%) translateY(-10px)}60%{transform:translateX(-50%) translateY(-5px)}}@media (max-width:768px){.hero{margin-left:0;width:100%}.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.1rem}.hero-buttons{align-items:center;flex-direction:column}}.sections-overview{background:#f8f9fa;margin-left:280px;padding:80px 0;width:calc(100% - 280px)}.word-cloud{display:flex;flex-wrap:wrap;gap:1.2rem 1.6rem;justify-content:center;margin-left:auto;margin-right:auto;margin-top:3rem;max-width:900px;position:relative}.word-cloud-word{cursor:default;font-weight:600;transform:translate(0);transform:translate(var(--tx,0),var(--ty,0));transition:transform .25s ease,text-shadow .25s ease,opacity .25s ease;white-space:nowrap;will-change:transform}.word-cloud-word:hover{text-shadow:0 6px 18px #0000002e;transform:translate(0) scale(1.08) translateY(-2px);transform:translate(var(--tx,0),var(--ty,0)) scale(1.08) translateY(-2px)}.word-cloud-caption{color:#7f8c8d;line-height:1.6;margin:1.8rem auto 3rem;max-width:900px;text-align:center}.sections-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(2,1fr);margin-left:auto;margin-right:auto;margin-top:3rem;max-width:800px}@media (max-width:1024px){.sections-grid{grid-template-columns:repeat(2,1fr)}}.section-card{background:#fff;border-radius:15px;box-shadow:0 5px 20px #0000001a;color:inherit;overflow:hidden;padding:2rem;position:relative;text-decoration:none;transition:all .3s ease}.section-card:hover{box-shadow:0 20px 40px #00000026;transform:translateY(-10px)}.section-card:before{background:linear-gradient(90deg,#667eea,#764ba2);content:"";height:4px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s ease}.section-card:hover:before{transform:scaleX(1)}.section-icon{align-items:center;border-radius:50%;display:flex;font-size:2rem;height:60px;justify-content:center;margin-bottom:1.5rem;transition:transform .3s ease;width:60px}.section-card:hover .section-icon{transform:scale(1.1)}.section-card h3{color:#2c3e50;font-size:1.3rem;font-weight:600;margin-bottom:1rem}.section-card p{color:#7f8c8d;line-height:1.6;margin-bottom:1.5rem}.section-arrow{color:#3498db;font-size:1.5rem;font-weight:700;transition:transform .3s ease}.section-card:hover .section-arrow{transform:translateX(5px)}@media (max-width:768px){.sections-overview{margin-left:0;width:100%}.sections-grid{gap:1.5rem;grid-template-columns:1fr}.section-card{padding:1.5rem}.section-icon{font-size:1.5rem;height:50px;width:50px}}.about{background:#f8f9fa}.section-header{margin-bottom:4rem;text-align:center}.section-header h2{color:#2c3e50;font-size:2.5rem;margin-bottom:1rem}.section-header p{color:#7f8c8d;font-size:1.1rem;margin:0 auto;max-width:1200px}.about-content{grid-gap:4rem;align-items:start;display:grid;gap:4rem;grid-template-columns:2fr 1fr}.about-text h3{color:#2c3e50;font-size:1.5rem;margin-bottom:1rem;margin-top:2rem}.about-text h3:first-child{margin-top:0}.about-text p{color:#555;line-height:1.8;margin-bottom:1.5rem}.about-text ul{list-style:none;padding:0}.about-text li{color:#555;list-style:none;padding:.5rem 0 .5rem 1.5rem;position:relative}.about-text li:before{color:gold;content:"▸";font-weight:700;left:0;position:absolute;top:50%;transform:translateY(-50%)}.capsule-item{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:25px;box-shadow:0 5px 15px #667eea4d;color:#fff;display:inline-block;font-weight:500;margin:.5rem 0;padding:.8rem 1.5rem;transition:transform .3s ease,box-shadow .3s ease}.capsule-item:hover{box-shadow:0 8px 25px #667eea66;transform:translateY(-2px)}.about-stats{display:flex;flex-direction:column;gap:2rem}.stat-item{background:#fff;border-radius:10px;box-shadow:0 5px 15px #0000001a;padding:2rem;text-align:center;transition:transform .3s ease}.stat-item:hover{transform:translateY(-5px)}.stat-item h4{color:#3498db;font-size:2.5rem;margin-bottom:.5rem}.stat-item p{color:#7f8c8d;font-weight:500}@media (max-width:768px){.about-content{gap:2rem;grid-template-columns:1fr}.about-stats{flex-direction:row;justify-content:space-around}.stat-item{flex:1 1;padding:1.5rem}.stat-item h4{font-size:2rem}}.research{background:#fff}.research-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:3rem}.research-card{background:#f8f9fa;border:2px solid #0000;border-radius:15px;padding:2rem;text-align:center;transition:all .3s ease}.research-card:hover{border-color:#3498db;box-shadow:0 20px 40px #0000001a;transform:translateY(-10px)}.research-icon{font-size:3rem;margin-bottom:1rem}.research-card h3{color:#2c3e50;font-size:1.3rem;margin-bottom:1rem}.research-card p{color:#7f8c8d;line-height:1.6}@media (max-width:768px){.research-grid{grid-template-columns:1fr}}.page-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;margin-top:80px;padding:100px 0 60px;text-align:center}.page-header h1{font-size:3rem;font-weight:700;margin-bottom:1rem}.page-header p{font-size:1.2rem;margin:0 auto;max-width:600px;opacity:.9}.AboutPage,.MembersPage,.ProfessorPage,.ProjectsPage,.PublicationsPage,.StudentsPage{margin-left:280px;padding-top:0}.AboutPage .about,.MembersPage .members,.ProfessorPage .professor-section,.ProjectsPage .projects,.PublicationsPage .contact,.StudentsPage .students{margin-top:0}@media (max-width:768px){.AboutPage,.MembersPage,.ProfessorPage,.ProjectsPage,.PublicationsPage,.StudentsPage{margin-left:0;padding-top:0}.page-header{margin-top:70px;padding:80px 0 40px}.page-header h1{font-size:2.5rem}.page-header p{font-size:1rem}}.members{background:none;position:relative}.members:before{background:#f8f9fa;content:"";height:100%;left:50%;position:absolute;top:0;transform:translateX(-50%);width:100vw;z-index:-1}.students{margin-left:280px;width:calc(100% - 280px)}.members .container{box-sizing:border-box;margin-left:auto;margin-right:auto;max-width:1200px;padding-left:clamp(8px,3vw,24px);padding-right:clamp(8px,3vw,24px)}.degree-section{margin-bottom:4rem}.degree-title{border-bottom:3px solid #3498db;color:#2c3e50;display:inline-block;font-size:1.8rem;margin-bottom:2rem;padding-bottom:.5rem;text-align:center;width:100%}.members-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-top:3rem}.students .members-grid{justify-content:start}.member-card{background:#fff;border-radius:15px;box-shadow:0 5px 20px #00000012;padding:2rem 1rem;text-align:center;transition:transform .3s,box-shadow .3s}.member-card:hover{box-shadow:0 15px 30px #0000001f;transform:translateY(-8px)}.member-image{align-items:center;background:#f1f3f4;border-radius:50%;display:flex;height:120px;justify-content:center;margin:0 auto 1rem;overflow:hidden;position:relative;width:120px}.member-image img{border-radius:50%;height:100%;object-fit:cover;width:100%}.member-avatar-placeholder{align-items:center;background:#f1f3f4;color:#9aa0a6;display:flex;font-size:3rem;height:100%;justify-content:center;width:100%}.member-card h3{color:#2c3e50;font-size:1.2rem;margin-bottom:.5rem}.member-company{color:#3498db;font-weight:600}.member-company,.member-position{font-size:.9rem;margin-bottom:.3rem}.member-position{color:#e74c3c;font-weight:500}.member-email,.member-work{color:#7f8c8d;font-size:.85rem}.member-email{margin-bottom:.3rem;word-break:break-all}@media (max-width:1024px){.members-grid{gap:1.5rem}.member-card{padding:1.5rem 1rem}.member-image{height:100px;width:100px}.member-card h3{font-size:1.1rem}}@media (max-width:768px){.members-grid{gap:1.25rem;grid-template-columns:repeat(2,1fr)}.member-card{padding:1.25rem .875rem}.member-image{height:90px;width:90px}.member-card h3{font-size:1rem}.member-company,.member-position{font-size:.85rem}.member-work{font-size:.8rem}.students{margin-left:0;width:100%}}@media (max-width:480px){.members-grid{gap:.75rem;grid-template-columns:1fr}.member-image{height:72px;width:72px}.member-card{margin:0 auto;max-width:420px;padding:.875rem .75rem}.member-card h3{font-size:.95rem}.member-company,.member-position{font-size:.8rem}.member-work{font-size:.78rem}.students{margin-left:0;width:100%}}@media (max-width:360px){.members .container{padding-left:8px;padding-right:8px}.member-image{height:64px;width:64px}.member-card h3{font-size:.9rem}.member-company,.member-position,.member-work{font-size:.75rem}}.projects-container{background:#fff;margin-top:0;min-height:100vh;padding:4rem 0}.projects-section-title{margin-bottom:2rem;text-align:center}.projects-section-title h2{color:#2c3e50;font-size:2.5rem;font-weight:600;margin-bottom:1rem}.projects-container .container{margin:0 auto;max-width:1200px;padding:0 1rem}.loading{color:#7f8c8d;padding:4rem 0;text-align:center}.projects-tabs{border-bottom:1px solid #e0e0e0;display:flex;justify-content:flex-start;margin-bottom:2rem}.tab-button{background:none;border:none;border-bottom:2px solid #0000;color:#757575;cursor:pointer;font-size:1rem;font-weight:500;padding:1rem 2rem;transition:all .3s ease;white-space:nowrap}.tab-button.active,.tab-button:hover{background-color:#0000000a;color:#333}.tab-button.active{border-bottom-color:#333;font-weight:600}.projects-header{grid-gap:1rem;align-items:center;background-color:#f8f9fa;border-bottom:1px solid #e0e0e0;display:grid!important;gap:1rem;grid-template-columns:1fr auto 1fr;margin-bottom:1rem;margin-top:.5rem;padding:.5rem 0 1rem;visibility:visible!important;width:100%}.header-pagination{align-items:center;display:flex;justify-content:center}.projects-info{align-items:center;display:flex;gap:1rem}.total-count{color:#333;font-size:.9rem;font-weight:500}.page-info{color:#757575;font-size:.9rem}.projects-controls{align-items:center;display:flex!important;justify-content:flex-end;min-width:150px;visibility:visible!important}.items-per-page-select{background:#fff;border:2px solid #4472c4;border-radius:8px;box-shadow:0 2px 8px #00000026;color:#333;cursor:pointer;font-size:1rem;font-weight:600;height:45px;min-width:140px;padding:.8rem 1.2rem;text-align:left;transition:all .2s ease}.items-per-page-select:hover{border-color:#4472c4;box-shadow:0 2px 5px #00000026}.items-per-page-select:focus{border-color:#4472c4;box-shadow:none;outline:none}.projects-table-container{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem;overflow:hidden;overscroll-behavior:contain}.projects-table{border-collapse:collapse;font-size:.9rem;width:100%}.projects-table thead{background-color:#4472c4}.projects-table th{border-bottom:1px solid #e0e0e0;color:#fff;font-weight:600;padding:1rem;text-align:center}.projects-table th .th-sort{background:#0000;border:none;color:#fff;cursor:pointer;font-weight:600;white-space:nowrap}.projects-table .col-no{white-space:nowrap;width:130px}.projects-table .col-title{width:auto}.projects-table .col-period{width:200px}.project-row{border-bottom:1px solid #f0f0f0;transition:background-color .2s ease}.project-row:hover{background-color:#f8f9fa}.project-row:last-child{border-bottom:none}.projects-table td{padding:1rem;vertical-align:middle}.project-no{color:#757575;font-weight:500;text-align:center;white-space:nowrap}.project-title{max-width:0;width:100%}.project-thumbnail{align-items:center;background:#f5f5f5;border:1px solid #e0e0e0;border-radius:6px;display:flex;flex-shrink:0;height:100px;justify-content:center;overflow:hidden;position:relative;width:100px}.project-image{border-radius:3px;height:100%;object-fit:cover;width:100%}.thumbnail-placeholder{color:#9e9e9e;font-size:2.5rem;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.title-text{flex:1 1;min-width:0}.title-text h4{color:#333;font-size:1.1rem;font-weight:500;line-height:1.4;margin:0;overflow-wrap:break-word;word-break:break-word}.ongoing-badge{align-self:center;background:#e3f2fd;border-radius:12px;color:#1976d2;display:inline-block;font-size:.75rem;font-weight:700;margin-top:.3rem;padding:.2rem .7rem}.project-period{color:#757575;font-size:.9rem;text-align:center;white-space:nowrap}.period-content{align-items:center;display:flex;flex-direction:column;gap:0}.date-text{color:#757575;display:inline-block;font-size:.9rem;line-height:1}.projects-table td.project-period{padding-bottom:.4rem;padding-top:.4rem}.pagination-container{display:flex;justify-content:center;margin-top:2rem}.pagination{gap:.5rem}.page-btn,.pagination{align-items:center;display:flex}.page-btn{background:#fff;border:1px solid #4472c4;border-radius:4px;color:#4472c4;cursor:pointer;font-size:.9rem;height:36px;justify-content:center;min-width:36px;padding:.5rem .75rem;transition:all .2s ease}.page-btn.active,.page-btn:hover:not(:disabled){background-color:#4472c4;border-color:#4472c4;color:#fff}.page-btn:disabled{background-color:#f5f5f5;border-color:silver;color:#999;cursor:not-allowed}.next-btn,.prev-btn{font-size:1.1rem;font-weight:700}@media (max-width:768px){.projects-container{padding:1rem 0}.projects-header{gap:.75rem;grid-template-columns:1fr}.projects-info{width:100%}.projects-controls{justify-content:flex-start;width:100%}.items-per-page-select{width:100%}.projects-table{font-size:.8rem}.projects-table td,.projects-table th{padding:.75rem .5rem}.title-content{align-items:flex-start;flex-direction:column;gap:.5rem}.project-thumbnail{height:75px;width:75px}.thumbnail-placeholder{font-size:1.9rem}.title-text h4{font-size:.95rem}.projects-table .col-no{width:60px}.projects-table .col-period{width:140px}.project-period{font-size:.8rem}.pagination{gap:.25rem}.page-btn{font-size:.8rem;height:32px;min-width:32px;padding:.4rem .6rem}}@media (max-width:480px){.projects-tabs{flex-direction:column}.tab-button{padding:.75rem 1rem;text-align:left}.title-content{gap:.75rem}.project-thumbnail{height:68px;width:68px}.thumbnail-placeholder{font-size:1.7rem}.title-text h4{font-size:.9rem;line-height:1.3}.ongoing-badge{font-size:.7rem;padding:.15rem .4rem}}.gantt-root{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overscroll-behavior:contain;padding:.5rem .75rem .75rem}.gantt-header{border-bottom:1px solid #e0e0e0;padding:.25rem 0}.gantt-year-strip{height:20px;position:relative}.gantt-year-label{color:#777;font-size:12px;position:absolute;top:0;transform:translateX(-50%)}.gantt-controls{display:flex;gap:6px}.gantt-btn{background:#fff;border:1px solid #c9d1e3;border-radius:14px;color:#334;cursor:pointer;font-size:12px;padding:4px 10px}.gantt-btn:hover{background:#f2f5fb}.gantt-btn.active{background:#4472c4;border-color:#4472c4;color:#fff}.gantt-left{align-items:center;border-right:1px solid #e0e0e0;color:#333;display:flex;font-weight:600;padding:0 .5rem}.gantt-right{position:relative}.gantt-scroll{overflow-x:auto;overflow-y:hidden;overscroll-behavior:contain;white-space:nowrap}.gantt-scroll::-webkit-scrollbar{height:10px}.gantt-scroll::-webkit-scrollbar-track{background:#f1f1f1}.gantt-scroll::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:5px}.gantt-track{position:relative}.gantt-row{align-items:center;display:flex;padding:0 .5rem}.gantt-row,.gantt-row-bg{border-bottom:1px solid #f1f1f1}.gantt-row-bg{background:#f9fafc;left:0;position:absolute;right:0}.gantt-label{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#444;display:-webkit-box;font-weight:500;line-height:1.2;overflow:hidden;text-overflow:ellipsis}.gantt-tick,.gantt-tick-body{position:absolute;top:0}.gantt-tick-label,.gantt-tick-line{display:none}.gantt-tick-body{background:#c9d1e3;bottom:0;top:0;width:2px}.gantt-tick-body.minor{background:#e2e6ef;width:1px}.gantt-bar{background:linear-gradient(90deg,#4472c4,#6495ed);border-radius:6px;box-shadow:0 1px 2px #00000026;cursor:pointer;position:absolute;transition:transform .08s ease,filter .08s ease,box-shadow .08s ease,outline-color .08s ease}.gantt-bar:hover{box-shadow:0 2px 6px #00000040;filter:brightness(1.12);outline:2px solid #4472c480;transform:translateY(-1px);z-index:3}.gantt-bar.completed{background:linear-gradient(90deg,#9ea7b3,#c0c6cf)}.gantt-legend .dot.completed{background:#9ea7b3}.gantt-footer{align-items:center;display:flex;gap:1rem;padding:.5rem .25rem 0}.gantt-slider{width:100%}.gantt-legend{color:#555;font-size:.85rem;white-space:nowrap}.gantt-legend .dot{background:#4472c4;border-radius:50%;display:inline-block;height:10px;margin-right:6px;width:10px}.gantt-tooltip{background:#000c;border-radius:4px;color:#fff;font-size:12px;line-height:1.3;padding:6px 8px;pointer-events:none;position:absolute;white-space:pre;z-index:5}.gantt-tooltip.bottom:after,.gantt-tooltip.top:after{border:6px solid #0000;content:"";height:0;position:absolute;width:0}.gantt-tooltip.top:after{border-top-color:#000c;bottom:-12px;left:12px}.gantt-tooltip.bottom:after{border-bottom-color:#000c;left:12px;top:-12px}.contact.section{background:#f8f9fa;padding:4rem 0}.contact-header{margin-bottom:3rem;margin-left:280px;text-align:center;width:calc(100% - 280px)}.contact-header h2{color:#2c3e50;font-size:2.5rem;font-weight:600;margin-bottom:1rem}.contact-header p{color:#7f8c8d;font-size:1.2rem;margin:0}.map-section{display:flex;justify-content:center;margin-bottom:3rem;padding:0 1rem}.map-container{border-radius:15px;box-shadow:0 10px 30px #0000001a;height:500px;margin-left:280px;overflow:hidden;width:809px}.info-container{margin-bottom:3rem;margin-left:280px;padding:0 1rem;width:calc(100% - 280px)}.info-row{display:flex;gap:2rem;justify-content:center;margin:0 auto;max-width:809px}.address-section{flex:1 1;max-width:388px}.address-card{align-items:center;background:#fff;border-radius:15px;box-shadow:0 5px 20px #0000001a;display:flex;height:100%;justify-content:center;padding:2rem}.address-content{text-align:center;width:100%}.address-content h3{color:#2c3e50;font-size:1.5rem;font-weight:600;margin:0 0 1rem;text-align:center}.address-text{color:#7f8c8d;font-size:1.1rem;line-height:1.6;margin:0;text-align:center}.contact-section{flex:1 1;max-width:388px}.contact-card{align-items:center;background:#fff;border-radius:15px;box-shadow:0 5px 20px #0000001a;display:flex;height:100%;justify-content:center;padding:2rem}.contact-content{text-align:center;width:100%}.contact-content h3{color:#2c3e50;font-size:1.5rem;font-weight:600;margin:0 0 1.5rem;text-align:center}.contact-info{display:flex;flex-direction:column;gap:1rem}.contact-item{align-items:center;display:flex;gap:1rem;justify-content:center}.contact-icon{flex-shrink:0;font-size:2rem}.contact-details{text-align:center}.contact-details h4{color:#2c3e50;font-size:1.2rem;font-weight:600;margin:0 0 .5rem}.contact-text{margin:0}.contact-link{color:#3498db;font-size:1.1rem;font-weight:500;text-decoration:none;transition:color .3s ease}.contact-link:hover{color:#2980b9;text-decoration:underline}@media (max-width:1024px){.contact-header{margin-left:250px;width:calc(100% - 250px)}.map-container{margin-left:250px;width:750px}.info-container{margin-left:250px;width:calc(100% - 250px)}.info-row{max-width:750px}.address-section,.contact-section{max-width:350px}}@media (max-width:768px){.contact.section{padding:2rem 0}.contact-header{margin-left:0;width:100%}.contact-header h2{font-size:2rem}.contact-header p{font-size:1rem}.map-container{height:400px;margin-left:0;max-width:647px;width:100%}.info-container{margin-left:0;padding:0 1rem;width:100%}.info-row{flex-direction:column;gap:1.5rem;margin:0 auto;max-width:647px}.address-section,.contact-section{max-width:100%}.address-card,.contact-card{flex-direction:column;margin-left:0;padding:1.5rem;text-align:center;width:100%}.address-content h3,.contact-content h3{font-size:1.3rem}.address-text{font-size:1rem}.contact-item{flex-direction:column;gap:.5rem}.contact-icon{font-size:1.8rem}.contact-details h4{font-size:1.1rem}.contact-link{font-size:1rem}}.professor-section{background:#f8fafc;padding:40px 0 80px}.professor-container{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:1fr;margin:0 auto;max-width:1200px;padding:0 2rem}.professor-profile{grid-gap:2rem;align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 10px #00000014;display:grid;gap:2rem;grid-template-columns:auto 1fr;height:fit-content;padding:2.5rem;position:static;top:auto}.professor-image{margin:0;text-align:center}.profile-placeholder{align-items:center;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:12px;box-shadow:0 8px 25px #3b82f64d;color:#fff;display:flex;font-size:9.2rem;height:440px;justify-content:center;margin:0 auto;width:440px}.profile-photo{border-radius:12px;display:block;height:100%;object-fit:cover;width:100%}.professor-info h2{color:#1e293b;font-size:3.3rem;font-weight:700;margin-bottom:.5rem;text-align:left}.professor-info .title{color:#64748b;font-size:1.3rem;line-height:1.5;margin-bottom:2rem;text-align:left}.contact-info{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1.5rem}.contact-info p{align-items:flex-start;color:#475569;display:flex;font-size:1.05rem;gap:.75rem;line-height:1.6;margin-bottom:1rem}.contact-info p:last-child{margin-bottom:0}.contact-info strong{color:#1e40af;flex-shrink:0;font-size:.95rem;font-weight:600;min-width:50px}.contact-info .icon{color:#64748b;flex-shrink:0;height:16px;margin-top:2px;width:16px}.contact-info .address{font-size:.9rem;line-height:1.4;overflow-wrap:break-word;word-break:keep-all}.professor-details{display:flex;flex-direction:column;gap:1.5rem;padding-bottom:1rem}.detail-section{background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 1px 3px #0000000d;padding:2rem;position:relative}.detail-section h3{align-items:center;border-bottom:2px solid #3b82f6;color:#1e293b;display:flex;font-size:1.3rem;font-weight:600;gap:.5rem;margin-bottom:1.5rem;padding-bottom:.75rem}.detail-section h3:before{background:#3b82f6;border-radius:50%;content:"";display:inline-block;height:16px;width:16px}.detail-section ul{list-style:none;margin:0;padding:0}.detail-section li{border-bottom:1px solid #f1f5f9;color:#475569;font-size:.95rem;line-height:1.6;padding:.75rem 0 .75rem 1.25rem;position:relative}.detail-section li:last-child{border-bottom:none}.detail-section li:before{color:#3b82f6;content:"▸";font-weight:700;left:0;position:absolute}.education-section li{color:#475569;font-size:.95rem;padding:.75rem 0;transition:padding-left .2s ease}.education-section li:hover{color:#1e293b;font-weight:500;padding-left:1.5rem}.education-section li:hover:before{color:#1d4ed8}.education-section li:before{transition:transform .2s ease}.experience-section li{align-items:flex-start;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:.75rem 0;transition:all .2s ease}.experience-section li:hover{color:#1e293b;font-weight:500;padding-left:1.5rem}.experience-section li:hover:before{color:#1d4ed8}.experience-section .year{background:#eff6ff;border-radius:6px;color:#1d4ed8;flex-shrink:0;font-size:.9rem;font-weight:600;min-width:100px;padding:.25rem .75rem;text-align:center}.experience-section .position{color:#475569;flex:1 1;font-size:.95rem}.experience-section li:hover .position{color:#1e293b;font-weight:500}.research-section{overflow:visible;padding-bottom:2rem;position:relative}.research-section li{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;color:#374151;display:flex;font-size:.95rem;font-weight:500;line-height:1.4;margin-bottom:.5rem;min-height:3rem;overflow-wrap:break-word;padding:1.25rem 1.5rem 1.25rem 1.25rem;position:relative;transition:padding-left .2s ease,background .2s ease,border-color .2s ease,color .2s ease,box-shadow .2s ease;word-break:keep-all}.research-section li:hover{background:#eff6ff;border-color:#3b82f6;box-shadow:0 4px 12px #3b82f633;color:#1e40af;padding-left:1.5rem;z-index:10}.research-section li:last-child{margin-bottom:0}.research-section li:hover:before{color:#1d4ed8}@media (max-width:1024px){.professor-container{gap:2rem;grid-template-columns:1fr}.professor-profile{position:static}}@media (max-width:768px){.professor-section{padding:40px 0 60px}.professor-container{padding:0 1rem}.professor-profile{gap:1.25rem;grid-template-columns:1fr}.professor-info h2{font-size:2.6rem;text-align:center}.profile-placeholder{font-size:7.6rem;height:330px;width:330px}.professor-info .title{text-align:center}.detail-section{padding:1.5rem}.experience-section li{flex-direction:column;gap:.5rem}.experience-section .year{align-self:flex-start;min-width:auto}.contact-info .address{font-size:.85rem}}.publications.section{background:#fff;min-height:100vh;padding:4rem 0}.publications.section .document-search{margin-left:0;width:100%}.publications.section .container{margin-left:auto;margin-right:auto;max-width:1200px;padding-left:20px;padding-right:20px;width:100%}.publications-header{margin-bottom:2rem;text-align:center}.publications-header h2{color:#2c3e50;font-size:2.5rem;font-weight:600;margin-bottom:1rem}.main-tabs{display:flex;gap:1rem;justify-content:center;margin-bottom:2rem;margin-left:auto;margin-right:auto;max-width:1200px}.main-tab{background:#fff;border:2px solid #ddd;border-radius:25px;color:#7f8c8d;cursor:pointer;font-size:1rem;font-weight:600;min-width:120px;padding:1rem 2rem;transition:all .3s ease}.main-tab:hover{box-shadow:0 4px 12px #3498db33;color:#3498db}.main-tab.active,.main-tab:hover{border-color:#3498db;transform:translateY(-2px)}.main-tab.active{background:#3498db;box-shadow:0 4px 15px #3498db4d;color:#fff}.sub-tabs{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;margin-bottom:3rem;margin-left:auto;margin-right:auto;max-width:1200px;padding-bottom:0}.sub-tab{background:#fff;border:2px solid #e5e7eb;border-radius:9999px;box-shadow:0 1px 2px #0000000a;color:#6b7280;cursor:pointer;font-size:1rem;font-weight:600;min-width:150px;padding:.6rem 1.25rem;transition:background-color .2s ease,border-color .2s ease,color .2s ease,transform .1s ease,box-shadow .2s ease}.sub-tab:hover{background:#e74c3c0f;border-color:#f1b4ac;box-shadow:0 2px 8px #e74c3c26;color:#e74c3c;transform:translateY(-1px)}.sub-tab.active{background:#e74c3c;border-color:#e74c3c;box-shadow:0 4px 12px #e74c3c40;color:#fff;transform:translateY(-1px)}.sub-tab:focus-visible{box-shadow:0 0 0 3px #e74c3c40;outline:none}.publications-table-container{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem;margin-left:auto;margin-right:auto;max-width:1200px;overflow:hidden}.publications-table{border-collapse:collapse;font-size:.9rem;width:100%}.publications-table thead{background-color:#4472c4}.publications-table th{border-bottom:1px solid #e0e0e0;color:#fff;font-weight:600;padding:1rem;text-align:center}.publications-table .col-no{width:80px}.publications-table .col-title{width:auto}.publications-table .col-download{white-space:nowrap;width:160px}.publication-row{border-bottom:1px solid #f0f0f0;transition:background-color .2s ease}.publication-row:hover{background-color:#f8f9fa}.publication-row:last-child{border-bottom:none}.publications-table td{padding:1rem;vertical-align:middle}.download-cell{min-width:160px;text-align:center}.download-btn-edu{align-items:center;background:#27ae60;border-radius:9999px;color:#fff;display:inline-flex;font-weight:600;height:36px;justify-content:center;min-width:120px;padding:0 1rem;text-decoration:none;transition:background-color .2s ease,box-shadow .2s ease;white-space:nowrap}.download-btn-edu:hover{background:#229954;box-shadow:0 2px 8px #27ae604d}.no-download{color:#b0b0b0}.edu-search-container{align-items:center;display:flex;gap:.75rem;justify-content:center;margin-left:auto;margin-right:auto;margin-top:1.5rem;max-width:600px}.edu-search-select{background:#fff;color:#34495e;font-weight:600;padding:0 .75rem}.edu-search-input,.edu-search-select{border:2px solid #e0e0e0;border-radius:8px;box-sizing:border-box;font-size:1rem;height:44px}.edu-search-input{flex:1 1;min-width:0;outline:none;padding:0 1rem;transition:border-color .2s ease}.edu-search-input:focus{border-color:#3498db}.edu-search-btn{background:#3498db;border:none;border-radius:8px;box-sizing:border-box;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;height:44px;min-width:auto;padding:0 1.2rem;transition:background-color .15s ease,transform .1s ease}.edu-search-btn:hover{background:#2980b9}.edu-search-btn:active{transform:translateY(1px)}.publication-no{color:#757575;font-weight:500;text-align:center}.publication-title{max-width:0;width:100%}.title-content{gap:1rem;width:100%}.publication-thumbnail,.title-content{align-items:center;display:flex;position:relative}.publication-thumbnail{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:6px;flex-shrink:0;height:100px;justify-content:center;overflow:hidden;width:100px}.publication-thumbnail .thumbnail-placeholder{color:#9e9e9e;font-size:2.5rem}.publication-info{display:flex;flex:1 1;flex-direction:column;gap:.5rem;min-width:0;text-align:left}.publication-meta{align-items:center;color:#757575;display:flex;font-size:.8rem;line-height:1.2;text-align:left}.journal-name{color:#757575;font-weight:500}.separator{color:#ccc;margin:0 .3rem}.year-text{color:#757575;font-weight:500}.publication-title-text{text-align:left}.publication-title-text h4{color:#333;font-size:1.1rem;font-weight:500;line-height:1.4;margin:0;overflow-wrap:break-word;text-align:left;word-break:break-word}.publication-authors{color:#757575;font-size:.9rem;font-style:italic;line-height:1.3;text-align:left}.hover-arrow{align-items:center;bottom:0;display:flex;opacity:0;position:absolute;right:0;top:0;transition:all .3s ease;visibility:hidden}.publication-row:hover .hover-arrow{opacity:1;visibility:visible}.link-button{align-items:center;background:#4472c4;border:none;border-left:1px solid #fff3;border-radius:0 8px 8px 0;box-shadow:-2px 0 8px #4472c44d;color:#fff;cursor:pointer;display:flex;font-size:.8rem;height:100%;justify-content:center;position:relative;transition:all .2s ease;width:8px}.link-button:before{content:"▶";opacity:0;position:absolute;transition:opacity .2s ease}.link-button:hover:before{opacity:1}.link-button:hover{background:#365aa0;border-left:2px solid #ffffff4d;box-shadow:-4px 0 12px #4472c466;width:16px}.no-data{color:#9e9e9e;font-style:italic;padding:3rem 1rem;text-align:center}@media (max-width:1024px){.publications.section .container{width:100%}.main-tabs,.publications-table-container,.sub-tabs{margin-left:auto;margin-right:auto;max-width:1000px}}@media (max-width:768px){.publications.section{padding:2rem 0}.publications.section .container{margin-left:0;width:100%}.main-tabs{align-items:center;flex-direction:column;width:100%}.main-tab{max-width:200px;width:100%}.sub-tabs{align-items:center;flex-direction:column;width:100%}.sub-tab{max-width:250px;text-align:center}.publications-table-container,.sub-tab{width:100%}.publications-table{font-size:.8rem}.publications-table td,.publications-table th{padding:.75rem .5rem}.title-content{align-items:flex-start;flex-direction:column;gap:.5rem}.publication-thumbnail{height:75px;width:75px}.publication-thumbnail .thumbnail-placeholder{font-size:1.9rem}.publication-meta{font-size:.75rem}.publication-title-text h4{font-size:.95rem}.publication-authors{font-size:.85rem}.hover-arrow{right:0}.link-button{font-size:.7rem;height:100%;width:6px}.link-button:hover{width:12px}.publications-table .col-no{width:60px}}@media (max-width:480px){.title-content{gap:.75rem}.publication-thumbnail{height:68px;width:68px}.publication-thumbnail .thumbnail-placeholder{font-size:1.7rem}.publication-meta{font-size:.7rem}.publication-title-text h4{font-size:.9rem;line-height:1.3}.publication-authors{font-size:.8rem}.hover-arrow{right:0}.link-button{font-size:.6rem;height:100%;width:5px}.link-button:hover{width:10px}}.document.section{background:#f8f9fa;padding:4rem 0}.document-header{margin-bottom:3rem;margin-left:280px;text-align:center;width:calc(100% - 280px)}.document-header h2{color:#2c3e50;font-size:2.5rem;font-weight:600;margin-bottom:1rem}.document-header p{color:#7f8c8d;font-size:1.2rem;margin:0}.document-categories{margin-bottom:3rem;margin-left:280px;width:calc(100% - 280px)}.category-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin:0 auto;max-width:1200px}.category-card{background:#fff;border-radius:15px;box-shadow:0 5px 20px #0000001a;cursor:pointer;padding:2rem;text-align:center;transition:transform .3s ease,box-shadow .3s ease}.category-card:hover{box-shadow:0 10px 30px #00000026;transform:translateY(-5px)}.category-icon{font-size:3rem;margin-bottom:1rem}.category-card h3{color:#2c3e50;font-size:1.5rem;font-weight:600;margin:0 0 1rem}.category-card p{color:#7f8c8d;font-size:1rem;line-height:1.6;margin:0 0 1.5rem}.document-count{background:#3498db;border-radius:20px;color:#fff;display:inline-block;font-size:.9rem;font-weight:600;padding:.5rem 1rem}.recent-documents{margin-bottom:3rem;margin-left:280px;width:calc(100% - 280px)}.recent-documents h3{color:#2c3e50;font-size:2rem;font-weight:600;margin-bottom:2rem;text-align:center}.document-list{margin:0 auto;max-width:800px}.document-item{align-items:center;background:#fff;border-radius:10px;box-shadow:0 3px 15px #0000001a;display:flex;justify-content:space-between;margin-bottom:1rem;padding:1.5rem;transition:transform .3s ease}.document-item:hover{transform:translateX(5px)}.document-info{align-items:center;display:flex;flex:1 1;gap:1rem}.document-icon{flex-shrink:0;font-size:2rem}.document-details h4{color:#2c3e50;font-size:1.2rem;font-weight:600;margin:0 0 .5rem}.document-details p{color:#7f8c8d;font-size:1rem;line-height:1.4;margin:0 0 .5rem}.document-date{color:#95a5a6;font-size:.9rem;font-weight:500}.download-btn{background:#27ae60;border:none;border-radius:8px;color:#fff;cursor:pointer;flex-shrink:0;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:background-color .3s ease}.download-btn:hover{background:#229954}.document-search{margin-left:280px;width:calc(100% - 280px)}.document-search h3{color:#2c3e50;font-size:2rem;font-weight:600;margin-bottom:2rem;text-align:center}.search-container{align-items:center;display:flex;gap:1rem;justify-content:center;margin:0 auto;max-width:600px}.search-select{background:#fff;color:#34495e;font-weight:600;padding:0 .75rem}.search-input,.search-select{border:2px solid #e0e0e0;border-radius:10px;box-sizing:border-box;font-size:1rem;height:44px}.search-input{flex:1 1;outline:none;padding:0 1rem;transition:border-color .3s ease}.search-input:focus{border-color:#3498db}.search-btn{background:#3498db;border:none;border-radius:10px;box-sizing:border-box;color:#fff;cursor:pointer;flex-shrink:0;font-size:1rem;font-weight:600;height:44px;padding:0 1.2rem;transition:background-color .3s ease}.search-btn:hover{background:#2980b9}@media (max-width:1024px){.document-categories,.document-header,.document-search,.recent-documents{margin-left:250px;width:calc(100% - 250px)}.category-grid{gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width:768px){.document.section{padding:2rem 0}.document-categories,.document-header,.document-search,.recent-documents{margin-left:0;width:100%}.document-header h2{font-size:2rem}.document-header p{font-size:1rem}.category-grid{gap:1rem;grid-template-columns:1fr}.category-card{padding:1.5rem}.category-icon{font-size:2.5rem}.category-card h3{font-size:1.3rem}.document-search h3,.recent-documents h3{font-size:1.5rem}.document-item{gap:1rem}.document-info,.document-item{flex-direction:column;text-align:center}.search-container{flex-direction:column;gap:1rem}.search-btn,.search-input{width:100%}}.selected-year-photos{margin-left:0;margin-top:40px;padding-left:20px;text-align:center}.year-display{margin-bottom:40px;margin-left:0;text-align:center}.year-number{color:#000;display:block;font-size:2.5rem;font-weight:600;line-height:1;margin:0}.selected-year-title{color:#2c3e50;font-size:2.5rem;font-weight:700;margin-bottom:30px;text-align:left}.no-photos-message{color:#7f8c8d;font-size:1.2rem;padding:60px 20px;text-align:center}.no-photos-message p{margin:0}.album-container{box-sizing:border-box;margin-left:calc(280px + (100% - 280px - min(1200px, calc(100% - 280px)))/2);margin-right:0;margin-top:20px;width:min(1200px,calc(100% - 280px))}.album-inner{margin:0 auto;max-width:1200px}.year-buttons{gap:20px;margin:40px 0;width:100%}.year-button,.year-buttons{display:flex;justify-content:center}.year-button{align-items:center;background:#fff;border:3px solid #3498db;border-radius:30px;color:#3498db;cursor:pointer;font-size:1.4rem;font-weight:700;height:60px;transition:all .3s ease;width:120px}.year-button:hover{background:#3498db;color:#fff;transform:scale(1.1)}.year-button.active{background:#3498db;box-shadow:0 4px 15px #3498db66;color:#fff}.album-photos{padding:20px 0}.album-photo-slider{align-items:center;display:flex;gap:20px;justify-content:center;max-width:1600px;overflow:visible;padding:20px 80px;position:relative;width:100%}.album-photos-container{display:flex;gap:20px;margin-left:0;padding:0 60px;transition:transform .5s ease}.nav-button{align-items:center;background:#fff;border:2px solid #3498db;border-radius:50%;color:#3498db;cursor:pointer;display:flex;flex-shrink:0;font-size:1.3rem;font-weight:700;height:45px;justify-content:center;position:absolute;transition:all .3s ease;width:45px;z-index:10}.nav-button:hover{background:#3498db;color:#fff;transform:scale(1.1)}.prev-button{left:20px}.next-button{right:20px}.album-photo-item{display:flex;flex-direction:column;flex-shrink:0;gap:15px;max-width:450px;min-width:400px;text-align:center}.album-photo-item img{border-radius:12px;box-shadow:0 8px 25px #00000026;height:300px;object-fit:cover;transition:transform .3s ease;width:100%}.album-photo-item img:hover{transform:scale(1.02)}.album-photo-caption{background:#0000;border:none;min-height:60px;padding:0}.album-photo-caption p{word-wrap:break-word;color:#2c3e50;font-size:1rem;font-weight:400;line-height:1.4;margin:0;overflow-wrap:break-word;padding:0 15px;text-align:center}.album-header{box-sizing:border-box;margin-bottom:1rem;margin-left:280px;text-align:center;width:calc(100% - 280px)}.album-header h2{color:#2c3e50;font-size:2.5rem;font-weight:600;margin:0}@media (max-width:1200px){.album-header{margin-left:350px;width:calc(100% - 350px)}.album-container{margin-left:calc(350px + (100% - 350px - min(1200px, calc(100% - 350px)))/2);margin-right:0;padding:0 20px;width:min(1200px,calc(100% - 350px))}}.featured-slider{margin:60px 0;text-align:center;width:100%}.pages-section{padding-bottom:40px;padding-top:120px}.slider-header{margin-bottom:40px}.slider-header h3{color:#2c3e50;font-size:2.5rem;margin-bottom:10px}.slider-header p{color:#7f8c8d;font-size:1.1rem}.slider-container{justify-content:center;margin:40px 0;overflow:visible;position:relative;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.slide-controls,.slider-container{align-items:center;display:flex;padding:0 12px}.slide-controls{bottom:0;justify-content:space-between;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:20}.slider-nav{-webkit-text-stroke:1.2px #0000008c;align-items:center;background:#0000;border:none;border-radius:0;box-shadow:none;color:#fff;cursor:pointer;display:flex;font-size:clamp(2.2rem,5vw,6rem);font-weight:100;height:auto;justify-content:center;padding:clamp(6px,1.2vw,14px);pointer-events:auto;text-shadow:0 1px 2px #00000073,0 0 6px #00000059;transition:color .2s ease,transform .2s ease;width:auto;z-index:10}.slider-nav:hover{background:#0000;color:#fff;transform:none}.slider-nav.prev{left:0}.slider-nav.next,.slider-nav.prev{position:absolute;top:50%;transform:translateY(-50%)}.slider-nav.next{right:0}.slider-content{aspect-ratio:16/9;background:#000;border-radius:14px;box-shadow:0 15px 35px #0003;cursor:grab;max-width:1200px;overflow:hidden;position:relative;transition:transform .3s ease;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;width:100%}.slider-content:active{cursor:grabbing}.slider-content.dragging{transition:none}.slider-content.dragging .slide-item{transition:none!important}.slide-item{background:#000;transition:transform .8s cubic-bezier(.25,.46,.45,.94)}.slide-item-inner{cursor:pointer;pointer-events:auto}.slide-item img{-webkit-user-drag:none;-khtml-user-drag:none;-moz-user-drag:none;-o-user-drag:none;pointer-events:none}.slide-item{box-sizing:border-box;width:100%}.slide-item,.slide-item-inner{display:flex;height:100%;position:relative}.slide-item-inner{align-items:center;background:#000;flex:0 0 100%;justify-content:center;max-width:100%;overflow:hidden}.slide-item img{background:#000;border-radius:0;display:block;height:100%;object-fit:contain;width:100%}.slide-info{background:linear-gradient(#0000,#000c);bottom:0;color:#fff;left:0;padding:40px 30px 30px;position:absolute;right:0;text-align:left}.slide-info h4{font-size:1.5rem;font-weight:600;margin-bottom:10px}.slide-date{font-size:1rem;opacity:.9}.slider-indicators{display:flex;gap:6px;justify-content:center;margin-top:30px}.indicator{background:#ddd;border-radius:3px;cursor:pointer;height:6px;transition:all .3s ease;width:20px}.indicator.active{background:#3498db;border-radius:3px;height:6px;transform:none;width:32px}.post-back-btn{align-items:center;background:#ffffffeb;border:1px solid #00000047;border-radius:9999px;box-shadow:none;color:#2c3e50;cursor:pointer;display:inline-flex;padding:8px 14px;transition:background-color .2s ease,transform .12s ease,box-shadow .2s ease,color .2s ease}.post-back-arrow{color:#4b5563;font-size:1rem;margin-right:10px}.post-back-primary{border-bottom:none;display:inline-block;margin-right:6px;padding-bottom:0}.post-back-btn:hover{background:#f3f4f6;color:#111827}.post-back-btn:active{transform:translateY(1px)}.post-back-floating{left:12px;pointer-events:auto;position:absolute;top:-56px;z-index:30}.post-topbar{align-items:center;display:flex;margin:0 auto 12px calc(50% - 590px);max-width:1000px}.post-header{margin:0 auto 24px;max-width:1000px;text-align:center}.post-yearline{align-items:center;color:#6b7280;display:flex;font-size:.95rem;gap:8px;justify-content:center;margin-bottom:6px}.post-sep{color:#9ca3af}.post-title{color:#111827;font-size:2rem;font-weight:700;margin:0 0 8px}.post-meta{color:#6b7280;font-size:.95rem}.post-divider{background:#e5e7eb;height:1px;margin:16px 0 0}.post-description{color:#4b5563;font-size:1rem;line-height:1.6;margin:12px auto 16px;max-width:1000px}.album-grid{margin:80px 0;width:100%}.grid-header{margin-bottom:50px;text-align:center}.grid-header h3{color:#2c3e50;font-size:2.2rem;margin-bottom:15px}.grid-header p{color:#7f8c8d;font-size:1.1rem}.photo-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(3,1fr);margin:0 auto;max-width:1200px;position:relative}.photo-item-container{display:flex;flex-direction:column;padding-bottom:16px;position:relative}.photo-item-container,.photo-item-container:active,.photo-item-container:hover,.photo-item-container:link,.photo-item-container:visited{color:inherit;text-decoration:none}.photo-item-container:after{background:#6b7280;bottom:0;content:"";height:2px;left:0;position:absolute;right:0}.grid-photo-item{border-radius:12px;box-shadow:0 8px 25px #00000026;margin-bottom:0;overflow:hidden;position:relative;transition:transform .3s ease}.grid-photo-item:hover{transform:translateY(-10px)}.grid-photo-item img{border-radius:inherit;display:block;height:250px;object-fit:cover;width:100%}.photo-caption{background:#0000;border:none;color:#2c3e50;margin-bottom:0;margin-top:0;padding:0;position:relative;text-align:center}.photo-caption h4{color:#2c3e50;font-size:1.2rem;font-weight:600;margin:0;text-decoration:none}@media (max-width:768px){.album-inner>h2{font-size:2rem}.album-header{margin-left:0;width:100%}.album-header,.album-header h2,.selected-year-title{text-align:center}.album-container,.selected-year-photos{margin-left:0}.pages-section{padding-top:calc(84px + env(safe-area-inset-top, 0))!important;padding-top:calc(var(--mobile-header-height, 72px) + env(safe-area-inset-top, 0) + 12px)!important}.year-buttons{gap:15px}.year-button{border-radius:27.5px;font-size:1.1rem;height:55px;width:90px}.year-number{font-size:2.5rem}.selected-year-title{font-size:2rem}.album-photo-item{max-width:320px;min-width:280px}.album-photo-item img{height:200px}.nav-button{font-size:1.2rem;height:40px;width:40px}.album-photos-container{gap:30px;padding:0 40px}.album-photo-slider{max-width:100%;padding:20px 50px}.slider-header h3{font-size:2rem}.album-container{max-width:100%;padding:0 20px}.album-container,.album-grid,.featured-slider,.pages-section h2,.year-buttons{margin-left:0;width:100%}.slide-controls{bottom:0;left:0;pointer-events:none;right:0;top:0}.slider-nav{background:#0000;border-radius:0;font-size:clamp(1.8rem,8vw,3.6rem);height:auto;padding:clamp(6px,1.5vw,12px);width:auto}.slider-nav.prev{left:-24px}.slider-nav.next{right:-24px}.slide-item{width:100%}.slide-item-inner{min-width:100%}.slide-item img{height:350px}.slide-info{padding:30px 20px 20px}.slide-info h4{font-size:1.3rem}.photo-grid{gap:20px;grid-template-columns:repeat(2,1fr);padding:0 20px}.grid-photo-item img{height:200px}.photo-caption{border-bottom:none;margin-bottom:0;margin-top:10px;padding:8px 0 15px}.post-topbar{justify-content:flex-start;margin:0 0 12px;max-width:100%;padding:0 12px}.post-back-btn{font-size:.95rem;left:12px;padding:8px 12px;position:fixed;top:calc(96px + env(safe-area-inset-top, 0));top:calc(var(--mobile-header-height, 72px) + env(safe-area-inset-top, 0) + 24px);z-index:2000}}@media (max-width:360px){.post-topbar{margin:0 0 10px;padding:0 8px}.post-back-btn{font-size:.9rem;left:10px;padding:6px 10px;position:fixed;top:calc(188px + env(safe-area-inset-top, 0));top:calc(var(--mobile-header-height, 72px) + env(safe-area-inset-top, 0) + 116px);z-index:2000}.post-back-arrow{margin-right:8px}.post-back-primary{margin-right:4px}.pages-section{padding-top:calc(84px + env(safe-area-inset-top, 0))!important;padding-top:calc(var(--mobile-header-height, 72px) + env(safe-area-inset-top, 0) + 12px)!important}.post-header{margin-top:32px}}@media (max-width:420px) and (min-width:361px){.pages-section{padding-top:calc(80px + env(safe-area-inset-top, 0))!important;padding-top:calc(var(--mobile-header-height, 68px) + env(safe-area-inset-top, 0) + 12px)!important}.post-back-btn{left:12px;position:fixed;top:calc(180px + env(safe-area-inset-top, 0));top:calc(var(--mobile-header-height, 68px) + env(safe-area-inset-top, 0) + 112px);z-index:2000}.post-header{margin-top:28px}}
/*# sourceMappingURL=main.829d6c82.css.map*/