.header{z-index:100;background-color:#fff;padding:1rem 0;position:sticky;top:0;box-shadow:0 2px 8px #00000014}.header-container{justify-content:space-between;align-items:center;width:100%;padding:0 3rem;display:flex}.header-brand{color:inherit;align-items:center;text-decoration:none;display:flex}.header-logo{width:auto;height:48px;display:block}.header-brand h1{color:#324b72;margin:0;font-size:1.5rem;font-weight:700}.nav{align-items:center;gap:2.5rem;display:flex}.nav a{color:#333;font-weight:500;text-decoration:none;transition:color .3s}.nav a:hover{color:#324b72}.nav a.nav-active{color:#324b72;font-weight:600}@media (width<=768px){.header-logo{height:40px}.header-brand h1{font-size:1.25rem}.nav{flex-direction:column;gap:1rem}}.footer{color:#e0e0e0;background-color:#1a1a1a;padding:4rem 1rem 2rem}.footer-container{max-width:1200px;margin:0 auto}.footer-content{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:3rem;margin-bottom:2rem;display:grid}.footer-section h3,.footer-section h4{color:#fff;margin-bottom:1rem}.footer-section h3{font-size:1.4rem}.footer-section h4{text-transform:uppercase;font-size:1rem}.footer-section p{margin:.5rem 0;line-height:1.6}.footer-section a{color:#e0e0e0;text-decoration:none;transition:color .3s}.footer-section a:hover{color:#324b72}.footer-section ul{margin:0;padding:0;list-style:none}.footer-section ul li{margin-bottom:.8rem}.footer-bottom{text-align:center;color:#999;border-top:1px solid #ffffff1a;padding-top:1.5rem;font-size:.9rem}@media (width<=768px){.footer-content{grid-template-columns:repeat(2,1fr);gap:2rem}}@media (width<=480px){.footer-content{grid-template-columns:1fr;gap:1.5rem}.footer-section{text-align:center}.footer-section ul{text-align:left;display:inline-block}}.hero{background-color:#f8f7f5;align-items:center;height:calc(100dvh - 260px);min-height:420px;max-height:780px;padding:2rem 1rem;display:flex}.carousel{background:#ddd;border-radius:8px;width:100%;max-width:1200px;height:100%;margin:0 auto;overflow:hidden}.slide-images{gap:4px;width:100%;height:100%}.slide-desktop{display:flex}.slide-mobile{display:none}.hero-slot{background:#c8c8c8;flex:1;min-width:0;height:100%;position:relative;overflow:hidden}.hero-photo{object-fit:cover;opacity:0;will-change:opacity, transform;width:100%;height:100%;transition:opacity .9s cubic-bezier(.4,0,.2,1),transform .9s cubic-bezier(.4,0,.2,1);position:absolute;inset:0;transform:scale(1.04)}.hero-photo.is-visible{opacity:1;z-index:1;transform:scale(1)}@media (width<=768px){.hero{height:auto;min-height:unset;max-height:unset;padding:.5rem}.carousel{height:auto}.slide-desktop{display:none}.slide-mobile{grid-template-columns:1fr 1fr;display:grid}.slide-mobile .hero-slot{aspect-ratio:1;height:auto;position:relative}}@media (width<=480px){.hero{height:auto;min-height:unset;max-height:unset;padding:.25rem}}@media (prefers-reduced-motion:reduce){.hero-photo{transition:opacity .2s;transform:none}.hero-photo.is-visible{transform:none}}.about{color:#fff;background:linear-gradient(135deg,#1a1a1a 0%,#2d2d2d 100%);padding:2.5rem 1rem 6rem}.about-container{max-width:1200px;margin:0 auto}.about-content{text-align:center;max-width:900px;margin:0 auto}.about-title{letter-spacing:1px;flex-wrap:wrap;justify-content:center;align-items:center;gap:.2rem;min-height:120px;margin-bottom:2rem;font-size:3rem;font-weight:700;line-height:1.2;display:flex}.char{opacity:0;animation:2s cubic-bezier(.34,1.56,.64,1) forwards fadeInLetter;animation-delay:calc(var(--delay,0) * 1s);display:inline-block}@keyframes fadeInLetter{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.about-description{color:#e0e0e0;text-align:justify;margin-bottom:3rem;font-size:1.1rem;line-height:1.8}.about-button{color:#e0e0e0;cursor:pointer;text-transform:uppercase;letter-spacing:1px;background-color:#324b72;border:none;border-radius:4px;padding:1rem 2.5rem;font-size:1rem;font-weight:600;transition:all .3s}.about-button:hover{background-color:#3d5a8a;transform:translateY(-2px);box-shadow:0 8px 16px #324b724d}.about-button:active{transform:translateY(0)}@media (width<=768px){.about{padding:2rem 1rem 4rem}.about-title{min-height:80px;font-size:2rem}.about-description{text-align:center;font-size:1rem}}@media (width<=480px){.about{padding:1.5rem 1rem 3rem}.about-title{min-height:60px;font-size:1.5rem}.about-description{font-size:.95rem}.about-button{padding:.8rem 1.5rem;font-size:.9rem}}.projects{background-color:#fff;padding:5rem 1rem;overflow:visible}.projects-container{max-width:1200px;margin:0 auto;overflow:visible}.projects-container h2{text-align:center;color:#1a1a1a;margin-bottom:3rem;font-size:2.5rem;font-weight:700}.projects-grid{grid-template-columns:repeat(3,1fr);gap:2rem;display:grid;overflow:visible}.project-card{cursor:pointer;color:inherit;background:#fff;border-radius:8px;text-decoration:none;transition:transform .3s,box-shadow .3s;display:block;position:relative;overflow:hidden;box-shadow:0 2px 8px #0000001a}.project-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #324b7226}.project-card img{aspect-ratio:4/3;object-fit:cover;width:100%;transition:transform .4s}.project-card:hover img{transform:scale(1.08)}.project-info{background:#f9f9f9;padding:1.5rem}.category{color:#324b72;background:#e8f0f8;border-radius:20px;margin-bottom:.5rem;padding:.35rem .8rem;font-size:.8rem;font-weight:600;display:inline-block}.project-info h3{color:#1a1a1a;margin:0;font-size:1.1rem;transition:color .3s}.project-card:hover .project-info h3{color:#324b72}.projects-more{text-align:center;margin-top:3rem}.projects-more-btn{color:#fff;letter-spacing:.02em;background:#324b72;border-radius:6px;padding:.85rem 2.5rem;font-size:1rem;font-weight:600;text-decoration:none;transition:background .25s,transform .2s,box-shadow .25s;display:inline-block}.projects-more-btn:hover{background:#1a2f4e;transform:translateY(-2px);box-shadow:0 6px 16px #324b7240}@media (width<=768px){.projects-grid{grid-template-columns:repeat(2,1fr)}.projects-container h2{font-size:1.8rem}.projects-grid .project-card:nth-child(n+4){display:none}}@media (width<=480px){.projects-grid{grid-template-columns:1fr}.projects-container h2{font-size:1.5rem}.project-info{padding:1rem}}.contact-page{background-color:#f8f7f5;flex:1}.contact-hero{color:#fff;background:linear-gradient(135deg,#324b72 0%,#3d5a8a 100%);padding:4rem 1rem 3.5rem}.contact-hero-inner{text-align:center;max-width:1200px;margin:0 auto}.contact-hero h1{margin:0 0 .75rem;font-size:2.75rem}.contact-hero p{opacity:.92;margin:0;font-size:1.15rem}.contact-cards{padding:4rem 1rem}.contact-cards-inner{grid-template-columns:repeat(3,1fr);gap:2rem;max-width:1200px;margin:0 auto;display:grid}.contact-card{background:#fff;border-radius:8px;padding:2rem 1.75rem;transition:transform .3s,box-shadow .3s;box-shadow:0 2px 12px #00000014}.contact-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #324b7226}.contact-card-icon{color:#324b72;background:#e8f0f8;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:1.25rem;display:flex}.contact-card-icon svg{width:24px;height:24px}.contact-card h2{color:#324b72;margin:0 0 1rem;font-size:1.25rem}.contact-card p{color:#444;margin:0;line-height:1.7}.contact-card-link{color:#324b72;margin-top:1.25rem;font-weight:600;text-decoration:none;transition:color .3s;display:inline-block}.contact-card-link:hover{color:#3d5a8a}.contact-list{margin:0;padding:0;list-style:none}.contact-list li+li{margin-top:1.25rem}.contact-label{text-transform:uppercase;letter-spacing:.05em;color:#888;margin-bottom:.35rem;font-size:.8rem;font-weight:600;display:block}.contact-list a{color:#1a1a1a;font-weight:500;text-decoration:none;transition:color .3s}.contact-list a:hover{color:#324b72}.contact-social{flex-direction:column;gap:.75rem;margin:1rem 0 0;padding:0;list-style:none;display:flex}.contact-social a{color:#324b72;font-weight:600;text-decoration:none;transition:color .3s}.contact-social a:hover{color:#3d5a8a}.contact-map{padding:0 1rem 4rem}.contact-map-header{text-align:center;max-width:1200px;margin:0 auto 1.5rem}.contact-map-header h2{color:#1a1a1a;margin:0 0 .5rem;font-size:2rem}.contact-map-header p{color:#666;margin:0}.contact-map-frame{aspect-ratio:21/9;background:#ddd;border-radius:8px;max-width:1200px;margin:0 auto;overflow:hidden;box-shadow:0 4px 20px #0000001f}.contact-map-frame iframe{border:0;width:100%;height:100%;display:block}@media (width<=900px){.contact-cards-inner{grid-template-columns:1fr;max-width:480px}.contact-card{text-align:center}.contact-card-icon{margin-left:auto;margin-right:auto}.contact-list{text-align:center;display:inline-block}.contact-label{text-align:center}.contact-social{align-items:center}}@media (width<=768px){.contact-hero h1{font-size:2rem}.contact-map-frame{aspect-ratio:4/3}}.about-page{background-color:#f8f7f5;flex:1}.ap-hero{color:#fff;background:linear-gradient(135deg,#1a1a1a 0%,#2d2d2d 60%,#324b72 100%);padding:5rem 1rem 4rem}.ap-hero-inner{max-width:1200px;margin:0 auto}.ap-hero-tag{letter-spacing:.12em;text-transform:uppercase;color:#7aa3cc;margin-bottom:1.25rem;font-size:.8rem;font-weight:600;display:inline-block}.ap-hero h1{max-width:600px;margin:0 0 1.25rem;font-size:clamp(2rem,5vw,3.5rem);line-height:1.15}.ap-hero p{color:#ccc;max-width:480px;margin:0;font-size:1.1rem;line-height:1.7}.ap-company{padding:5rem 1rem}.ap-company-inner{grid-template-columns:1fr 380px;align-items:start;gap:4rem;max-width:1200px;margin:0 auto;display:grid}.ap-company-text h2{color:#1a1a1a;margin:0 0 1.5rem;padding-bottom:1rem;font-size:2rem;position:relative}.ap-company-text h2:after{content:"";background:#324b72;border-radius:2px;width:48px;height:3px;position:absolute;bottom:0;left:0}.ap-company-text p{color:#555;margin:0 0 1.25rem;font-size:1rem;line-height:1.85}.ap-company-text p:last-child{margin-bottom:0}.ap-stats{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid;position:sticky;top:100px}.ap-stat{text-align:center;background:#fff;border-radius:8px;padding:1.75rem 1.25rem;transition:transform .3s,box-shadow .3s;box-shadow:0 2px 12px #00000012}.ap-stat:hover{transform:translateY(-3px);box-shadow:0 6px 20px #324b7221}.ap-stat-value{color:#324b72;margin-bottom:.5rem;font-size:2.25rem;font-weight:700;line-height:1;display:block}.ap-stat-label{color:#888;font-size:.85rem;font-weight:500}.ap-team{background:#fff;padding:5rem 1rem}.ap-team-inner{max-width:1200px;margin:0 auto}.ap-section-header{text-align:center;margin-bottom:3.5rem}.ap-section-header h2{color:#1a1a1a;margin:0 0 .75rem;padding-bottom:1rem;font-size:2rem;display:inline-block;position:relative}.ap-section-header h2:after{content:"";background:#324b72;border-radius:2px;width:48px;height:3px;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.ap-section-header p{color:#777;margin:0;font-size:1rem}.ap-team-grid{grid-template-columns:repeat(3,1fr);gap:2.5rem;display:grid}.ap-member{text-align:center;cursor:default}.ap-member-photo-wrap{border:3px solid #e8f0f8;border-radius:50%;width:140px;height:140px;margin:0 auto 1.25rem;transition:border-color .3s,transform .3s;overflow:hidden;box-shadow:0 4px 16px #324b721f}.ap-member:hover .ap-member-photo-wrap{border-color:#324b72;transform:translateY(-4px)}.ap-member-photo{object-fit:cover;width:100%;height:100%;display:block}.ap-member-info h3{color:#1a1a1a;margin:0 0 .3rem;font-size:1.05rem}.ap-member-info span{color:#324b72;font-size:.85rem;font-weight:500}@media (width<=1024px){.ap-company-inner{grid-template-columns:1fr;gap:3rem}.ap-stats{max-width:480px;position:static}}@media (width<=768px){.ap-hero{padding:3.5rem 1rem 3rem}.ap-team-grid{grid-template-columns:repeat(2,1fr);gap:2rem}.ap-company,.ap-team{padding:3.5rem 1rem}}@media (width<=480px){.ap-team-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}.ap-member-photo-wrap{width:110px;height:110px}.ap-stats{grid-template-columns:1fr 1fr}}.pd-page{max-width:1200px;margin:0 auto;padding:2rem 3rem 4rem}.pd-breadcrumb{color:#666;align-items:center;gap:.75rem;margin-bottom:2rem;font-size:.9rem;display:flex}.pd-breadcrumb a{color:#324b72;font-weight:500;text-decoration:none;transition:color .2s}.pd-breadcrumb a:hover{color:#1a2f4e}.pd-breadcrumb span:before{content:"/";color:#ccc;margin-right:.75rem}.pd-body{grid-template-columns:1fr 420px;align-items:start;gap:3rem;display:grid}.pd-gallery{flex-direction:column;gap:1rem;display:flex}.pd-main-image{aspect-ratio:4/3;background:#e8e8e8;border-radius:12px;position:relative;overflow:hidden}.pd-main-image img{object-fit:cover;width:100%;height:100%;transition:transform .4s;display:block}.pd-main-image:hover img{transform:scale(1.03)}.pd-status-badge{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#324b72d9;border-radius:20px;padding:.3rem .8rem;font-size:.8rem;font-weight:600;position:absolute;top:1rem;right:1rem}.pd-thumbnails{flex-wrap:wrap;gap:.6rem;display:flex}.pd-thumb{cursor:pointer;background:#e8e8e8;border:2px solid #0000;border-radius:6px;width:80px;height:60px;padding:0;transition:border-color .2s;overflow:hidden}.pd-thumb.active{border-color:#324b72}.pd-thumb img{object-fit:cover;width:100%;height:100%;display:block}.pd-info{flex-direction:column;gap:1.25rem;display:flex}.pd-category{color:#324b72;background:#e8f0f8;border-radius:20px;width:fit-content;padding:.35rem .9rem;font-size:.82rem;font-weight:600;display:inline-block}.pd-title{color:#1a1a1a;margin:0;font-size:2rem;font-weight:700;line-height:1.2}.pd-description{color:#555;margin:0;font-size:1rem;line-height:1.7}.pd-details{border:1px solid #e8e8e8;border-radius:10px;overflow:hidden}.pd-detail-row{border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:.85rem 1.25rem;display:flex}.pd-detail-row:last-child{border-bottom:none}.pd-detail-row:nth-child(2n){background:#fafafa}.pd-detail-label{color:#777;font-size:.88rem;font-weight:500}.pd-detail-value{color:#1a1a1a;text-align:right;font-size:.95rem;font-weight:600}.pd-status-text.done{color:#2e7d32}.pd-status-text.ongoing{color:#e65100}.pd-loading{justify-content:center;align-items:center;min-height:40vh;display:flex}.pd-spinner{border:4px solid #e8f0f8;border-top-color:#324b72;border-radius:50%;width:44px;height:44px;animation:.8s linear infinite pd-spin}@keyframes pd-spin{to{transform:rotate(360deg)}}.pd-not-found{text-align:center;color:#444;padding:6rem 2rem}.pd-not-found h2{margin-bottom:1.5rem}.pd-back{color:#324b72;font-weight:600;text-decoration:none}@media (width<=900px){.pd-page{padding:1.5rem 1.5rem 3rem}.pd-body{grid-template-columns:1fr;gap:2rem}}@media (width<=480px){.pd-page{padding:1rem 1rem 2rem}.pd-title{font-size:1.5rem}}.pp-page{background-color:#f8f7f5;flex:1}.pp-hero{color:#fff;background:linear-gradient(135deg,#1a1a1a 0%,#2d2d2d 60%,#324b72 100%);padding:5rem 1rem 4rem}.pp-hero-inner{max-width:1200px;margin:0 auto;padding:0 3rem}.pp-hero-tag{letter-spacing:.12em;text-transform:uppercase;color:#7aa3cc;margin-bottom:1.25rem;font-size:.8rem;font-weight:600;display:inline-block}.pp-hero h1{margin:0 0 1.25rem;font-size:clamp(2rem,5vw,3.5rem);line-height:1.15}.pp-hero p{color:#ccc;max-width:480px;margin:0;font-size:1.1rem;line-height:1.7}.pp-grid-section{padding:4rem 1rem 6rem}.pp-container{max-width:1200px;margin:0 auto;padding:0 3rem}.pp-grid{grid-template-columns:repeat(3,1fr);gap:2rem;display:grid}.pp-card{color:inherit;background:#fff;border-radius:10px;text-decoration:none;transition:transform .3s,box-shadow .3s;display:block;overflow:hidden;box-shadow:0 2px 8px #00000014}.pp-card:hover{transform:translateY(-5px);box-shadow:0 10px 24px #324b7226}.pp-card-img-wrap{aspect-ratio:4/3;background:#e0e0e0;position:relative;overflow:hidden}.pp-card-img-wrap img{object-fit:cover;width:100%;height:100%;transition:transform .4s;display:block}.pp-card:hover .pp-card-img-wrap img{transform:scale(1.06)}.pp-card-status{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:20px;padding:.25rem .7rem;font-size:.75rem;font-weight:600;position:absolute;top:.75rem;right:.75rem}.pp-card-status.done{color:#fff;background:#2e7d32d9}.pp-card-status.ongoing{color:#fff;background:#e65100d9}.pp-card-info{padding:1.25rem 1.5rem 1.5rem}.pp-card-category{color:#324b72;background:#e8f0f8;border-radius:20px;margin-bottom:.6rem;padding:.3rem .75rem;font-size:.78rem;font-weight:600;display:inline-block}.pp-card-title{color:#1a1a1a;margin:0 0 .6rem;font-size:1.1rem;font-weight:700;transition:color .2s}.pp-card:hover .pp-card-title{color:#324b72}.pp-card-meta{color:#777;justify-content:space-between;font-size:.82rem;display:flex}.pp-loading{justify-content:center;padding:6rem 0;display:flex}.pp-spinner{border:4px solid #e8f0f8;border-top-color:#324b72;border-radius:50%;width:44px;height:44px;animation:.8s linear infinite pp-spin}@keyframes pp-spin{to{transform:rotate(360deg)}}@media (width<=900px){.pp-hero-inner,.pp-container{padding:0 1.5rem}}@media (width<=768px){.pp-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=480px){.pp-hero{padding:3rem 1rem 2.5rem}.pp-grid{grid-template-columns:1fr}.pp-grid-section{padding:2.5rem 1rem 4rem}}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#333;background-color:#fff;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}#root{flex-direction:column;height:100vh;display:flex}.app{flex-direction:column;min-height:100vh;display:flex}main{flex:1;width:100%}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2}p{line-height:1.6}a{color:inherit;text-decoration:none}button{font-family:inherit}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#324b72;border-radius:5px}::-webkit-scrollbar-thumb:hover{background:#3d5a8a}@media (width<=768px){:root{font-size:14px}}@media (width<=480px){:root{font-size:13px}}
