@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&family=Montserrat:wght@300;400;600;700;800&display=swap";:root{--bg-dark: #fbfbfb;--bg-card: #ffffff;--primary: #F4BC0C;--primary-hover: #D4A30A;--text-main: #04041C;--text-muted: #555570;--accent: #eef2f6;--glass: rgba(255, 255, 255, .85);--glass-border: rgba(0, 0, 0, .08);--header-height: 80px;--section-padding: 100px 5%;--section-padding-mobile: 60px 20px;--border-radius: 12px;--font-heading: "Montserrat", sans-serif;--font-body: "Inter", sans-serif}*{margin:0;padding:0;box-sizing:border-box}html,body{font-family:var(--font-body);background-color:var(--bg-dark);color:var(--text-main);line-height:1.6;overflow-x:hidden;width:100%;margin:0;padding:0;-webkit-overflow-scrolling:touch}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);text-transform:uppercase;letter-spacing:2px}a{text-decoration:none;color:inherit;transition:.3s ease}ul{list-style:none}section{padding:var(--section-padding)}.container{max-width:1200px;margin:0 auto}.glass-effect{background:var(--glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--glass-border)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-dark)}::-webkit-scrollbar-thumb{background:var(--accent);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary)}.btn{display:inline-block;padding:12px 30px;border-radius:var(--border-radius);font-family:var(--font-heading);font-weight:600;font-size:.9rem;cursor:pointer;transition:all .3s ease}.btn-primary{background-color:var(--primary);color:var(--bg-dark)}.btn-primary:hover{background-color:var(--primary-hover);transform:translateY(-2px);box-shadow:0 5px 15px #c5a0594d}.btn-outline{border:1px solid var(--primary);color:var(--primary)}.btn-outline:hover{background-color:var(--primary);color:var(--bg-dark)}.btn-outline:hover{background-color:transparent!important;color:var(--primary-hover)!important;border-color:var(--primary-hover)!important;box-shadow:inset 0 0 0 1px var(--primary-hover)!important}@media(max-width:1024px){:root{--section-padding: 80px 5%}}@media(max-width:768px){:root{--section-padding: var(--section-padding-mobile)}h1{font-size:2rem!important;letter-spacing:1px}h2{font-size:1.5rem!important;letter-spacing:1px}h3{font-size:1.25rem!important}.btn{width:100%;text-align:center;padding:14px 20px}}@media(max-width:480px){h1{font-size:1.75rem!important}}.navbar{position:fixed;top:0;left:0;width:100%;height:var(--header-height);display:flex;align-items:center;z-index:1000;transition:all .4s ease;padding:0;background:transparent}.navbar.scrolled{height:70px;background:#e1f0fff2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--glass-border)}.navbar-container{width:100%;max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;padding:0 5%}.logo img{height:45px;width:auto;object-fit:contain}.nav-links{display:flex;align-items:center;gap:30px;justify-content:flex-start}.nav-links a{font-family:var(--font-heading);font-size:.85rem;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--text-main)}.nav-links a:hover{color:var(--primary)}.nav-links .btn{padding:8px 20px}.contact-btn{display:flex!important;align-items:center;gap:8px}.menu-icon{display:none;color:var(--text-main);cursor:pointer;z-index:1001}.navbar-overlay{position:fixed;top:0;left:0;width:100%;height:100vh;background:#0006;z-index:998}@media(max-width:992px){.navbar{background:transparent}.navbar-container{padding:0 20px}.nav-links{position:fixed;top:0;right:-100%;width:80%;max-width:400px;height:100vh;background:var(--bg-card);flex-direction:column;justify-content:center;align-items:center;gap:40px;transition:.4s ease;z-index:999;box-shadow:-10px 0 30px #0000001a;padding:80px 20px}.nav-links.active{right:0}.menu-icon{display:block;margin-left:auto}.nav-links a{font-size:1.1rem}.nav-links .btn{width:100%;justify-content:center;margin:0}}.footer{padding:80px 0 40px;background-color:#e5e5e5;border-top:1px solid var(--glass-border)}.footer-top{display:flex;justify-content:space-between;margin-bottom:60px;flex-wrap:wrap;gap:40px}.footer-brand img{height:80px;width:auto;object-fit:contain;margin-bottom:15px}.footer-brand{max-width:400px}.footer-brand p{color:var(--text-muted)}.footer-links{display:flex;gap:80px;flex-grow:1;justify-content:flex-end}.link-group h4{font-size:1rem;color:var(--primary);margin-bottom:20px}.link-group ul li{margin-bottom:12px}.link-group ul li a{color:var(--text-muted);font-size:.9rem;display:inline-block;transition:transform .3s ease,color .3s ease}.link-group ul li a:hover{color:var(--text-main);transform:translate(-8px)}.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:40px;border-top:1px solid var(--glass-border);color:var(--text-muted);font-size:.8rem}.socials{display:flex;gap:15px}.socials button{width:36px;height:36px;background-color:#04041c;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;transition:all .3s ease;border:none;cursor:pointer}.socials button:hover{background-color:var(--primary);transform:translateY(-3px)}@media(max-width:768px){.footer-top{flex-direction:column;text-align:center}.footer-links{flex-direction:column;align-items:center;gap:40px;justify-content:center}.link-group ul li a:hover{transform:translateY(-3px)}.footer-bottom{flex-direction:column-reverse;gap:20px;text-align:center}}.whatsapp-float{position:fixed;width:60px;height:60px;bottom:40px;right:40px;background-color:#25d366;color:#fff;border-radius:50px;text-align:center;font-size:30px;box-shadow:2px 2px 3px #999;z-index:1000;display:flex;align-items:center;justify-content:center;transition:all .3s ease;animation:bounce 2s infinite}.whatsapp-float:hover{background-color:#128c7e;transform:scale(1.1)}.whatsapp-float svg{width:35px;height:35px}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}@media(max-width:768px){.whatsapp-float{width:50px;height:50px;bottom:20px;right:20px}.whatsapp-float svg{width:28px;height:28px}}.hero{height:100vh;width:100%;position:relative;display:flex;align-items:center;justify-content:center;background:url(/assets/p1-DkKXhgIe.webp) no-repeat center center/cover;padding-top:140px;padding-bottom:120px;text-align:center;overflow:hidden}.hero-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#fff6;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1}.hero-content{position:relative;z-index:2;max-width:900px;padding:0 20px}.hero-content h2{font-size:1.75rem;color:var(--primary);margin-bottom:20px;animation:fadeInDown 1s ease forwards}.hero-content h1{font-size:clamp(2rem,8vw,5.3rem);word-wrap:break-word;overflow-wrap:break-word;margin-bottom:20px;animation:fadeInUp 1s ease .3s forwards;opacity:0}.hero-content h1 span{display:block;font-weight:300;font-style:italic}.hero-content p{font-size:1.6rem;color:var(--text-main);max-width:800px;margin:0 auto 40px;animation:fadeInUp 1s ease .6s forwards;opacity:0;font-weight:700}.hero-btns{display:flex;gap:20px;justify-content:center;animation:fadeInUp 1s ease .9s forwards;opacity:0}.hero-scroll{position:absolute;bottom:30px;left:50%;transform:translate(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:10px;opacity:.6}.hero-scroll span{font-size:.7rem;text-transform:uppercase;letter-spacing:2px}.mouse{width:25px;height:40px;border:2px solid var(--text-muted);border-radius:20px;position:relative}.mouse:before{content:"";width:4px;height:8px;background-color:var(--primary);position:absolute;top:8px;left:50%;transform:translate(-50%);border-radius:2px;animation:scrollWheel 2s infinite}@keyframes scrollWheel{0%{transform:translate(-50%);opacity:1}to{transform:translate(-50%,15px);opacity:0}}@keyframes fadeInUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes fadeInDown{0%{transform:translateY(-30px);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:768px){.hero{height:auto;min-height:100vh;padding-top:120px;padding-bottom:80px}.hero-content h1{font-size:2.2rem;margin-bottom:15px}.hero-content h2{font-size:1.2rem;margin-bottom:15px}.hero-content p{font-size:1.1rem;margin-bottom:30px;font-weight:500}.hero-btns{flex-direction:column;width:100%;gap:15px}.hero-btns .btn{width:100%}.hero-scroll{display:none}}.about{padding:100px 0;background-color:#fff}.about .section-header h2{font-size:2.5rem;max-width:800px;margin:0 auto 15px;line-height:1.2;color:var(--text-main)}.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;margin-top:40px}.about-text p{font-size:1.1rem;line-height:1.8;color:var(--text-muted);margin-bottom:40px}.values-grid{display:flex;flex-wrap:wrap;gap:15px;margin-bottom:40px}.value-item{padding:20px 15px;border-radius:12px;flex:1;min-width:120px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px;box-shadow:0 4px 15px #0000000d}.value-icon{color:var(--primary)}.value-item span{font-size:.85rem;font-weight:700;color:var(--text-main);font-family:var(--font-heading)}.about-link{display:flex;align-items:center;gap:8px;color:var(--text-main);font-weight:700;font-size:.95rem;transition:.3s}.about-link:hover{color:var(--primary);gap:12px}.about-image-container{border-radius:20px;overflow:hidden;box-shadow:0 20px 40px #00000026}.about-image{width:100%;height:auto;display:block;transition:.5s}.about-image-container:hover .about-image{transform:scale(1.05)}@media(max-width:992px){.about-grid{grid-template-columns:1fr;gap:40px}}@media(max-width:768px){.about{padding:60px 0}.about .section-header h2{font-size:1.8rem}.values-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.value-item{min-width:0;padding:15px 10px}}@media(max-width:480px){.values-grid{grid-template-columns:1fr}}.services{background-color:var(--bg-dark);position:relative}.section-header{text-align:center;margin-bottom:60px}.section-header h2{font-size:2.5rem;margin-bottom:15px}.section-header .line{width:60px;height:3px;background-color:var(--primary);margin:0 auto 20px}.section-header p{color:var(--text-muted);font-size:1.1rem}.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px}.service-card{padding:40px;border-radius:var(--border-radius);transition:all .4s ease;cursor:pointer;position:relative;overflow:hidden;background:var(--bg-card)}.service-card:hover{transform:translateY(-10px);background:#fff;box-shadow:0 15px 30px #0000001a;border-color:var(--primary)}.service-icon{font-size:2.5rem;margin-bottom:20px;display:block}.service-card h3{font-size:1.3rem;margin-bottom:15px;color:var(--text-main)}.service-card p{color:var(--text-muted);font-size:.95rem;margin-bottom:25px}.service-link{display:flex;align-items:center;gap:10px;color:var(--primary);font-weight:600;text-transform:uppercase;font-size:.8rem;letter-spacing:1px}.service-link .arrow{transition:transform .3s ease}.service-card:hover .arrow{transform:translate(5px)}@media(max-width:768px){.section-header h2{font-size:1.8rem}.services-grid{grid-template-columns:1fr!important;gap:20px;width:100%}.service-card{padding:30px 20px;width:100%!important;max-width:100%!important}}.projects{padding:100px 0;background-color:var(--bg-card)}.filter-tabs{display:flex;justify-content:center;gap:20px;margin-bottom:50px;padding-bottom:10px}.filter-tab{padding:10px 25px;background:transparent;border:1px solid #ddd;border-radius:30px;color:var(--text-muted);font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap;font-family:inherit}.filter-tab:hover{border-color:var(--primary);color:var(--primary)}.filter-tab.active{background-color:var(--primary);border-color:var(--primary);color:var(--bg-dark)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:30px}.project-card{position:relative;border-radius:var(--border-radius, 12px);overflow:hidden;aspect-ratio:4/3;cursor:pointer;background-color:#eee}.project-image{width:100%;height:100%;position:relative;overflow:hidden}.project-image img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}.project-card:hover .project-image img{transform:scale(1.1)}.project-info{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to top,rgba(4,4,28,.9),transparent);display:flex;flex-direction:column;justify-content:flex-end;padding:25px;opacity:0;transition:opacity .4s ease}.project-card:hover .project-info{opacity:1}.project-info .cat{color:var(--primary);font-size:.8rem;font-weight:700;text-transform:uppercase;margin-bottom:5px}.project-info h3{color:#fff;font-size:1.4rem;margin:5px 0}.project-info p{color:#fffc;font-size:.85rem;margin-bottom:15px}.view-btn{align-self:flex-start;padding:8px 15px;border:1px solid var(--primary);color:var(--primary);font-size:.8rem;font-weight:700;text-decoration:none;border-radius:4px;transition:.3s}.view-btn:hover{background-color:var(--primary);color:var(--bg-dark)}@media(max-width:1024px){.projects-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media(max-width:768px){.projects{padding:60px 0}.filter-tabs{justify-content:flex-start;overflow-x:auto!important;display:flex!important;gap:15px!important;padding:5px 20px 15px;margin-left:-20px;margin-right:-20px;scrollbar-width:none;-ms-overflow-style:none}.filter-tabs::-webkit-scrollbar{display:none}.projects-grid{display:flex!important;overflow-x:auto!important;scroll-snap-type:x mandatory!important;gap:20px!important;padding-bottom:20px;margin-left:-20px;margin-right:-20px;padding-left:20px;padding-right:20px;scrollbar-width:none}.projects-grid::-webkit-scrollbar{display:none}.project-card{flex:0 0 85%!important;scroll-snap-align:center!important;aspect-ratio:16/9}.project-info{opacity:1!important;background:linear-gradient(to top,#04041cd9,#04041c4d)}.project-info h3{font-size:1.2rem}}.budget-calculator{padding:100px 0;background-color:#fff}.calculator-card{max-width:1000px;margin:40px auto 0;padding:50px;border-radius:20px;background-color:#fff;box-shadow:0 15px 50px #00000014;border:1px solid var(--glass-border)}.input-section{margin-bottom:40px}.selection-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:30px}.field-group{display:flex;flex-direction:column;gap:12px}.field-group label{font-size:1rem;font-weight:700;color:var(--text-main)}.select-field,.text-field,.area-field input{width:100%!important;padding:15px 20px;font-size:1rem;border:2px solid #eee;border-radius:12px;outline:none;transition:.3s;background-color:#f9f9f9;color:var(--text-main);font-family:var(--font-body)}.select-field:focus,.text-field:focus,.area-field input:focus{border-color:var(--primary);background-color:#fff;box-shadow:0 5px 15px #f4bc0c1a}.area-field{position:relative}.area-field .unit{position:absolute;right:20px;top:50%;transform:translateY(-50%);font-weight:700;color:var(--text-muted)}.rubros-section label{display:block;font-size:1.1rem;font-weight:700;color:var(--text-main);margin-bottom:25px}.rubros-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.rubro-card{display:flex;align-items:center;gap:15px;padding:20px;background-color:#fff;border:1px solid #eee;border-radius:15px;cursor:pointer;transition:all .3s ease}.rubro-card:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:0 5px 15px #0000000d}.rubro-card.active{background-color:#f4bc0c0d;border-color:var(--primary);box-shadow:0 5px 15px #f4bc0c1a}.checkbox{width:24px;height:24px;border:2px solid #ddd;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:.3s;flex-shrink:0}.active .checkbox{background-color:var(--primary);border-color:var(--primary);color:var(--text-main)}.rubro-info{display:flex;flex-direction:column}.rubro-info .label{font-weight:700;font-size:.95rem;color:var(--text-main)}.rubro-info .price-ratio{font-size:.8rem;color:var(--text-muted)}.result-section{margin-top:50px;padding:40px;background-color:#f8fbff;border-radius:15px;border:1px solid #e1f0ff}.breakdown-details{margin-bottom:30px;padding-bottom:20px;border-bottom:2px dashed #e1f0ff}.breakdown-item{display:flex;justify-content:space-between;padding:12px 0;font-size:.95rem;color:var(--text-muted)}.breakdown-item.highlight{color:var(--text-main);font-weight:700;background-color:#f4bc0c0d;padding:12px 15px;margin:5px -15px;border-radius:8px}.total-box{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px}.total-header{display:flex;align-items:center;gap:15px;color:var(--text-main)}.total-header h3{font-size:1.5rem;margin:0}.total-header svg{color:var(--primary)}.total-value{font-size:2.5rem;font-weight:800;color:#04041c;font-family:var(--font-heading)}.disclaimer{display:flex;gap:12px;padding-top:20px;border-top:1px solid #e1f0ff}.disclaimer svg{color:var(--primary);flex-shrink:0}.disclaimer p{font-size:.85rem;color:var(--text-muted);line-height:1.5;margin:0}.calculator-footer{margin-top:40px;text-align:center}.calculator-footer .btn{padding:15px 40px;font-size:1.1rem;display:inline-flex;align-items:center;gap:12px}@media(max-width:992px){.calculator-card{padding:40px 30px}}@media(max-width:768px){.calculator-card{padding:30px 15px;margin:20px auto 0}.selection-grid{grid-template-columns:1fr!important;gap:15px!important;display:flex!important;flex-direction:column!important}.total-box{flex-direction:column;align-items:flex-start;gap:20px}.total-value{font-size:1.8rem}.total-header h3{font-size:1.2rem}}.contact{background-color:#e5e5e5;padding:100px 5%}.container{max-width:1200px;margin:0 auto;padding:0 20px}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}.contact-info h2{font-size:3rem;margin-bottom:25px;line-height:1.2;color:var(--text-main)}.contact-info h2 span{color:var(--primary);font-weight:300;display:block}.contact-info p{color:var(--text-muted);font-size:1.1rem;margin-bottom:40px}.info-items{display:flex;flex-direction:column;gap:30px}.info-item{display:flex;gap:20px}.info-item .icon{width:auto;height:auto;color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:1.5rem;padding-top:5px}.info-item h4{font-size:.9rem;color:var(--primary);margin-bottom:5px}.info-item p{margin-bottom:0;font-size:1rem;color:var(--text-main)}.info-item a{color:var(--text-main)}.info-item a:hover{color:var(--primary)}.contact-form-container{padding:50px;border-radius:var(--border-radius);background:#fff;box-shadow:0 10px 30px #0000000d;border:1px solid var(--glass-border)}.contact-form{display:flex;flex-direction:column;gap:20px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:15px;background-color:#f8f9fa;border:1px solid var(--glass-border);border-radius:8px;color:var(--text-main);font-family:var(--font-body);outline:none;transition:.3s}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);background-color:#ffffff1a}.contact-form button{width:100%;border:none;transition:all .3s ease}.contact-form button:hover:not(:disabled){background-color:var(--primary-dark);transform:translateY(-2px)}.contact-form button:disabled{opacity:.7;cursor:not-allowed}.success-message{text-align:center;padding:40px 20px;display:flex;flex-direction:column;align-items:center;gap:20px;animation:fadeIn .5s ease}.success-message h3{font-size:1.8rem;color:var(--text-main)}.success-message p{color:var(--text-muted);font-size:1.1rem;margin-bottom:20px}.error-text{color:#ff4d4d;font-size:.9rem;margin-top:15px;text-align:center}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:992px){.contact-grid{grid-template-columns:1fr;gap:50px}}.privacy-policy{padding:120px 5% 60px;background-color:var(--bg-dark);color:var(--text-main);min-height:100vh}.privacy-policy h1{font-size:2rem;color:var(--primary);margin-bottom:40px;text-align:center}.policy-content{max-width:900px;margin:0 auto;background-color:var(--bg-card);padding:40px;border-radius:var(--border-radius);box-shadow:0 5px 20px #0000000d}.policy-content h2{font-size:1.4rem;margin-top:30px;margin-bottom:15px;color:var(--text-main);border-bottom:2px solid var(--accent);padding-bottom:10px}.policy-content p{font-size:1rem;line-height:1.8;color:var(--text-muted);margin-bottom:15px}.policy-content ul{list-style:disc;padding-left:20px;margin-bottom:20px;color:var(--text-muted)}.policy-content li{margin-bottom:8px}.policy-content a{color:var(--primary);text-decoration:underline}.policy-content a:hover{text-decoration:none;color:var(--primary-hover)}.cookies-table{width:100%;border-collapse:collapse;margin:20px 0;font-size:.9rem}.cookies-table th,.cookies-table td{border:1px solid var(--accent);padding:12px;text-align:left}.cookies-table th{background-color:var(--bg-dark);color:var(--primary);font-family:var(--font-heading)}@media(max-width:768px){.cookies-table{display:block;overflow-x:auto}}@media(max-width:768px){.policy-content{padding:20px}.privacy-policy h1{font-size:1.5rem}}.login-page{min-height:100vh;padding:120px 5% 60px;background-color:var(--bg-dark);display:flex;align-items:center;justify-content:center}.login-card{max-width:450px;width:100%;margin:0 auto;padding:50px 40px;border-radius:var(--border-radius);text-align:center}.login-icon{color:var(--primary);margin-bottom:20px}.login-header h1{font-size:1.8rem;margin-bottom:10px;color:var(--text-main)}.login-header p{color:var(--text-muted);font-size:.9rem;margin-bottom:40px}.login-error-message{background-color:#fff2f2;color:#d32f2f;padding:12px;border-radius:8px;margin-bottom:20px;font-size:.9rem;border:1px solid #ffcdd2;text-align:center}.login-form{text-align:left}.login-form .form-group{margin-bottom:25px}.login-form label{display:block;font-size:.85rem;font-weight:600;color:var(--text-main);margin-bottom:8px}.input-with-icon{position:relative;display:flex;align-items:center}.input-with-icon svg{position:absolute;left:15px;color:var(--text-muted)}.input-with-icon input{width:100%;padding:12px 45px;background-color:#00000008;border:1px solid var(--glass-border);border-radius:8px;color:var(--text-main);font-family:var(--font-body);transition:.3s}.password-toggle{position:absolute;right:15px;background:none;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:.3s}.password-toggle:hover{color:var(--primary)}.input-with-icon input:focus{border-color:var(--primary);outline:none;background-color:#fff}.login-options{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.remember-me{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-muted);cursor:pointer}.forgot-password{font-size:.85rem;color:var(--primary)}.login-btn{width:100%;padding:14px;font-size:1rem}.login-footer{margin-top:30px;padding-top:20px;border-top:1px solid var(--glass-border);font-size:.85rem;color:var(--text-muted)}.login-footer a{color:var(--primary);font-weight:600}.dashboard-container{display:flex;min-height:100vh;background-color:#f4f7fa;padding-top:80px}.dashboard-sidebar{width:280px;background-color:#fff;border-right:1px solid #e1e8f0;display:flex;flex-direction:column;padding:30px 20px;position:fixed;height:calc(100vh - 80px);left:0}.sidebar-header{margin-bottom:40px}.sidebar-header h3{font-size:1.2rem;color:var(--text-main);margin:0}.sidebar-header p{font-size:.85rem;color:var(--primary);font-weight:700;text-transform:uppercase}.sidebar-nav{display:flex;flex-direction:column;gap:10px;flex-grow:1}.sidebar-nav a,.sidebar-nav button{display:flex;align-items:center;gap:12px;padding:12px 15px;border-radius:10px;color:var(--text-muted);font-weight:600;transition:.3s;background:none;border:none;width:100%;cursor:pointer;text-align:left;font-family:inherit;font-size:.95rem}.sidebar-nav a:hover,.sidebar-nav a.active,.sidebar-nav button:hover,.sidebar-nav button.active{background-color:#f8fbff;color:var(--primary)}.sidebar-footer{padding-top:20px;border-top:1px solid #eee}.user-info{display:flex;align-items:center;gap:12px;margin-bottom:20px}.avatar{width:40px;height:40px;background-color:var(--primary);color:var(--text-main);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800}.user-info .details{display:flex;flex-direction:column}.user-info .name{font-size:.95rem;font-weight:700;color:var(--text-main)}.user-info .role{font-size:.75rem;color:var(--text-muted);text-transform:capitalize}.logout-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;border-radius:8px;border:1px solid #ff4d4d22;background:none;color:#ff4d4d;font-weight:600;cursor:pointer;transition:.3s}.logout-btn:hover{background-color:#ff4d4d11}.dashboard-main{flex-grow:1;margin-left:280px;padding:40px}.main-header{margin-bottom:40px}.main-header h1{font-size:2rem;color:var(--text-main);margin-bottom:5px}.main-header p{color:var(--text-muted)}.dashboard-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}.card{background:#fff;border-radius:15px;padding:25px;box-shadow:0 4px 15px #00000008;border:1px solid #f0f0f0}.card h3{font-size:1.1rem;margin-bottom:20px;color:var(--text-main)}.stat-card{grid-column:span 1}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.card-header .icon{color:var(--primary)}.progress-container{height:10px;background:#eee;border-radius:5px;margin-bottom:15px;position:relative;overflow:hidden}.progress-bar{height:100%;background:var(--primary);border-radius:5px}.employee-portal-view{padding:50px!important;background:#fff;min-height:400px}.portal-layout{display:flex;gap:60px;align-items:flex-start}.portal-info{flex:1}.portal-info h2{font-size:2.2rem;color:var(--text-main);margin-bottom:25px;text-transform:none;letter-spacing:normal}.portal-description{font-size:1.05rem;color:var(--text-muted);line-height:1.6;margin-bottom:35px}.employee-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:15px}.link-item{display:flex;align-items:center;gap:15px}.link-item a{color:#1a4da1;font-size:1.1rem;font-weight:500;text-decoration:underline;text-underline-offset:4px;text-transform:none;letter-spacing:normal}.link-item a:hover{color:var(--primary)}.bullet{width:6px;height:6px;background-color:var(--text-main);border-radius:50%}.portal-visual{flex:0 0 450px}.visual-placeholder{width:100%;height:300px;background:#f0f0f0;border-radius:4px;overflow:hidden}.visual-placeholder img{width:100%;height:100%;object-fit:cover;opacity:.9}@media(max-width:1200px){.portal-layout{flex-direction:column;gap:40px}.portal-visual{flex:none;width:100%;max-width:600px}}.status-note{font-size:.85rem;color:var(--text-muted);margin-top:15px;padding:10px;background:#f9f9f9;border-radius:8px}.file-list{display:flex;flex-direction:column;gap:12px}.file-item{display:flex;align-items:center;gap:12px;padding:12px;background:#f8fbff;border-radius:10px;color:var(--text-main);font-size:.9rem}.file-item span{flex-grow:1}.download-btn{cursor:pointer;color:var(--text-muted);transition:.3s}.download-btn:hover{color:var(--primary)}.timeline{display:flex;flex-direction:column;gap:20px}.timeline-item{display:flex;gap:15px}.timeline-item strong{display:block;font-size:.95rem}.timeline-item p{font-size:.8rem;color:var(--text-muted)}.done{color:#28a745}.pending{color:#ffc107}.dropzone{border:2px dashed #eee;border-radius:15px;padding:40px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:15px;transition:.3s}.dropzone:hover{border-color:var(--primary);background:#fffcf0}.dropzone p{font-size:.9rem;color:var(--text-muted)}.project-list{display:flex;flex-direction:column;gap:10px}.project-item{display:flex;justify-content:space-between;align-items:center;padding:15px;border:1px solid #eee;border-radius:10px}.proj-info{display:flex;flex-direction:column}.proj-info strong{font-size:.95rem;color:var(--text-main)}.proj-info span{font-size:.8rem;color:var(--text-muted)}.client-list{display:flex;flex-direction:column;gap:12px}.client-item{display:flex;align-items:center;gap:15px;padding:12px;background:#fdfdfd;border:1px solid #f0f0f0;border-radius:10px}.client-item svg{color:var(--primary)}.client-details{display:flex;flex-direction:column}.client-details strong{font-size:.9rem;color:var(--text-main)}.client-details span{font-size:.8rem;color:var(--text-muted)}.badge{padding:4px 10px;border-radius:20px;font-size:.75rem}.badge-success{background:#e6f7eb;color:#28a745}.badge-warning{background:#fff8e6;color:#f4bc0c}.dashboard-error{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.full-width{grid-column:span 2}.table-responsive{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;margin-top:20px}.admin-table th,.admin-table td{text-align:left;padding:15px;border-bottom:1px solid #eee}.admin-table th{font-size:.85rem;text-transform:uppercase;color:var(--text-muted)}.stat-list{display:flex;flex-direction:column;gap:15px;margin-top:10px}.stat-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0}.stat-item span{color:var(--text-muted)}.stat-item strong{font-size:1.2rem;color:var(--primary)}.clock-status{font-size:.9rem;margin-bottom:5px}.clock-status strong{color:#28a745}@media(max-width:1024px){.dashboard-sidebar{width:80px;padding:30px 10px}.sidebar-header h3,.sidebar-header p,.sidebar-nav a span,.details,.user-info .avatar{display:none}.dashboard-main{margin-left:80px}}@media(max-width:768px){.dashboard-grid{grid-template-columns:1fr}}.calendar-view-container{padding:30px}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding:10px 0;border-bottom:1px solid #f0f0f0}.calendar-header h3{margin:0;font-size:1.4rem;color:var(--text-main)}.calendar-grid-header{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:10px}.calendar-day-label{text-align:center;font-weight:700;color:var(--text-muted);font-size:.85rem;text-transform:uppercase}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background-color:#f0f0f0;border:1px solid #f0f0f0;border-radius:10px;overflow:hidden}.calendar-day{background-color:#fff;min-height:100px;padding:10px;display:flex;flex-direction:column;gap:5px;transition:.2s}.calendar-day:not(.empty):hover{background-color:#f8fbff}.calendar-day.empty{background-color:#fafafa}.day-number{font-weight:600;font-size:.9rem;color:var(--text-muted)}.day-label{font-size:.7rem;padding:2px 6px;border-radius:4px;font-weight:700;text-align:center}.day-label.festivo{background-color:#fff1f1;color:#e53e3e}.day-label.vacaciones{background-color:#f0fff4;color:#38a169}.calendar-day.holiday{background-color:#fff9f9}.calendar-day.vacation{background-color:#f7fffb}.calendar-legend{display:flex;gap:20px;margin-top:30px;padding-top:20px;border-top:1px solid #f0f0f0}.legend-item{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-muted)}.dot{width:10px;height:10px;border-radius:50%}.dot.holiday{background-color:#e53e3e}.dot.vacation{background-color:#38a169}@media(max-width:600px){.calendar-grid-header,.calendar-grid{font-size:.8rem}.calendar-day{min-height:60px;padding:5px}.day-label{font-size:.6rem;padding:1px 3px}}.category-page{padding-top:var(--header-height);background-color:var(--bg-dark)}.category-hero{background-color:var(--bg-card);padding:120px 5%;text-align:center}.category-hero h1{font-size:3.5rem;margin-bottom:20px}.category-hero .line{width:80px;height:4px;background-color:var(--primary);margin:0 auto 30px}.back-link{color:var(--primary);font-weight:600;font-family:var(--font-heading);text-transform:uppercase;letter-spacing:1px;font-size:.9rem}.category-projects{padding:60px 5% 100px}.section-subtitle{font-size:1.8rem;margin-bottom:40px;text-align:center}.category-details-info{padding:100px 5% 60px;background-color:#fff}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-bottom:60px}.info-text h2{font-size:2rem;color:var(--text-main);margin-bottom:25px}.info-text p{color:var(--text-muted);margin-bottom:20px;font-size:1.1rem}.info-regulations h3{font-size:1.5rem;color:var(--text-main);margin-bottom:25px}.reg-list{display:flex;flex-direction:column;gap:25px}.reg-item strong{display:block;color:var(--primary);margin-bottom:5px;font-family:var(--font-heading)}.reg-item p{font-size:.95rem;color:var(--text-muted)}.solutions-row{text-align:center;border-top:1px solid var(--accent);padding-top:50px}.solutions-row h3{margin-bottom:30px;color:var(--text-main)}.solutions-chips{display:flex;justify-content:center;flex-wrap:wrap;gap:15px}.solutions-chips span{background-color:var(--accent);color:var(--text-main);padding:8px 18px;border-radius:50px;font-size:.85rem;font-weight:600;font-family:var(--font-heading)}@media(max-width:992px){.info-grid{grid-template-columns:1fr;gap:40px}}@media(max-width:768px){.category-hero h1{font-size:2.5rem}}.project-detail-page{padding-top:var(--header-height);background-color:var(--bg-dark)}.project-hero{height:60vh;position:relative;display:flex;align-items:flex-end;padding-bottom:60px;overflow:hidden}.project-hero-bg{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1}.project-hero-bg img{width:100%;height:100%;object-fit:cover}.project-hero-bg .hero-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to top,#12121ce6,#12121c33)}.project-hero .hero-content{position:relative;z-index:2;color:#fff}.back-link{display:flex;align-items:center;gap:8px;color:var(--primary);font-weight:600;text-transform:uppercase;font-size:.8rem;letter-spacing:1px;margin-bottom:30px}.project-meta{display:flex;gap:20px;margin-bottom:15px}.project-meta span{display:flex;align-items:center;gap:6px;font-size:.9rem;font-weight:500;color:#fffc}.cat-badge{color:var(--primary)!important}.project-hero h1{font-size:clamp(2.5rem,5vw,4rem);line-height:1.1;text-transform:uppercase}.project-intro{padding:100px 5%;background-color:#fff}.intro-text h2{font-size:2.2rem;margin-bottom:30px;color:var(--text-main)}.intro-text p{font-size:1.2rem;line-height:1.8;color:var(--text-muted)}.project-gallery{padding:100px 5%}.project-gallery h2{text-align:center;margin-bottom:60px;font-size:2.2rem}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:25px}.gallery-item{border-radius:var(--border-radius);overflow:hidden;aspect-ratio:4/3;box-shadow:0 10px 20px #0000000d}.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.gallery-item:hover img{transform:scale(1.05)}.project-cta{padding:100px 5%;background-color:var(--bg-card);text-align:center;border-top:1px solid var(--accent)}.project-cta h3{font-size:2rem;margin-bottom:15px}.project-cta p{color:var(--text-muted);margin-bottom:40px}.project-not-found{padding:200px 0;text-align:center}@media(max-width:768px){.project-hero{height:50vh}.gallery-grid{grid-template-columns:1fr}}.App{width:100%;min-height:100vh}main{width:100%}
