*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}:root{--primary:#0c2d6b;--primary-light:#1e40af;--accent:#c9a84c;--accent-light:#ddc371;--bg:#f8f9fc;--bg-alt:#eef1f8;--card:#ffffff;--text:#1a1a2e;--text-muted:#5a607a;--border:#dfe3ec;--white:#ffffff;--shadow-sm:0 2px 8px rgba(12,45,107,0.06);--shadow-md:0 8px 24px rgba(12,45,107,0.1);--shadow-lg:0 16px 48px rgba(12,45,107,0.12);--radius:12px}html{scroll-behavior:smooth;font-size:16px}body{font-family:'Inter',system-ui,-apple-system,sans-serif;color:var(--text);background:var(--bg);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;font-weight:700;line-height:1.2}img{max-width:100%;height:auto;display:block}a{text-decoration:none;color:inherit}.container{width:100%;max-width:1280px;margin:0 auto;padding:0 1.25rem}@media (min-width:768px){.container{padding:0 2rem}}@media (min-width:1024px){.container{padding:0 2.5rem}}.reveal{opacity:0;transform:translateY(40px);transition:opacity 0.8s cubic-bezier(.22,1,.36,1),transform 0.8s cubic-bezier(.22,1,.36,1)}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:0.1s}.reveal-delay-2{transition-delay:0.2s}.reveal-delay-3{transition-delay:0.3s}.reveal-delay-4{transition-delay:0.4s}.reveal-delay-5{transition-delay:0.5s}.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgb(255 255 255 / .92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid #fff0;transition:all 0.4s ease}.site-header.scrolled{background:rgb(255 255 255 / .97);border-bottom-color:var(--border);box-shadow:var(--shadow-sm)}.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px}.logo-link{display:flex;align-items:center;gap:.75rem}.logo-mark{width:44px;height:44px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);border-radius:10px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.logo-mark::after{content:'';position:absolute;top:50%;left:50%;width:18px;height:2px;background:var(--accent);transform:translate(-50%,-50%);border-radius:2px}.logo-mark svg{width:22px;height:22px;fill:var(--white);position:relative;z-index:1}.logo-text{font-family:'Playfair Display',serif;font-weight:800;font-size:1.35rem;color:var(--primary);letter-spacing:-.02em}.logo-text span{color:var(--accent)}.desktop-nav{display:none}@media (min-width:769px){.desktop-nav{display:flex}}.desktop-nav ul{display:flex;list-style:none;gap:.25rem;align-items:center}.desktop-nav a{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:var(--text-muted);border-radius:8px;transition:all 0.25s ease;position:relative}.desktop-nav a:hover{color:var(--primary);background:var(--bg-alt)}.nav-cta-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem!important;background:var(--primary)!important;color:var(--white)!important;border-radius:8px!important;font-weight:600!important;font-size:0.875rem!important;transition:all 0.3s ease!important}.nav-cta-btn:hover{background:var(--primary-light)!important;transform:translateY(-1px);box-shadow:0 4px 12px rgb(12 45 107 / .25)}.mobile-toggle{display:flex;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;border-radius:8px;transition:background 0.2s}.mobile-toggle:hover{background:var(--bg-alt)}@media (min-width:769px){.mobile-toggle{display:none}}.mobile-toggle span{width:22px;height:2px;background:var(--primary);border-radius:2px;transition:all 0.35s cubic-bezier(.22,1,.36,1);transform-origin:center}.mobile-toggle.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.mobile-toggle.open span:nth-child(2){opacity:0;transform:scaleX(0)}.mobile-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.mobile-nav{position:fixed;top:72px;left:0;right:0;bottom:0;background:rgb(255 255 255 / .98);backdrop-filter:blur(20px);display:flex;flex-direction:column;padding:2rem 1.5rem;transform:translateX(100%);transition:transform 0.4s cubic-bezier(.22,1,.36,1);z-index:999}.mobile-nav.open{transform:translateX(0)}@media (min-width:769px){.mobile-nav{display:none!important}}.mobile-nav ul{list-style:none;display:flex;flex-direction:column;gap:.5rem}.mobile-nav a{display:block;padding:1rem;font-size:1.1rem;font-weight:500;color:var(--text);border-radius:10px;transition:all 0.25s}.mobile-nav a:hover{background:var(--bg-alt);color:var(--primary)}.mobile-nav-cta{margin-top:1.5rem;display:block;text-align:center;padding:1rem!important;background:var(--primary)!important;color:var(--white)!important;border-radius:10px!important;font-weight:600!important}.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:var(--primary)}.hero-bg{position:absolute;inset:0;z-index:1}.hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.35}.hero-overlay{position:absolute;inset:0;z-index:2;background:linear-gradient(135deg,rgb(12 45 107 / .92) 0%,rgb(30 64 175 / .7) 50%,rgb(12 45 107 / .85) 100%)}.hero-content{position:relative;z-index:3;padding:8rem 0 5rem;max-width:720px}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:rgb(201 168 76 / .15);border:1px solid rgb(201 168 76 / .3);border-radius:50px;font-size:.85rem;font-weight:600;color:var(--accent-light);margin-bottom:1.5rem;backdrop-filter:blur(4px)}.hero-badge svg{width:16px;height:16px;fill:var(--accent)}.hero h1{font-size:clamp(2.5rem, 5vw, 4rem);color:var(--white);margin-bottom:1.25rem;letter-spacing:-.02em}.hero h1 .accent-text{color:var(--accent-light)}.hero-desc{font-size:1.15rem;color:rgb(255 255 255 / .8);line-height:1.7;margin-bottom:2.5rem;max-width:560px}.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}.btn-primary{display:inline-flex;align-items:center;gap:.5rem;padding:.9rem 2rem;background:var(--accent);color:var(--primary);font-weight:700;font-size:.95rem;border-radius:10px;border:none;cursor:pointer;transition:all 0.3s ease;box-shadow:0 4px 16px rgb(201 168 76 / .3)}.btn-primary:hover{background:var(--accent-light);transform:translateY(-2px);box-shadow:0 8px 24px rgb(201 168 76 / .4)}.btn-primary svg{width:18px;height:18px}.btn-outline{display:inline-flex;align-items:center;gap:.5rem;padding:.9rem 2rem;background:#fff0;color:var(--white);font-weight:600;font-size:.95rem;border-radius:10px;border:2px solid rgb(255 255 255 / .3);cursor:pointer;transition:all 0.3s ease}.btn-outline:hover{border-color:var(--white);background:rgb(255 255 255 / .08)}.hero-floating-stats{position:absolute;bottom:0;left:0;right:0;z-index:3}.hero-stats-bar{display:grid;grid-template-columns:repeat(4,1fr);background:rgb(255 255 255 / .08);backdrop-filter:blur(20px);border-top:1px solid rgb(255 255 255 / .12)}.hero-stat{text-align:center;padding:1.5rem 1rem;border-right:1px solid rgb(255 255 255 / .08);transition:background 0.3s}.hero-stat:last-child{border-right:none}.hero-stat:hover{background:rgb(255 255 255 / .05)}.hero-stat-num{font-family:'Playfair Display',serif;font-size:2rem;font-weight:800;color:var(--accent);line-height:1;margin-bottom:.35rem}.hero-stat-label{font-size:.8rem;color:rgb(255 255 255 / .7);font-weight:500;text-transform:uppercase;letter-spacing:.08em}@media (max-width:640px){.hero-stats-bar{grid-template-columns:repeat(2,1fr)}.hero-stat{padding:1rem .75rem}.hero-stat:nth-child(2){border-right:none}.hero-stat-num{font-size:1.5rem}}.section{padding:5rem 0}.section-alt{background:var(--bg-alt)}.section-dark{background:var(--primary);color:var(--white)}.section-label{display:inline-flex;align-items:center;gap:.5rem;font-size:.8rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.12em;margin-bottom:.75rem}.section-label::before{content:'';width:32px;height:2px;background:var(--accent);border-radius:2px}.section-title{font-size:clamp(1.75rem, 3.5vw, 2.75rem);color:var(--text);margin-bottom:1rem;letter-spacing:-.02em}.section-dark .section-title{color:var(--white)}.section-subtitle{font-size:1.05rem;color:var(--text-muted);max-width:560px;line-height:1.7}.section-dark .section-subtitle{color:rgb(255 255 255 / .7)}.section-header{margin-bottom:3.5rem}.section-header-center{text-align:center}.section-header-center .section-subtitle{margin:0 auto}.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}@media (max-width:1024px){.services-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.services-grid{grid-template-columns:1fr}}.service-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;transition:all 0.4s cubic-bezier(.22,1,.36,1);position:relative;overflow:hidden}.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--accent));transform:scaleX(0);transform-origin:left;transition:transform 0.4s ease}.service-card:hover::before{transform:scaleX(1)}.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:#fff0}.service-icon-wrap{width:52px;height:52px;border-radius:12px;background:var(--bg-alt);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;transition:all 0.3s ease}.service-card:hover .service-icon-wrap{background:var(--primary)}.service-icon-wrap svg{width:24px;height:24px;stroke:var(--primary);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:stroke 0.3s ease}.service-card:hover .service-icon-wrap svg{stroke:var(--white)}.service-card h3{font-size:1.2rem;margin-bottom:.6rem;color:var(--text);font-family:'Inter',sans-serif;font-weight:700}.service-card p{font-size:.9rem;color:var(--text-muted);line-height:1.65}.products-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}@media (max-width:1024px){.products-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.products-grid{grid-template-columns:1fr}}.product-card{background:var(--card);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:all 0.4s cubic-bezier(.22,1,.36,1);border:1px solid var(--border)}.product-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:#fff0}.product-img-wrap{position:relative;height:220px;overflow:hidden}.product-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s cubic-bezier(.22,1,.36,1)}.product-card:hover .product-img-wrap img{transform:scale(1.08)}.product-badge{position:absolute;top:1rem;left:1rem;padding:.35rem .85rem;background:var(--primary);color:var(--white);font-size:.75rem;font-weight:700;border-radius:6px;text-transform:uppercase;letter-spacing:.05em}.product-body{padding:1.5rem}.product-body h3{font-size:1.25rem;margin-bottom:.5rem;color:var(--text)}.product-specs-row{display:flex;gap:1rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.product-spec{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--text-muted);font-weight:500}.product-spec svg{width:14px;height:14px;stroke:var(--accent);fill:none;stroke-width:2}.product-body p{font-size:.9rem;color:var(--text-muted);line-height:1.65;margin-bottom:1.25rem}.product-link{display:inline-flex;align-items:center;gap:.4rem;font-size:.9rem;font-weight:600;color:var(--primary);transition:all 0.25s}.product-link svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;transition:transform 0.25s}.product-link:hover{color:var(--accent)}.product-link:hover svg{transform:translateX(4px)}.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}@media (max-width:768px){.about-grid{grid-template-columns:1fr;gap:2.5rem}}.about-img-wrap{position:relative;border-radius:var(--radius);overflow:hidden}.about-img-wrap img{width:100%;height:420px;object-fit:cover;border-radius:var(--radius)}.about-img-accent{position:absolute;bottom:-8px;right:-8px;width:40%;height:40%;border:3px solid var(--accent);border-radius:var(--radius);z-index:-1}.about-text p{font-size:.95rem;color:var(--text-muted);line-height:1.75;margin-bottom:1rem}.about-features{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.5rem}.about-feature{display:flex;align-items:center;gap:.6rem;font-size:.9rem;font-weight:600;color:var(--text)}.about-feature-icon{width:32px;height:32px;border-radius:8px;background:rgb(201 168 76 / .12);display:flex;align-items:center;justify-content:center;flex-shrink:0}.about-feature-icon svg{width:16px;height:16px;stroke:var(--accent);fill:none;stroke-width:2.5}.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}@media (max-width:1024px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.gallery-grid{grid-template-columns:1fr}}.gallery-item{position:relative;border-radius:var(--radius);overflow:hidden;height:260px;cursor:pointer}.gallery-item.tall{grid-row:span 2;height:100%}.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s cubic-bezier(.22,1,.36,1)}.gallery-item:hover img{transform:scale(1.1)}.gallery-item-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgb(12 45 107 / .7) 0%,transparent 60%);opacity:0;transition:opacity 0.4s ease;display:flex;align-items:flex-end;padding:1.5rem}.gallery-item:hover .gallery-item-overlay{opacity:1}.gallery-item-overlay span{color:var(--white);font-weight:600;font-size:.95rem}.cta-banner{position:relative;overflow:hidden;border-radius:var(--radius);background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);padding:4rem 3rem;text-align:center;margin:0 auto}.cta-banner::before{content:'';position:absolute;top:-100px;right:-100px;width:300px;height:300px;border-radius:50%;background:rgb(201 168 76 / .1)}.cta-banner::after{content:'';position:absolute;bottom:-80px;left:-80px;width:250px;height:250px;border-radius:50%;background:rgb(255 255 255 / .04)}.cta-banner h2{font-size:clamp(1.5rem, 3vw, 2.25rem);color:var(--white);margin-bottom:.75rem;position:relative}.cta-banner p{color:rgb(255 255 255 / .8);font-size:1.05rem;margin-bottom:2rem;position:relative}.cta-banner .btn-primary{position:relative}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem}@media (max-width:768px){.contact-grid{grid-template-columns:1fr}}.contact-info-list{display:flex;flex-direction:column;gap:1.5rem;margin-top:.5rem}.contact-item{display:flex;gap:1rem;align-items:flex-start}.contact-icon{width:48px;height:48px;border-radius:12px;background:var(--bg-alt);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all 0.3s}.contact-item:hover .contact-icon{background:var(--primary)}.contact-icon svg{width:20px;height:20px;stroke:var(--primary);fill:none;stroke-width:2;transition:stroke 0.3s}.contact-item:hover .contact-icon svg{stroke:var(--white)}.contact-detail h4{font-family:'Inter',sans-serif;font-size:.95rem;font-weight:700;color:var(--text);margin-bottom:.15rem}.contact-detail p,.contact-detail a{font-size:.9rem;color:var(--text-muted);line-height:1.5}.contact-detail a:hover{color:var(--primary)}.contact-map{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);height:100%;min-height:360px}.contact-map iframe{width:100%;height:100%;border:none}.site-footer{background:var(--text);color:rgb(255 255 255 / .85);padding:4rem 0 0;}.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid rgb(255 255 255 / .08)}@media (max-width:768px){.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}}@media (max-width:480px){.footer-grid{grid-template-columns:1fr}}.footer-brand p{font-size:.9rem;color:rgb(255 255 255 / .6);line-height:1.65;margin-top:1rem}.footer-col h4{font-family:'Playfair Display',serif;font-weight:700;font-size:1.05rem;color:var(--accent);margin-bottom:1.25rem}.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}.footer-col a{font-size:.9rem;color:rgb(255 255 255 / .6);transition:all 0.25s}.footer-col a:hover{color:var(--accent);transform:translateX(3px);display:inline-block}.footer-col p{font-size:.9rem;color:rgb(255 255 255 / .6);line-height:1.6}.footer-bottom-bar{padding:1.5rem 0;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem}.footer-copyright{font-size:.85rem;color:rgb(255 255 255 / .4);line-height:1.6}.footer-copyright strong{color:rgb(255 255 255 / .7)}.footer-copyright a{color:rgb(255 255 255 / .5);transition:color 0.25s}.footer-copyright a:hover{color:var(--accent)}.footer-social{display:flex;gap:.75rem}.footer-social a{width:36px;height:36px;border-radius:8px;background:rgb(255 255 255 / .06);display:flex;align-items:center;justify-content:center;transition:all 0.3s}.footer-social a:hover{background:var(--accent);transform:translateY(-2px)}.footer-social svg{width:16px;height:16px;fill:rgb(255 255 255 / .7)}.footer-social a:hover svg{fill:var(--primary)}.scroll-top{position:fixed;bottom:2rem;right:2rem;width:44px;height:44px;border-radius:10px;background:var(--primary);color:var(--white);display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;opacity:0;transform:translateY(20px);transition:all 0.35s ease;z-index:500;box-shadow:var(--shadow-md)}.scroll-top.visible{opacity:1;transform:translateY(0)}.scroll-top:hover{background:var(--accent);transform:translateY(-2px)}.scroll-top svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2.5}@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.preloader{position:fixed;inset:0;background:var(--primary);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity 0.6s ease,visibility 0.6s ease}.preloader.hidden{opacity:0;visibility:hidden}.preloader-inner{text-align:center;color:var(--white)}.preloader-logo{font-family:'Playfair Display',serif;font-size:2rem;font-weight:800;margin-bottom:1.5rem;letter-spacing:-.02em}.preloader-logo span{color:var(--accent)}.preloader-bar{width:160px;height:3px;background:rgb(255 255 255 / .15);border-radius:4px;overflow:hidden;margin:0 auto}.preloader-bar-inner{width:40%;height:100%;background:var(--accent);border-radius:4px;animation:preloaderSlide 1.2s ease infinite}@keyframes preloaderSlide{0%{transform:translateX(-100%)}100%{transform:translateX(400%)}}.particles-canvas{position:absolute;inset:0;z-index:2;pointer-events:none}