:root{--color-primary:#1a1a1a;--color-secondary:#2d2d2d;--color-accent:#c9a962;--color-accent-light:#d4bc7e;--color-accent-dark:#a68a4a;--color-accent-text:#7a5c1e;--color-text:#333333;--color-text-light:#666666;--color-text-muted:#999999;--color-bg:#ffffff;--color-bg-light:#f8f8f8;--color-bg-dark:#1a1a1a;--color-border:#e5e5e5;--color-border-dark:#333333;--font-heading:'Cormorant Garamond',Georgia,serif;--font-body:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;--space-xs:0.5rem;--space-sm:1rem;--space-md:1.5rem;--space-lg:2rem;--space-xl:3rem;--space-2xl:4rem;--space-3xl:6rem;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:20px;--shadow-sm:0 2px 8px rgba(0,0,0,0.08);--shadow-md:0 4px 20px rgba(0,0,0,0.12);--shadow-lg:0 8px 40px rgba(0,0,0,0.16);--shadow-xl:0 20px 60px rgba(0,0,0,0.2);--transition-fast:0.2s ease;--transition-base:0.35s cubic-bezier(0.25,0.46,0.45,0.94);--transition-slow:0.5s cubic-bezier(0.25,0.46,0.45,0.94);--header-height:120px}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);font-size:1rem;line-height:1.6;color:var(--color-text);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color var(--transition-fast)}
ul,ol{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,textarea,select{font-family:inherit;font-size:inherit}
address{font-style:normal}
.container{width:100%;max-width:1400px;margin:0 auto;padding:0 var(--space-lg)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.loader{position:fixed;inset:0;background:var(--color-primary);z-index:9999;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:var(--space-lg)}
.loader-logo{width:230px;height:230px;opacity:0;animation:fadeIn 0.6s ease forwards 0.2s}
.loader-logo svg,.loader-logo img{width:100%;height:100%;object-fit:contain}
.loader-bar{width:150px;height:2px;background:rgba(255,255,255,0.1);border-radius:2px;overflow:hidden;opacity:0;animation:fadeIn 0.6s ease forwards 0.4s}
.loader-progress{height:100%;background:var(--color-accent);width:0%;animation:loadProgress 1.8s ease forwards}
@keyframes fadeIn{to{opacity:1}}
@keyframes loadProgress{to{width:100%}}
.loader.fade-out{animation:fadeOutLoader 0.8s ease forwards;display:none}
@keyframes fadeOutLoader{to{opacity:0;visibility:hidden;pointer-events:none}}
.header{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--header-height);background:transparent;transition:background var(--transition-base),box-shadow var(--transition-base)}
.header.scrolled{background:rgba(255,255,255,0.98);box-shadow:var(--shadow-sm);height:80px}
.header.scrolled .logo{color:var(--color-primary);padding-bottom:0}
.header.scrolled .logo-icon img,.header.scrolled .logo-icon svg{width:100px;height:100px;filter:brightness(0);transition:all var(--transition-base)}
.nav{display:flex;align-items:center;justify-content:space-between;height:100%}
.logo{display:flex;align-items:flex-end;gap:var(--space-sm);color:var(--color-bg);transition:color var(--transition-fast),transform var(--transition-base);padding-bottom:15px}
.logo:hover{transform:translateX(3px)}
.logo-icon{display:flex;align-items:flex-end;justify-content:center;padding-bottom:10px}
.logo-icon img,.logo-icon svg{width:180px;height:180px;object-fit:contain;transition:all var(--transition-base);display:block}
.logo-text{font-family:var(--font-heading);font-size:1.5rem;font-weight:600;letter-spacing:0.15em}
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:6px;width:32px;height:32px;z-index:1001}
.nav-toggle span{display:block;width:100%;height:2px;background:var(--color-bg);transition:transform var(--transition-base),opacity var(--transition-fast),background var(--transition-fast)}
.header.scrolled .nav-toggle span{background:var(--color-primary)}
.nav-toggle.active span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggle.active span:nth-child(2){opacity:0}
.nav-toggle.active span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
.nav-menu{display:flex;align-items:center;gap:var(--space-xl)}
.nav-link{position:relative;font-size:0.875rem;font-weight:500;color:var(--color-bg);letter-spacing:0.05em;text-transform:uppercase;padding:var(--space-xs) 0;transition:color var(--transition-fast)}
.header.scrolled .nav-link{color:var(--color-text)}
.nav-link::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--color-accent);transition:width var(--transition-base)}
.nav-link:hover::after,.nav-link.active::after{width:100%}
.nav-link:hover,.nav-link.active{color:var(--color-accent)}
.hero{position:relative;height:100vh;min-height:700px;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.05);transition:transform 8s ease-out}
.hero:hover .hero-bg{transform:scale(1)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,0,0,0.7) 0%,rgba(0,0,0,0.4) 100%)}
.hero-content{position:relative;z-index:10;max-width:800px}
.hero-subtitle{display:inline-block;font-size:0.875rem;font-weight:500;color:var(--color-accent);letter-spacing:0.2em;text-transform:uppercase;margin-bottom:var(--space-md);opacity:0;transform:translateY(20px);animation:fadeUp 0.8s ease forwards 0.4s}
.hero-title{font-family:var(--font-heading);font-size:clamp(3rem,8vw,5rem);font-weight:300;line-height:1.1;color:var(--color-bg);margin-bottom:var(--space-lg);opacity:0;transform:translateY(30px);animation:fadeUp 0.8s ease forwards 0.6s}
.hero-title span{font-weight:600;color:var(--color-accent)}
.hero-description{font-size:1.125rem;color:rgba(255,255,255,0.85);max-width:480px;margin-bottom:var(--space-xl);opacity:0;transform:translateY(20px);animation:fadeUp 0.8s ease forwards 0.8s}
.hero-actions{display:flex;gap:var(--space-md);opacity:0;transform:translateY(20px);animation:fadeUp 0.8s ease forwards 1s}
.hero-scroll{position:absolute;bottom:var(--space-xl);left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);color:rgba(255,255,255,0.6);font-size:0.75rem;letter-spacing:0.1em;text-transform:uppercase;opacity:0;animation:fadeIn 1s ease forwards 1.4s}
.hero-scroll svg{animation:gentleBounce 2s ease-in-out infinite}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
@keyframes gentleBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:0.875rem 2rem;font-size:0.875rem;font-weight:600;letter-spacing:0.05em;text-transform:uppercase;border-radius:var(--radius-sm);transition:all var(--transition-base);white-space:nowrap}
.btn-primary{background:var(--color-accent);color:var(--color-primary)}
.btn-primary:hover{background:var(--color-accent-light);transform:translateY(-2px);box-shadow:0 6px 20px rgba(201,169,98,0.3)}
.btn-outline{background:transparent;color:var(--color-bg);border:1px solid rgba(255,255,255,0.4)}
.btn-outline:hover{background:var(--color-bg);color:var(--color-primary);border-color:var(--color-bg)}
.btn-text{background:transparent;color:var(--color-accent-text);padding:0}
.btn-text svg{transition:transform var(--transition-fast)}
.btn-text:hover svg{transform:translateX(4px)}
.btn-large{padding:1rem 2.5rem;font-size:1rem}
.btn-full{width:100%}
.btn-outline-light{background:transparent;color:var(--color-bg);border:1px solid var(--color-bg)}
.btn-outline-light:hover{background:var(--color-bg);color:var(--color-primary)}
.section-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:var(--space-2xl)}
.section-header.centered{flex-direction:column;align-items:center;text-align:center}
.section-tag{display:inline-block;font-size:0.75rem;font-weight:600;color:var(--color-accent-text);letter-spacing:0.2em;text-transform:uppercase;margin-bottom:var(--space-sm)}
.section-title{font-family:var(--font-heading);font-size:clamp(2rem,4vw,2.75rem);font-weight:400;color:var(--color-primary);line-height:1.2}
.section-desc{max-width:600px;color:var(--color-text-light);margin-top:var(--space-md)}
.about-preview{padding:var(--space-3xl) 0;background:var(--color-bg)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3xl);align-items:center}
.about-image{position:relative}
.about-image img{width:100%;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);transition:transform var(--transition-slow)}
.about-image:hover img{transform:scale(1.02)}
.about-image-accent{position:absolute;top:-20px;right:-20px;width:150px;height:150px;border:2px solid var(--color-accent);border-radius:var(--radius-md);z-index:-1;opacity:0.5}
.about-content{padding-left:var(--space-lg)}
.about-lead{font-family:var(--font-heading);font-size:1.375rem;font-weight:500;color:var(--color-primary);margin-bottom:var(--space-lg);line-height:1.5}
.about-content p{color:var(--color-text-light);margin-bottom:var(--space-md)}
.about-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-lg);margin:var(--space-xl) 0;padding:var(--space-lg) 0;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}
.about-stats li{display:flex;flex-direction:column}
.stat-number{font-family:var(--font-heading);font-size:2.5rem;font-weight:600;color:var(--color-accent);line-height:1}
.stat-label{font-size:0.875rem;color:var(--color-text-light);margin-top:var(--space-xs)}
.services-preview{padding:var(--space-3xl) 0;background:var(--color-bg-light)}
.services-cta{text-align:center;margin-top:50px}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-lg)}
.service-card{background:var(--color-bg);padding:var(--space-xl);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all var(--transition-base);opacity:1!important;visibility:visible!important}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.service-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-light);border-radius:var(--radius-md);margin-bottom:var(--space-md);color:var(--color-accent);transition:all var(--transition-base)}
.service-card:hover .service-icon{background:var(--color-accent);color:var(--color-bg)}
.service-title{font-family:var(--font-heading);font-size:1.375rem;font-weight:500;color:var(--color-primary);margin-bottom:var(--space-sm)}
.service-desc{font-size:0.9375rem;color:var(--color-text-light);margin-bottom:var(--space-md);line-height:1.6}
.service-link{display:inline-flex;align-items:center;gap:var(--space-xs);font-size:0.875rem;font-weight:600;color:var(--color-accent-text);text-transform:uppercase;letter-spacing:0.05em}
.service-link svg{transition:transform var(--transition-fast)}
.service-card:hover .service-link svg{transform:translateX(4px)}
.projects-preview{padding:var(--space-3xl) 0;background:var(--color-bg)}
.projects-showcase{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(2,300px);gap:var(--space-md);margin-top:var(--space-xl)}
.project-item{position:relative;overflow:hidden;border-radius:var(--radius-md)}
.project-item.large{grid-column:span 2;grid-row:span 2}
.project-item figure{width:100%;height:100%;margin:0}
.project-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s ease}
.project-item:hover img{transform:scale(1.05)}
.project-item figcaption{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:var(--space-lg);background:linear-gradient(to top,rgba(0,0,0,0.85) 0%,rgba(0,0,0,0.2) 60%,transparent 100%);color:var(--color-bg);opacity:0;transition:opacity var(--transition-base)}
.project-item:hover figcaption{opacity:1}
.project-category{font-size:0.75rem;font-weight:500;color:var(--color-accent);letter-spacing:0.1em;text-transform:uppercase;margin-bottom:var(--space-xs)}
.project-title{font-family:var(--font-heading);font-size:1.375rem;font-weight:500;margin-bottom:var(--space-xs)}
.project-location{font-size:0.875rem;opacity:0.8}
.testimonials{padding:var(--space-3xl) 0;background:var(--color-bg-light)}
.testimonials-slider{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg);margin-top:var(--space-xl)}
.testimonial-card{background:var(--color-bg);padding:var(--space-lg);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}
.testimonial-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.testimonial-rating{display:flex;gap:4px;color:var(--color-accent);margin-bottom:var(--space-md)}
.testimonial-text{font-size:1rem;color:var(--color-text);line-height:1.7;margin-bottom:var(--space-lg)}
.testimonial-author{display:flex;flex-direction:column}
.author-name{font-weight:600;color:var(--color-primary);font-style:normal}
.author-title{font-size:0.875rem;color:var(--color-text-light)}
.cta{padding:var(--space-3xl) 0;background:var(--color-primary)}
.cta-content{text-align:center;max-width:700px;margin:0 auto}
.cta-title{font-family:var(--font-heading);font-size:clamp(2rem,4vw,2.75rem);font-weight:400;color:var(--color-bg);margin-bottom:var(--space-md)}
.cta-text{font-size:1.0625rem;color:rgba(255,255,255,0.75);margin-bottom:var(--space-xl)}
.cta-actions{display:flex;justify-content:center;gap:var(--space-md);flex-wrap:wrap}
.footer{background:var(--color-bg-dark);color:var(--color-bg);padding:var(--space-3xl) 0 var(--space-lg)}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr 1.5fr;gap:var(--space-2xl);padding:var(--space-xl) 0 var(--space-2xl);border-bottom:1px solid var(--color-border-dark);align-items:start}
.footer-logo{display:inline-block;margin-bottom:var(--space-md)}
.footer-logo img{width:160px;height:auto;max-height:160px;object-fit:contain;display:block}
.footer-brand{display:flex;flex-direction:column;align-items:flex-start;gap:0}
.footer-brand .footer-desc{margin-bottom:var(--space-lg)}
.footer-desc{color:rgba(255,255,255,0.6);line-height:1.7}
.footer-social{display:flex;gap:var(--space-md);margin-top:var(--space-lg)}
.footer-social a{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:1px solid var(--color-border-dark);border-radius:50%;color:var(--color-bg);transition:all var(--transition-base)}
.footer-social a:hover{background:var(--color-accent);border-color:var(--color-accent);color:var(--color-primary)}
.footer-nav h3,.footer-contact h3{font-size:1rem;font-weight:600;margin-bottom:var(--space-lg);text-transform:uppercase;letter-spacing:0.05em}
.footer-nav ul{display:flex;flex-direction:column;gap:var(--space-sm)}
.footer-nav a{color:rgba(255,255,255,0.6);transition:color var(--transition-fast)}
.footer-nav a:hover{color:var(--color-accent)}
.footer-contact address{display:flex;flex-direction:column;gap:var(--space-md)}
.footer-contact p{display:flex;align-items:flex-start;gap:var(--space-sm);color:rgba(255,255,255,0.6)}
.footer-contact svg{flex-shrink:0;color:var(--color-accent)}
.footer-contact a{color:rgba(255,255,255,0.6);transition:color var(--transition-fast)}
.footer-contact a:hover{color:var(--color-accent)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg) 0;font-size:0.875rem;color:rgba(255,255,255,0.5)}
.footer-legal{display:flex;gap:var(--space-lg)}
.footer-legal a{color:rgba(255,255,255,0.5);transition:color var(--transition-fast)}
.footer-legal a:hover{color:var(--color-accent)}
.page-hero{position:relative;height:400px;display:flex;align-items:center;overflow:hidden;padding-top:var(--header-height)}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,0,0,0.8) 0%,rgba(0,0,0,0.5) 100%)}
.page-hero-content{position:relative;z-index:10}
.breadcrumb{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md)}
.breadcrumb li{display:flex;align-items:center;font-size:0.875rem;color:rgba(255,255,255,0.6)}
.breadcrumb li:not(:last-child)::after{content:'/';margin-left:var(--space-sm)}
.breadcrumb a{color:rgba(255,255,255,0.6);transition:color var(--transition-fast)}
.breadcrumb a:hover{color:var(--color-accent)}
.breadcrumb li:last-child{color:var(--color-bg)}
.page-title{font-family:var(--font-heading);font-size:clamp(2.5rem,5vw,3.5rem);font-weight:400;color:var(--color-bg);margin-bottom:var(--space-sm)}
.page-subtitle{font-size:1.125rem;color:rgba(255,255,255,0.8)}
.about-story{padding:var(--space-3xl) 0;background:var(--color-bg)}
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3xl);align-items:center}
.story-content p{color:var(--color-text-light);margin-bottom:var(--space-md);line-height:1.8}
.story-content h3{font-family:var(--font-heading);font-size:1.5rem;font-weight:500;color:var(--color-primary);margin-bottom:var(--space-sm);margin-top:var(--space-lg)}
.story-image img{width:100%;border-radius:var(--radius-md);box-shadow:var(--shadow-lg)}
.values{padding:var(--space-3xl) 0;background:var(--color-bg-light)}
.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-lg);margin-top:var(--space-xl)}
.value-card{text-align:center;padding:var(--space-xl);background:var(--color-bg);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}
.value-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.value-icon{width:72px;height:72px;display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-lg);background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-accent-dark) 100%);border-radius:50%;color:var(--color-bg);transition:transform var(--transition-base)}
.value-card:hover .value-icon{transform:scale(1.05)}
.value-card h3{font-family:var(--font-heading);font-size:1.25rem;font-weight:500;color:var(--color-primary);margin-bottom:var(--space-sm)}
.value-card p{font-size:0.9375rem;color:var(--color-text-light);line-height:1.6}
.team{padding:var(--space-3xl) 0;background:var(--color-bg)}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-lg);margin-top:var(--space-xl)}
.team-member{text-align:center}
.member-image{position:relative;overflow:hidden;border-radius:var(--radius-md);margin-bottom:var(--space-lg)}
.member-image img{width:100%;aspect-ratio:1;object-fit:cover;transition:transform var(--transition-slow)}
.team-member:hover .member-image img{transform:scale(1.03)}
.member-info{padding:0 var(--space-sm)}
.member-name{font-family:var(--font-heading);font-size:1.25rem;font-weight:500;color:var(--color-primary);margin-bottom:var(--space-xs)}
.member-role{display:block;font-size:0.875rem;color:var(--color-accent);margin-bottom:var(--space-sm)}
.member-info p{font-size:0.875rem;color:var(--color-text-light);line-height:1.6}
.awards{padding:var(--space-3xl) 0;background:var(--color-bg-light)}
.awards-timeline{max-width:800px;margin:var(--space-xl) auto 0}
.award-item{display:flex;gap:var(--space-xl);padding:var(--space-lg) 0;border-bottom:1px solid var(--color-border)}
.award-item:last-child{border-bottom:none}
.award-year{flex-shrink:0;width:80px;font-family:var(--font-heading);font-size:2rem;font-weight:600;color:var(--color-accent)}
.award-content h3{font-family:var(--font-heading);font-size:1.25rem;font-weight:500;color:var(--color-primary);margin-bottom:var(--space-xs)}
.award-content p{color:var(--color-text-light)}
.service-detail{padding:var(--space-3xl) 0;background:var(--color-bg)}
.service-detail.alt{background:var(--color-bg-light)}
.service-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3xl);align-items:center}
.service-detail-grid.reverse{direction:rtl}
.service-detail-grid.reverse>*{direction:ltr}
.service-detail-image img{width:100%;border-radius:var(--radius-md);box-shadow:var(--shadow-lg)}
.service-number{display:inline-block;font-family:var(--font-heading);font-size:4rem;font-weight:300;color:var(--color-accent);opacity:0.3;line-height:1;margin-bottom:calc(-1 * var(--space-sm))}
.service-detail-content h2{font-family:var(--font-heading);font-size:2.25rem;font-weight:400;color:var(--color-primary);margin-bottom:var(--space-md)}
.service-detail-content>p{color:var(--color-text-light);margin-bottom:var(--space-xl);line-height:1.8}
.service-features{margin-bottom:var(--space-xl)}
.service-features li{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) 0;color:var(--color-text)}
.service-features svg{flex-shrink:0;color:var(--color-accent)}
.process{padding:var(--space-3xl) 0;background:var(--color-bg)}
.process-steps{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--space-md);margin-top:var(--space-xl)}
.process-step{text-align:center;padding:var(--space-lg);background:var(--color-bg-light);border-radius:var(--radius-md);transition:all var(--transition-base)}
.process-step:hover{background:var(--color-bg);box-shadow:var(--shadow-sm)}
.step-number{font-family:var(--font-heading);font-size:2.5rem;font-weight:300;color:var(--color-accent);opacity:0.5;margin-bottom:var(--space-sm)}
.process-step h3{font-family:var(--font-heading);font-size:1rem;font-weight:500;color:var(--color-primary);margin-bottom:var(--space-sm)}
.process-step p{font-size:0.875rem;color:var(--color-text-light);line-height:1.6}
.projects-filter{padding:var(--space-lg) 0;background:var(--color-bg);position:sticky;top:var(--header-height);z-index:100;border-bottom:1px solid var(--color-border)}
.filter-buttons{display:flex;justify-content:center;gap:var(--space-sm);flex-wrap:wrap}
.filter-btn{padding:0.625rem 1.25rem;font-size:0.875rem;font-weight:500;color:var(--color-text-light);border:1px solid var(--color-border);border-radius:var(--radius-xl);transition:all var(--transition-base)}
.filter-btn:hover,.filter-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-bg)}
.projects-grid-section{padding:var(--space-2xl) 0 var(--space-3xl);background:var(--color-bg-light)}
.projects-full-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg)}
.project-card{background:var(--color-bg);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);transition:all var(--transition-base)}
.project-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.project-card.large{grid-column:span 2;grid-row:span 2}
.project-card-image{position:relative;overflow:hidden;margin:0}
.project-card.large .project-card-image{height:400px}
.project-card:not(.large) .project-card-image{height:200px}
.project-card-image img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s ease}
.project-card:hover .project-card-image img{transform:scale(1.05)}
.project-card-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.5);opacity:0;transition:opacity var(--transition-base)}
.project-card:hover .project-card-overlay{opacity:1}
.project-card-content{padding:var(--space-lg)}
.project-category-tag{display:inline-block;font-size:0.75rem;font-weight:600;color:var(--color-accent);letter-spacing:0.1em;text-transform:uppercase;margin-bottom:var(--space-xs)}
.project-card-title{font-family:var(--font-heading);font-size:1.375rem;font-weight:500;color:var(--color-primary);margin-bottom:var(--space-sm);transition:color var(--transition-fast)}
.project-card:hover .project-card-title{color:var(--color-accent)}
.project-card.large .project-card-title{font-size:1.75rem}
.project-meta{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md);font-size:0.875rem;color:var(--color-text-light)}
.project-location{display:flex;align-items:center;gap:var(--space-xs)}
.project-desc{font-size:0.9375rem;color:var(--color-text-light);line-height:1.6}
.contact-section{padding:var(--space-3xl) 0;background:var(--color-bg)}
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:var(--space-3xl)}
.contact-card h2{font-family:var(--font-heading);font-size:2rem;font-weight:400;color:var(--color-primary);margin-bottom:var(--space-md)}
.contact-card>p{color:var(--color-text-light);margin-bottom:var(--space-xl)}
.contact-details{display:flex;flex-direction:column;gap:var(--space-lg);margin-bottom:var(--space-xl)}
.contact-item{display:flex;gap:var(--space-md)}
.contact-icon{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-light);border-radius:var(--radius-md);color:var(--color-accent);transition:all var(--transition-base)}
.contact-item:hover .contact-icon{background:var(--color-accent);color:var(--color-bg)}
.contact-text h3{font-size:0.875rem;font-weight:600;color:var(--color-primary);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:var(--space-xs)}
.contact-text address,.contact-text a,.contact-text span{font-size:0.9375rem;color:var(--color-text-light)}
.contact-text a:hover{color:var(--color-accent)}
.contact-text span{display:block;margin-top:var(--space-xs);font-size:0.8125rem}
.contact-social h3{font-size:0.875rem;font-weight:600;color:var(--color-primary);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:var(--space-md)}
.social-links{display:flex;gap:var(--space-sm)}
.social-links a{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:1px solid var(--color-border);border-radius:50%;color:var(--color-text);transition:all var(--transition-base)}
.social-links a:hover{background:var(--color-accent);border-color:var(--color-accent);color:var(--color-bg)}
.contact-form-wrapper{background:var(--color-bg-light);padding:var(--space-2xl);border-radius:var(--radius-md)}
.contact-form h2{font-family:var(--font-heading);font-size:2rem;font-weight:400;color:var(--color-primary);margin-bottom:var(--space-sm)}
.contact-form>p{color:var(--color-text-light);margin-bottom:var(--space-xl)}
.form-row{margin-bottom:var(--space-md)}
.form-row.two-col{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}
.form-group{display:flex;flex-direction:column}
.form-group label{font-size:0.875rem;font-weight:500;color:var(--color-text);margin-bottom:var(--space-xs)}
.form-group input,.form-group textarea,.form-group select{padding:0.875rem 1rem;font-size:1rem;color:var(--color-text);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px rgba(201,169,98,0.15)}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--color-text-muted)}
.form-group textarea{resize:vertical;min-height:120px}
.form-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23666666' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:3rem}
.error-message{font-size:0.8125rem;color:#dc3545;margin-top:var(--space-xs);min-height:1.2em}
.checkbox-group{flex-direction:row}
.checkbox-label{display:flex;align-items:flex-start;gap:var(--space-sm);cursor:pointer;font-size:0.875rem;color:var(--color-text-light)}
.checkbox-label input{width:20px;height:20px;accent-color:var(--color-accent);cursor:pointer}
.checkbox-label a{color:var(--color-accent);text-decoration:underline}
.form-success{text-align:center;padding:var(--space-2xl)}
.success-icon{color:#28a745;margin-bottom:var(--space-lg)}
.form-success h3{font-family:var(--font-heading);font-size:2rem;font-weight:400;color:var(--color-primary);margin-bottom:var(--space-sm)}
.form-success p{color:var(--color-text-light)}
.contact-hours{margin-top:var(--space-xl);padding-top:var(--space-xl);border-top:1px solid var(--color-border)}
.contact-hours h3{font-size:0.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--color-text-muted);margin-bottom:var(--space-md)}
.hours-list{display:flex;flex-direction:column;gap:0}
.hours-row{display:flex;justify-content:space-between;align-items:center;padding:0.625rem 0;font-size:0.9375rem;color:var(--color-text-light);border-bottom:1px solid var(--color-border)}
.hours-row:last-child{border-bottom:none}
.hours-row .day{color:var(--color-text);font-weight:500}
.hours-closed{color:var(--color-text-muted)}
.btn-whatsapp{display:inline-flex;align-items:center;gap:var(--space-sm);margin-top:var(--space-xl);padding:0.875rem 1.5rem;background:#25D366;color:white;border-radius:var(--radius-md);font-weight:500;font-size:0.9375rem;transition:background 0.3s,transform 0.2s;text-decoration:none;width:100%;justify-content:center}
.btn-whatsapp:hover{background:#128C7E;transform:translateY(-1px)}
.contact-features{padding:var(--space-2xl) 0;background:var(--color-bg-light);border-top:1px solid var(--color-border)}
.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.feature-item{text-align:center;padding:var(--space-xl) var(--space-lg);border-right:1px solid var(--color-border)}
.feature-item:last-child{border-right:none}
.feature-icon{width:56px;height:56px;background:var(--color-accent);color:var(--color-bg-dark);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-md);flex-shrink:0}
.feature-item h3{font-family:var(--font-heading);font-size:1.125rem;font-weight:500;color:var(--color-primary);margin-bottom:var(--space-xs)}
.feature-item p{color:var(--color-text-light);font-size:0.875rem;line-height:1.6}
.map-section{line-height:0}
.map-container iframe{filter:grayscale(20%);transition:filter var(--transition-base)}
.map-container:hover iframe{filter:grayscale(0%)}
.fade-in-up{opacity:0;transform:translateY(30px);transition:opacity 0.6s ease,transform 0.6s ease}
.fade-in-up.visible{opacity:1;transform:translateY(0)}
.project-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.95);z-index:10000;overflow-y:auto;padding:20px}
.project-modal.active{display:block}
.modal-overlay{position:fixed;inset:0;cursor:pointer}
.modal-content{max-width:1000px;margin:0 auto;position:relative;padding:60px 0}
.modal-close{position:fixed;top:20px;right:20px;background:rgba(255,255,255,0.1);border:none;color:white;font-size:2rem;cursor:pointer;z-index:10001;width:50px;height:50px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background 0.3s}
.modal-close:hover{background:rgba(255,255,255,0.2)}
.modal-title{font-family:var(--font-heading);font-size:2rem;color:white;font-weight:400;text-align:center;margin-bottom:30px}
.modal-slider{position:relative;display:flex;align-items:center;justify-content:center}
.slider-images{display:flex;align-items:center;justify-content:center;width:100%;height:75vh;max-height:700px}
.slider-images img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;border-radius:8px;display:block;animation:imgFadeIn 0.2s ease}
@keyframes imgFadeIn{from{opacity:0}to{opacity:1}}
.slider-btn{position:fixed;top:50%;transform:translateY(-50%);background:rgba(255,255,255,0.1);border:none;color:white;font-size:2rem;cursor:pointer;width:50px;height:50px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background 0.3s;z-index:10001}
.slider-btn:hover{background:rgba(255,255,255,0.2)}
.slider-btn.prev{left:20px}
.slider-btn.next{right:20px}
.faq-question{cursor:pointer;list-style:none}
.faq-question::-webkit-details-marker{display:none}
.faq-question h3{font-family:var(--font-heading);font-size:1.375rem;font-weight:500;color:var(--color-primary);margin-bottom:var(--space-sm);transition:color var(--transition-fast)}
.faq-question:hover h3{color:var(--color-accent)}
.faq-answer{padding:var(--space-md) 0;color:var(--color-text-light);line-height:1.8}
.faq-answer ul{margin-top:var(--space-xs);padding-left:var(--space-md)}
.faq-answer li{margin-bottom:var(--space-xs)}
.faq-answer a{color:var(--color-accent);text-decoration:none}
.faq-answer a:hover{text-decoration:underline}
details[open] .faq-question{margin-bottom:var(--space-sm)}
@media(max-width:1200px){.services-grid{grid-template-columns:repeat(2,1fr)}.projects-showcase{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(3,250px)}.project-item.large{grid-column:span 2;grid-row:span 1}.values-grid{grid-template-columns:repeat(2,1fr)}.team-grid{grid-template-columns:repeat(2,1fr)}.process-steps{grid-template-columns:repeat(3,1fr)}.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:992px){:root{--header-height:70px}.loader{display:none}.nav-toggle{display:flex}.nav-menu{position:fixed;top:0;right:-100%;width:100%;max-width:400px;height:100vh;flex-direction:column;justify-content:center;gap:var(--space-xl);background:var(--color-primary);padding:var(--space-2xl);transition:right var(--transition-base)}.nav-menu.active{right:0}.nav-link{font-size:1.25rem;color:var(--color-bg)}.header.scrolled .nav-link{color:var(--color-bg)}.about-grid,.story-grid,.service-detail-grid,.contact-grid{grid-template-columns:1fr;gap:var(--space-xl)}.about-content,.story-content{padding-left:0;order:1}.about-image,.story-image{order:0}.service-detail-grid.reverse{direction:ltr}.projects-full-grid{grid-template-columns:repeat(2,1fr)}.project-card.large{grid-column:span 2;grid-row:span 1}.testimonials-slider{grid-template-columns:1fr}}
@media(max-width:768px){.hero{min-height:600px}.hero-title{font-size:2.5rem}.hero-actions{flex-direction:column}.section-header{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.services-grid,.values-grid,.team-grid{grid-template-columns:1fr}.projects-showcase{grid-template-columns:1fr;grid-template-rows:auto}.project-item.large{grid-column:span 1}.project-item{height:300px}.process-steps{grid-template-columns:repeat(2,1fr)}.projects-full-grid{grid-template-columns:1fr}.project-card.large{grid-column:span 1}.form-row.two-col{grid-template-columns:1fr}.cta-actions{flex-direction:column}.footer-grid{grid-template-columns:1fr}.footer-bottom{flex-direction:column;gap:var(--space-md);text-align:center}.page-hero{height:300px}.features-grid{grid-template-columns:repeat(2,1fr)}.feature-item{border-right:none;border-bottom:1px solid var(--color-border)}.feature-item:last-child{border-bottom:none}}
@media(max-width:480px){.container{padding:0 var(--space-md)}.hero-title{font-size:2rem}.process-steps{grid-template-columns:1fr}.filter-buttons{gap:var(--space-sm)}.filter-btn{padding:0.5rem 1rem;font-size:0.8125rem}.features-grid{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.reduced-motion .fade-in-up,.reduced-motion .service-card,.reduced-motion .project-card{opacity:1!important;transform:none!important;transition:none!important}
