.admin-login-container{height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#d8ecff,#416c8b,#c7d1e1);position:relative;overflow:hidden}.admin-login-container:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 80%,rgba(67,109,181,.716) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(14,31,74,.3) 0%,transparent 50%),radial-gradient(circle at 40% 40%,rgba(10,20,45,.2) 0%,transparent 50%);animation:backgroundPulse 8s ease-in-out infinite}.admin-login-wrapper{width:100%;max-width:400px;z-index:2;position:relative;animation:slideInUp .8s ease-out}.admin-login-card{background:#fffffffa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;padding:40px;box-shadow:0 25px 50px #155c8b4d,0 0 0 1px #ffffff1a;position:relative;border:1px solid rgba(21,78,139,.1);animation:cardFloat 6s ease-in-out infinite}.admin-login-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#ffffff1a,#f8f9fa1a);border-radius:20px;z-index:-1}.admin-login-header{text-align:center;margin-bottom:30px;position:relative}.back-button{position:absolute;top:-20px;left:-20px;background:#ffffffe6;border:2px solid rgba(49,93,124,.2);color:#315d7c;cursor:pointer;font-size:14px;padding:8px 12px;border-radius:12px;transition:all .3s ease;font-weight:600;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.back-button:hover{background:#fff;border-color:#315d7c;transform:translate(-3px);box-shadow:0 5px 15px #315d7c33;color:#10334f}.admin-login-header h2{color:#10334f;margin:0 0 15px;font-size:28px;font-weight:800;text-shadow:0 2px 4px rgba(21,109,139,.1);animation:titleGlow 3s ease-in-out infinite}.admin-login-header p{color:#315d7c;margin:0;font-size:15px;line-height:1.5;font-weight:500}.admin-login-form{display:flex;flex-direction:column;gap:25px}.form-group{display:flex;flex-direction:column;gap:10px;position:relative}.password-wrapper{position:relative;display:flex;align-items:center}.password-wrapper input{width:100%;padding-right:50px}.toggle-password{position:absolute;right:15px;top:50%;transform:translateY(-50%);background:transparent;border:none;cursor:pointer;font-size:18px;color:#315d7c;transition:color .3s ease;padding:5px;z-index:1}.toggle-password:hover{color:#1c3d5a}.toggle-password:focus{outline:none}.form-group label{font-weight:700;color:#10334f;font-size:14px;text-transform:uppercase;letter-spacing:.5px}.form-group input{padding:15px 20px;border:2px solid rgba(49,93,124,.2);border-radius:12px;font-size:16px;transition:all .3s ease;font-family:inherit;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;color:#10334f;font-weight:500}.form-group input::placeholder{color:#315d7c;opacity:.6;font-weight:400}.form-group input:focus{outline:none;border-color:#315d7c;box-shadow:0 0 0 4px #315d7c1a,0 8px 25px #315d7c26;background:#fff;transform:translateY(-2px);color:#10334f}.form-group input:disabled{background-color:#f5f5f5e6;cursor:not-allowed;opacity:.7;color:#666}.form-group:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:linear-gradient(90deg,#315d7c,#1c3d5a);transition:width .3s ease;border-radius:1px}.form-group:focus-within:after{width:100%}.error-message{background:#fffffff2;color:#315d7c;padding:15px 20px;border-radius:12px;font-size:14px;text-align:center;border:2px solid rgba(49,93,124,.3);margin:10px 0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:errorShake .5s ease-in-out;font-weight:600;box-shadow:0 4px 15px #315d7c1a}.error-message p{color:#315d7c}.login-button{background:linear-gradient(135deg,#1c3d5a,#2a5a78,#10334f);color:#fff;border:none;padding:16px 24px;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;font-family:inherit;text-transform:uppercase;letter-spacing:1px;position:relative;overflow:hidden;box-shadow:0 8px 25px #155c8b4d;text-shadow:0 1px 2px rgba(0,0,0,.3)}.login-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.login-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 12px 35px #155c8b66;background:linear-gradient(135deg,#1d4f78,#2e6c91,#1a3f5f);color:#fff}.login-button:hover:not(:disabled):before{left:100%}.login-button:disabled{opacity:.7;cursor:not-allowed;transform:none;animation:buttonPulse 1.5s ease-in-out infinite;color:#fff}.login-button:disabled:after{content:"";position:absolute;width:20px;height:20px;margin:auto;border:3px solid transparent;border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;top:0;left:0;bottom:0;right:0}.login-button:active:not(:disabled){transform:translateY(-1px)}.login-info{margin-top:30px;padding:25px;background:#fffffff2;border-radius:15px;font-size:13px;color:#315d7c;border-left:4px solid #1c3d5a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(49,93,124,.1);animation:infoGlow 4s ease-in-out infinite;box-shadow:0 4px 15px #315d7c1a}.login-info p{margin:8px 0;line-height:1.5;font-weight:500}.login-info strong{color:#10334f;font-weight:800}.admin-login-container:after{content:"";position:absolute;width:6px;height:6px;background:#fff6;border-radius:50%;animation:floatingParticles 15s linear infinite;box-shadow:25px 18px #ffffff4d,50px 35px #fff3,75px 55px #ffffff1a,100px 70px #ffffff4d}@media (max-width: 480px){.admin-login-container{padding:15px}.admin-login-card{padding:30px 20px;border-radius:15px}.admin-login-header h2{font-size:24px}.form-group input{font-size:16px;padding:12px 16px}.login-button{padding:14px 20px}}@media (max-width: 360px){.admin-login-card{padding:25px 15px}.back-button{top:-15px;left:-15px;padding:6px 10px;font-size:12px}}@keyframes backgroundPulse{0%,to{opacity:1}50%{opacity:.8}}@keyframes slideInUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}@keyframes cardFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}@keyframes titleGlow{0%,to{text-shadow:0 2px 4px rgba(21,92,139,.1)}50%{text-shadow:0 4px 8px rgba(21,92,139,.2),0 0 15px rgba(21,92,139,.1)}}@keyframes errorShake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@keyframes buttonPulse{0%,to{box-shadow:0 8px 25px #155c8b4d}50%{box-shadow:0 8px 25px #155c8b80}}@keyframes infoGlow{0%,to{box-shadow:0 4px 15px #315d7c1a}50%{box-shadow:0 6px 20px #315d7c26}}@keyframes floatingParticles{0%{transform:translateY(100vh) rotate(0);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateY(-100px) rotate(360deg);opacity:0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.back-button:focus,.login-button:focus,.form-group input:focus{outline:3px solid rgba(49,93,124,.3);outline-offset:2px}@media (prefers-contrast: high){.admin-login-card{border:3px solid #1c3d5a;background:#ffffff50}.form-group input{border-color:#1c3d5a;color:#000}.login-button{background:#1c3d5a;border:2px solid #1c3d5a;color:#fff}.admin-login-header h2,.form-group label{color:#000}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@supports (backdrop-filter: blur(20px)){.admin-login-card{background:#ffffff43;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2)}.form-group input{background:#ffffff8e;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.form-group input:focus{background:#fff}.login-info{background:#ffffffe6}.error-message{background:#fffffff2}}.admin-dashboard{display:flex;height:100vh;background:#f9fafb;font-family:Arial,sans-serif;overflow:hidden}.admin-sidebar{height:100%;width:250px;background:#111827;color:#fff;padding:20px;transition:transform .3s ease;position:relative;z-index:1000;display:flex;flex-direction:column}.admin-sidebar-header{display:flex;align-items:center;gap:10px;margin-bottom:30px;cursor:pointer}.admin-logo{background:#2563eb;width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.admin-menu{flex-grow:1;display:flex;flex-direction:column;gap:10px;overflow-y:auto;padding-right:5px}.admin-menu-item{background:transparent;border:none;color:#9ca3af;padding:12px 10px;text-align:left;cursor:pointer;display:flex;align-items:center;gap:10px;border-radius:6px;transition:all .2s ease;font-size:14px}.admin-menu-item:hover,.admin-menu-item.admin-active{background:#1f2937;color:#fff}.admin-logout{margin-top:auto}.admin-logout .admin-menu-item{width:100%;text-align:left}.admin-sidebar-close{display:none;position:absolute;top:20px;right:20px;background:transparent;border:none;color:#fff;cursor:pointer;padding:5px;font-size:20px}.admin-sidebar-overlay{display:none}@media (max-width: 768px){.admin-sidebar{position:fixed;top:0;left:0;transform:translate(-100%);width:280px;height:100vh;box-shadow:2px 0 10px #00000026}.admin-sidebar.mobile-open{transform:translate(0)}.admin-sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:900;display:none}.admin-sidebar-overlay.active,.admin-sidebar-close{display:block}.admin-menu-item{padding:16px 10px;font-size:16px}.admin-content{flex:1;padding:20px;overflow-y:auto;width:100%}}.admin-content{flex:1;padding:20px;overflow-y:auto}.admin-main{flex:1;display:flex;flex-direction:column;min-width:0}.admin-header{background:#fff;border-bottom:1px solid #e5e7eb;padding:15px 20px;display:flex;justify-content:space-between;align-items:center;position:relative}.admin-mobile-menu-btn{font-size:20px;display:none;background:transparent;border:none;cursor:pointer;padding:8px;border-radius:4px}@media (max-width: 768px){.admin-header{padding:12px 16px}.admin-mobile-menu-btn{font-size:20px;display:block;order:-1;margin-right:12px}}.admin-header h1{font-size:20px;margin:0;color:#111827}.admin-header p{color:#6b7280;margin:0;font-size:14px}@media (max-width: 480px){.admin-header h1{font-size:18px}.admin-header p{display:none}}.admin-header-actions{display:flex;align-items:center;gap:15px}.admin-search-box{position:relative}.admin-search-box input{padding:8px 12px 8px 36px;border:1px solid #d1d5db;border-radius:6px;width:250px;font-size:14px;transition:width .3s ease}.admin-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#9ca3af}@media (max-width: 1024px){.admin-search-box input{width:200px}}@media (max-width: 768px){.admin-search-box input{width:150px;padding:8px 8px 8px 32px}}@media (max-width: 480px){.admin-search-box{display:none}}.admin-icon-btn{border:none;background:transparent;cursor:pointer;padding:8px;border-radius:4px;transition:background-color .2s ease}.admin-icon-btn:hover{background:#f3f4f6}.admin-avatar{background:#2563eb;color:#fff;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0}.admin-content{padding:20px;display:flex;flex-direction:column;gap:20px;overflow-x:hidden;flex:1}@media (max-width: 768px){.admin-content{padding:16px;gap:16px}}@media (max-width: 480px){.admin-content{padding:12px;gap:12px}}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}@media (max-width: 768px){.admin-stats-grid{grid-template-columns:1fr;gap:16px}}@media (max-width: 480px){.admin-stats-grid{grid-template-columns:1fr;gap:12px}}.admin-card{background:#fff;border-radius:10px;padding:20px;border:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a}@media (max-width: 768px){.admin-card{padding:16px}}@media (max-width: 480px){.admin-card{padding:14px;border-radius:8px}}.admin-card.admin-dark{background:#111827;color:#fff}.admin-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.admin-card-header h3{margin:0;font-size:18px;font-weight:600}@media (max-width: 480px){.admin-card-header h3{font-size:16px}}.admin-grid-2{display:grid;grid-template-columns:2fr 1fr;gap:20px}@media (max-width: 1024px){.admin-grid-2{grid-template-columns:1fr 1fr}}@media (max-width: 768px){.admin-grid-2{grid-template-columns:1fr;gap:16px}}.admin-project-item{display:flex;justify-content:space-between;align-items:flex-start;padding:12px;border-radius:8px;transition:background-color .2s ease;gap:12px}.admin-project-item:hover{background:#f3f4f6}@media (max-width: 480px){.admin-project-item{flex-direction:column;align-items:stretch;gap:8px}}.admin-project-info{display:flex;gap:12px;align-items:flex-start;flex:1;min-width:0}.admin-avatar-sm{width:40px;height:40px;background:#e5e7eb;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.admin-project-name{margin:0 0 4px;font-weight:600;font-size:14px;line-height:1.3}.admin-project-client{font-size:13px;color:#6b7280;margin:0 0 4px}.admin-location{display:flex;align-items:center;font-size:12px;color:#9ca3af;gap:4px}.admin-project-meta{text-align:right;flex-shrink:0;display:flex;flex-direction:column;gap:4px;align-items:flex-end}@media (max-width: 480px){.admin-project-meta{flex-direction:row;justify-content:space-between;align-items:center;text-align:left}}.admin-project-meta p{margin:0;font-size:13px;font-weight:600;color:#111827}.admin-badge{padding:4px 8px;border-radius:12px;font-size:11px;font-weight:500;display:inline-block;white-space:nowrap}@media (max-width: 480px){.admin-badge{font-size:10px;padding:3px 6px}}.admin-badge-green{background:#d1fae5;color:#065f46}.admin-badge-blue{background:#dbeafe;color:#1e3a8a}.admin-badge-yellow{background:#fef3c7;color:#92400e}.admin-badge-gray{background:#f3f4f6;color:#374151}.admin-stats-circle{margin:20px auto;width:120px;height:120px;border:6px solid #3b82f6;border-radius:50%;display:flex;align-items:center;justify-content:center;text-align:center}@media (max-width: 480px){.admin-stats-circle{width:100px;height:100px;border-width:4px;margin:16px auto}.admin-stats-circle h2{font-size:16px}.admin-stats-circle p{font-size:12px}}.admin-categories{display:flex;flex-direction:column;gap:12px}.admin-category-item{display:flex;align-items:center;justify-content:space-between;gap:8px}.admin-category-item span:nth-child(2){flex:1;font-size:14px}@media (max-width: 480px){.admin-category-item span:nth-child(2){font-size:13px}}.admin-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.admin-dot.blue{background:#3b82f6}.admin-dot.green{background:#10b981}.admin-dot.purple{background:#8b5cf6}.admin-dot.orange{background:#f97316}.admin-dot.teal{background:#14b8a6}.admin-count{font-weight:600;font-size:14px}.admin-trend{color:#10b981;flex-shrink:0}.admin-link-btn{background:transparent;border:none;color:#2563eb;cursor:pointer;font-size:14px;text-decoration:none;padding:4px 0}.admin-link-btn:hover{text-decoration:underline}@media (max-width: 768px){.admin-card h2{font-size:20px}.admin-card h3{font-size:16px}}@media (max-width: 480px){.admin-card h2{font-size:18px}.admin-card h3{font-size:15px}}@media (max-width: 768px){.admin-content{overflow-y:auto;-webkit-overflow-scrolling:touch}}.project-management{min-height:100vh;background-color:#f9fafb}.container_projectsAdmin{max-width:1200px;margin:0 auto;padding:32px 16px}.modalProject-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;justify-content:center;align-items:center;z-index:1000;padding:2rem;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modalProject-content{background:var(--cardP);z-index:1000;border-radius:20px;max-width:900px;max-height:85vh;overflow-y:auto;position:relative;box-shadow:0 25px 50px #00000040}.modalProject-name{margin:20px}.modalProject-header{padding:2.5rem 2.5rem 1.5rem;display:flex;justify-content:space-between;align-items:flex-start;border-bottom:1px solid var(--borderP)}.modalProject-header h2{color:var(--foregroundP);margin:0;font-size:2rem;font-weight:700}.modalProject-subtitle{color:var(--mutedP-foreground);margin:.5rem 0 0;font-size:1rem}.form{display:flex;flex-direction:column;gap:20px;padding:2rem}.form-gridProject{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}label{font-weight:600;margin-bottom:6px;color:#111827}input,textarea,select{padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;transition:border-color .2s,box-shadow .2s;background-color:#fff}input:focus,textarea:focus,select:focus{border-color:#2a3a4e;outline:none;box-shadow:0 0 0 3px #2a3a4e33}textarea{min-height:120px;resize:vertical}.help-text{font-size:.85rem;color:#6b7280;margin-bottom:8px}.uploadAdm-box{border:2px dashed #d1d5db;border-radius:12px;padding:2rem;text-align:center;cursor:pointer;transition:border-color .2s,background .2s}.uploadAdm-box:hover{border-color:#2a3a4e;background:#f9fafb}.uploadAdm-icon{color:#6b7280;margin-bottom:.5rem}.upload-label{cursor:pointer;font-weight:500;color:#2a3a4e}.upload-label input{display:none}.upload-hint{font-size:.8rem;color:#9ca3af;margin-top:.5rem}.files_container{display:flex;flex-direction:column;gap:12px;margin-top:1rem}.file_item{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;position:relative}.file_order{font-weight:700;color:#374151;min-width:24px}.file_background{flex-shrink:0}.preview-file{width:60px;height:60px;object-fit:cover;border-radius:6px;border:1px solid #d1d5db}.file_name{flex:1;font-size:.9rem;color:#111827;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge_portada{position:absolute;top:8px;left:8px;background:#2a3a4e;color:#fff;font-size:.7rem;padding:2px 6px;border-radius:4px}.icon_closeimage{cursor:pointer;transition:transform .2s}.icon_closeimage:hover{transform:scale(1.1)}.order_buttons{display:flex;align-items:center;gap:6px}.order_buttons button{background:none;border:none;cursor:pointer}.form-actions{display:flex;justify-content:flex-end;gap:12px;border-top:1px solid #e5e7eb;padding-top:16px;margin-top:1rem}.btn-outline{padding:8px 16px;border-radius:6px;cursor:pointer;font-weight:500;border:1px solid #ccc;background:#fff;color:#333;transition:background .2s}.btn-createProject{padding:8px 16px;border-radius:6px;cursor:pointer;font-weight:500;border:none;background:#2a3a4e;color:#fff;transition:background .2s}.btn-createProject:hover{background:#425d7d}@media (max-width: 768px){.form-gridProject{display:flex;flex-direction:column;gap:12px}}.projectAdmin-header{margin-bottom:2rem}.projectAdmin-header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.projectAdmin-header-title{font-size:1.875rem;font-weight:700;color:#111827}.projectAdmin-header-subtitle{margin-top:.25rem;color:#4b5563}.btn-createProject{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-size:.875rem;font-weight:500;border-radius:.5rem;padding:.5rem 1rem;cursor:pointer;border:none;background-color:#2a3a4e;color:#fff;transition:all .3s ease-in}.btn-createProject:hover{background-color:#425d7d}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-size:.875rem;font-weight:500;border-radius:.5rem;padding:.5rem 1rem;cursor:pointer;border:none}.btn-black{background:#000;color:#fff}.icon{width:1rem;height:1rem}.projectAdmin-header-filters{display:flex;width:100%;align-items:center;justify-content:center;gap:1rem;background:#fff;padding:1rem;border-radius:.75rem;border:1px solid #e5e7eb;box-shadow:0 1px 2px #0000000d}.search-box{position:relative;flex:1;max-width:50rem}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:#9ca3af;width:1rem;height:1rem}.search-input{width:100%;padding:.5rem .75rem .5rem 2.5rem;border:1px solid #d1d5db;border-radius:.5rem;outline:none}.search-input:focus{border-color:#111827}.select{padding:.5rem;border-radius:.5rem;border:1px solid #d1d5db;background:#fff;cursor:pointer}.view-toggle{display:flex;gap:.5rem}.btn-outline{background:#fff;border:1px solid #d1d5db;color:#111827}.small{padding:.25rem .5rem}@media (max-width: 1024px){.projectAdmin-header-top{flex-direction:column;align-items:flex-start;gap:1rem}.projectAdmin-header-title{font-size:1.5rem}.projectAdmin-header-filters{flex-wrap:wrap;gap:.75rem;padding:.75rem}.search-box{flex:1 1 100%;max-width:100%}.select{flex:1 1 48%}}@media (max-width: 768px){.projectAdmin-header-top{align-items:center;text-align:center}.projectAdmin-header-subtitle{font-size:.9rem}.btn,.btn-black{width:100%;justify-content:center}.projectAdmin-header-filters{flex-direction:column;align-items:stretch}.search-box{flex:1 1 100%;max-width:100%}.select{width:100%}}@media (max-width: 480px){.projectAdmin-header-title{font-size:1.25rem}.search-input{font-size:.85rem;padding:.4rem .6rem .4rem 2rem}.select{font-size:.85rem;padding:.4rem}.form-gridProject{display:flex;flex-direction:column;margin:10px}}.projectsAdmin-grid{display:flex;width:75vw;justify-content:center;flex-wrap:wrap;gap:24px;margin:24px}.pagination{display:flex;justify-content:center;align-items:center;gap:12px;margin-top:16px}.pagination button{background-color:#111827;color:#fff;align-items:center;justify-content:center;padding:.75rem 2rem;border-radius:.5rem;font-weight:600;text-decoration:none;border:none;cursor:pointer;position:relative;overflow:hidden}.container-projects{display:flex;flex-direction:column;max-width:1200px;margin:0 auto;padding:0 1rem}.cardAdmin{background:#fff;width:22rem;border-radius:10px;overflow:hidden;transition:box-shadow .2s ease;box-shadow:0 1px 3px #0000001a}.cardAdmin:hover{box-shadow:0 6px 20px #00000026}.cardAdmin-image-wrapper{position:relative}.cardAdmin-image{width:100%;height:190px;object-fit:cover;display:block;border-bottom:1px solid #eee}.favorite-btn{position:absolute;top:8px;right:8px;background:#ffffffd9;border-radius:50%;border:none;padding:6px 8px;cursor:pointer;font-size:14px}.favorite-btn:hover{background:#fff}.cardAdmin-content{padding:16px}.cardAdmin-header{display:flex;align-items:start;justify-content:space-between;margin-bottom:8px}.cardAdmin-title{font-size:1.1rem;font-weight:600;color:#111;margin:0;max-width:80%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dropdown{position:relative;display:inline-block}.dropdown .icon-button{background:none;border:none;font-size:20px;cursor:pointer}.dropdown-menu{position:absolute;top:100%;right:0;background:#fff;border:1px solid #ddd;border-radius:8px;padding:8px 0;min-width:180px;box-shadow:0 4px 12px #00000026}.dropdown-menu button{display:block;width:100%;padding:8px 12px;text-align:left;background:none;border:none;cursor:pointer}.dropdown-menu button:hover{background:#f5f5f5}.cardAdmin-description{font-size:.9rem;color:#666;margin-bottom:12px;line-height:1.4;max-height:40px;overflow:hidden;text-overflow:ellipsis}.cardAdmin-badges{display:flex;gap:6px;margin-bottom:12px}.badge{font-size:12px;padding:4px 8px;border-radius:6px;font-weight:500;display:inline-block}.badge-outline{border:1px solid #ccc;background:#fff;color:#333}.badge-blue{background:#dbeafe;color:#1e3a8a}.badge-yellow{background:#fef9c3;color:#854d0e}.badge-gray{background:#f3f4f6;color:#374151}.badge-green{background:#dcfce7;color:#166534}.cardAdmin-info{display:flex;flex-direction:column;gap:6px;font-size:.9rem;color:#555}.info-item{display:flex;align-items:center;gap:6px}.cardAdmin-footer{margin-top:16px;padding-top:12px;border-top:1px solid #eee}.cardAdmin-budget{font-size:1.5rem;font-weight:700;color:#111}.favorite-btn{position:absolute;top:8px;right:8px;background:#fff;border-radius:50%;padding:6px;display:flex;align-items:center;justify-content:center}.favorite-btn.is-favorite{background:#ffe6e6}@media (min-width: 768px){.project-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.project-grid{grid-template-columns:repeat(3,1fr)}}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#1e1e1e99;display:flex;justify-content:center;align-items:center;z-index:2000}.modal-content{background:#fff;border-radius:10px;max-width:700px;width:100%;max-height:90vh;overflow-y:auto;padding:20px;box-shadow:0 8px 30px #00000040}.modal-header{margin-bottom:20px}.modal-title{font-size:1.4rem;font-weight:700;margin:0}.modal-subtitle{font-size:.95rem;color:#666}.form{display:flex;flex-direction:column;gap:20px}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.form-group{display:flex;flex-direction:column}.form-group.full-width{grid-column:span 2}label{font-weight:500;margin-bottom:6px}input,textarea,select{padding:8px 10px;border:1px solid #ccc;border-radius:6px;font-size:.95rem;transition:border-color .2s}input:focus,textarea:focus,select:focus{border-color:#000;outline:none}textarea{min-height:100px;resize:vertical}.form-actions{display:flex;justify-content:flex-end;gap:12px;border-top:1px solid #ddd;padding-top:16px}.btn{padding:8px 16px;border-radius:6px;cursor:pointer;font-weight:500;transition:background .2s}.btn-outline{border:1px solid #ccc;background:#fff;color:#333}.btn-outline:hover{background:#f5f5f5}.btn-primary{background:#000;color:#fff;border:none}.modalAdm-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background:#1e1e1e99;display:flex;justify-content:center;align-items:center;z-index:100}.modalAdm-content{background:#fff;border-radius:10px;max-width:700px;width:100%;max-height:85vh;overflow-y:auto;padding:20px;box-shadow:0 8px 30px #00000040}.modalAdm-title{font-size:1.25rem;font-weight:600;margin-bottom:1.5rem;color:#111827}.uploadAdmEdit-box{text-align:center;padding:1.5rem 2rem;border:2px dashed #d1d5db;border-radius:.75rem;cursor:pointer;transition:all .2s}.uploadAdmEdit-box:hover{border-color:#2a3a4e;background:#f9fafb}.hidden-file-input{display:none}.uploadAdmEdit-icon{width:3rem;height:3rem;color:#9ca3af;margin:0 auto 1rem}.uploadAdmEdit-text{font-size:1.125rem;font-weight:500;color:#111827;margin-bottom:.25rem}.uploadAdmEdit-subtext{color:#4b5563;margin-bottom:1rem}.sectionUpload-title{font-size:2rem;font-weight:500;margin-bottom:1rem}.images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.image-card{position:relative;cursor:pointer;border-radius:.5rem;overflow:hidden;border:2px solid #e5e7eb;transition:all .2s}.image-card:hover{border-color:#d1d5db}.image-card.selected{border-color:#3b82f6;box-shadow:0 0 0 3px #bfdbfe}.image{width:100%;height:8rem;object-fit:cover}.badge{position:absolute;top:.5rem;left:.5rem;background:#000;color:#fff;font-size:.75rem;padding:.125rem .5rem;border-radius:.25rem}.overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#3b82f633;display:flex;align-items:center;justify-content:center}.checkmark{background:#3b82f6;color:#fff;border-radius:9999px;padding:.25rem}.checkmark-icon{width:1rem;height:1rem}.modalAdm-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1rem;border-top:1px solid #e5e7eb;margin-top:1.5rem}.btn-outline,.btn-black{padding:.5rem 1rem;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-outline{border:1px solid #d1d5db;background:#fff;color:#111827}.btn-outline:hover{background:#f3f4f6}.btn-black{background:#000;color:#fff;border:none}.btn-black:hover{background:#1f2937}.files_containerEdit{display:flex;justify-content:center;flex-wrap:wrap;gap:15px;margin-top:15px;max-height:300px;overflow-y:auto;padding:10px;border:1px solid #e5e7eb;border-radius:10px;background:#f9fafb}.file_itemEdit{position:relative;width:180px;aspect-ratio:1 / 1;border:2px solid #e5e7eb;border-radius:12px;overflow:hidden;box-shadow:0 2px 6px #00000014;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:transform .2s ease,box-shadow .2s ease}.file_itemEdit:hover{transform:scale(1.03);box-shadow:0 4px 12px #00000026}.preview-file{width:100%;height:7rem;object-fit:cover;border-bottom:1px solid #e5e7eb;background:#f9f9f9}.file_background{position:relative;width:100%;height:7rem}.file_background:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background-color:#0000003f;border-radius:10px;z-index:1}.file_name{font-size:14px;color:#374151;text-align:center;padding:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:95%}.file_order{position:absolute;color:#fff;font-size:20px;z-index:10}.icon_closeimage{position:absolute;top:6px;right:6px;cursor:pointer;background:#fff;border-radius:50%;box-shadow:0 2px 5px #00000026;transition:transform .2s ease;z-index:10}.icon_closeimage:hover{transform:scale(1.2)}.badge_portada{position:absolute;top:8px;left:8px;background:#38b0db;color:#fff;font-size:12px;font-weight:700;padding:4px 8px;border-radius:6px;box-shadow:0 2px 4px #00000026;z-index:10}.order_buttons{display:flex;gap:5px;margin-top:6px;margin-bottom:6px}.order_buttons button{display:flex;align-items:center;justify-content:center;width:30px;height:30px;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:14px;transition:background .2s ease}.icon_image{text-align:center;justify-content:center;align-items:center;color:#34435c}.order_buttons button:hover{background:#e5e7eb}@media (max-width: 1024px){.modalAdm-content{width:80vw;max-width:650px;padding:16px}.images-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem}.image{height:6rem}}@media (max-width: 768px){.modalAdm-content{display:flex;flex-direction:column;width:90vw;max-width:500px;padding:12px}.images-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem}.image{height:5rem}.modalAdm-title,.sectionUpload-title{text-align:center}.uploadAdmEdit-text{font-size:1rem}.uploadAdmEdit-subtext{font-size:.85rem}}@media (max-width: 480px){.modalAdm-content{width:100vw;max-width:350px;padding:10px}.images-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.4rem}.image{height:4rem}.uploadAdmEdit-icon{width:2.5rem;height:2.5rem}.uploadAdmEdit-text{font-size:.95rem}.uploadAdmEdit-subtext{font-size:.8rem}}:root{--PrimaryBlue: #2a3a4e;--SecundaryBlue: #456080;--PrimaryBackground: #bcc8d37a;--SecundaryBackground: #F4F4F4;--PrimaryTextColor: #5B5858;--HoverTextColor: white}.modal_confirm{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s ease-in-out}.modal_content{background-color:#fff;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);padding:20px;display:flex;flex-direction:column;align-items:center;border-radius:8px;box-shadow:0 4px 8px #0000001a;z-index:1000;animation:fadeIn .4s ease-in-out}.modal_content h2{text-align:center;margin-top:10px;margin-bottom:10px}.modal_projectName{font-size:20px}.modal_actions{display:flex;justify-content:space-between;width:100%;gap:20px;margin-top:15px}.modal_actions button{padding:10px 20px;font-size:16px;background-color:var(--SecundaryBlue);color:#fff;border:none;border-radius:5px;cursor:pointer;transition:background-color .3s ease}.modal_actions button:hover{background-color:var(--PrimaryBlue)}.modalFile{position:fixed;top:0;left:0;width:100%;height:100%;background:#1e1e1e99;display:flex;justify-content:center;align-items:center;z-index:50;padding:1rem;box-sizing:border-box}.file-modal-content{position:relative;background:#fff;border-radius:10px;width:60vw;height:90vh;max-width:900px;max-height:90vh;display:flex;justify-content:center;align-items:center;box-shadow:0 8px 30px #00000040;overflow:hidden}.preview-full{width:100%;height:100%;object-fit:contain;border-radius:8px;box-shadow:0 4px 15px #0003}.close-modal-btn{position:absolute;top:10px;left:10px;background:#ff4b4b;border:none;color:#fff;font-size:18px;font-weight:700;width:35px;height:35px;border-radius:50%;cursor:pointer;display:flex;justify-content:center;align-items:center;z-index:100;transition:background .2s}.close-modal-btn:hover{background:#ff1a1a}@media (max-width: 1024px){.file-modal-content{width:80vw;height:85vh}}@media (max-width: 768px){.file-modal-content{width:90vw;height:85vh}}@media (max-width: 480px){.file-modal-content{width:95vw;height:80vh}.close-modal-btn{width:30px;height:30px;font-size:16px}}.header{position:fixed;top:0;width:100%;background:#2a3a4ef2;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);color:var(--color-light);padding:.5rem 0;z-index:50;border-bottom:1px solid rgba(79,137,189,.2);transition:var(--transition-normal)}.header-container{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;justify-content:space-between;align-items:center}.logo{display:flex;align-items:center;width:5.5rem;cursor:pointer}.logo-img{width:100%;height:100%;border-radius:10%;display:flex;align-items:center;justify-content:center;color:#fff}.nav{display:none;gap:2rem}.nav a{position:relative;color:var(--color-light);text-decoration:none;transition:var(--transition-normal)}.nav a:hover,.nav a.active{color:var(--color-secondary)}.nav a:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--gradient-accent);transition:var(--transition-normal)}.nav a:hover:after,.nav a.active:after{width:100%}.header-contact{display:none;align-items:center;gap:.5rem;font-size:.875rem}.header-contact a{color:#fff;text-decoration:none;cursor:pointer;font-weight:500;transition:all .2s ease-in}.header-contact a:hover{color:#5a7ea7f2;transition:all .2s ease-in}.mobile-menu-btn{display:block;background:none;border:none;color:var(--color-light);cursor:pointer}.mobile-menu{position:absolute;top:100%;left:0;width:100%;background:#2a3a4efa;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid rgba(79,137,189,.2);padding:1rem}.mobile-menu nav{display:flex;flex-direction:column;gap:1rem}.mobile-menu a{color:var(--color-light);text-decoration:none;transition:var(--transition-normal)}.mobile-menu a:hover{color:var(--color-secondary)}.hero-section{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;padding-top:8rem;padding-bottom:4rem}.hero-background{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,var(--color-primary),rgba(42,58,78,.95),rgba(79,137,189,.2))}.hero-decorative{position:absolute}.hero-decorative-1{top:25%;right:25%;width:128px;height:128px;border:2px solid rgba(79,137,189,.3);transform:rotate(45deg);animation:spin-slow 20s linear infinite}.hero-decorative-2{bottom:25%;left:25%;width:96px;height:96px;background:linear-gradient(135deg,rgba(79,137,189,.2),transparent);border-radius:50%;animation:bounce-slow 3s ease-in-out infinite}.hero-container{max-width:1200px;margin:0 auto;padding:0 1rem;position:relative;z-index:10}.hero-grid{display:grid;gap:3rem;align-items:center}.hero-content{text-align:center;color:var(--color-light)}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;background:#4f89bd33;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(79,137,189,.3);border-radius:9999px;padding:.5rem 1.5rem;margin-bottom:2rem;font-size:.875rem;font-weight:500;color:var(--color-accent)}.hero-title{font-size:3rem;font-weight:700;margin-bottom:1.5rem;line-height:1.1}.hero-title-gradient{background:var(--gradient-accent);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.hero-description{font-size:1.25rem;color:#e8e5e0e6;margin-bottom:2rem;line-height:1.6}.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:2rem}.hero-stat{text-align:center;transition:var(--transition-normal)}.hero-stat:hover{transform:scale(1.1)}.hero-stat-value{font-size:2rem;font-weight:700;color:var(--color-secondary)}.hero-stat-label{font-size:.875rem;color:#e8e5e0cc}.hero-buttons{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.hero-contact{display:flex;flex-direction:column;gap:1rem;color:#e8e5e0cc}.hero-contact-item{display:flex;align-items:center;gap:.5rem}.hero-images-wrapper{position:relative}.hero-images{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;padding:1rem}.hero-images-column{display:flex;flex-direction:column;gap:1rem}.hero-images-column.pt{padding-top:2rem}.hero-image{height:16rem;width:100%;border-radius:1rem;overflow:hidden;transition:var(--transition-slow);box-shadow:var(--shadow-lg)}.hero-image:hover{transform:rotate(0) scale(1.05)}.hero-image.rotate-2{transform:rotate(2deg)}.hero-image.rotate--1{transform:rotate(-1deg)}.hero-image.rotate-1{transform:rotate(1deg)}.hero-image.rotate--2{transform:rotate(-2deg)}.hero-image img{width:100%;height:100%;object-fit:cover;transition:var(--transition-slow)}.hero-image:hover img{transform:scale(1.1)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 2rem;border-radius:.5rem;font-weight:600;text-decoration:none;border:none;cursor:pointer;transition:var(--transition-normal);position:relative;overflow:hidden}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-lg)}.btn-primary:hover{transform:scale(1.05);box-shadow:var(--shadow-xl)}.btn-secondary{background:transparent;color:var(--color-accent);border:2px solid var(--color-accent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.btn-secondary:hover{background:var(--color-accent);color:var(--color-primary);transform:scale(1.05)}.btn-lg{padding:1rem 2rem;font-size:1.125rem}.services-section{padding:5rem 0;background:linear-gradient(135deg,var(--color-light),rgba(232,229,224,.3));position:relative}.section-badge{display:inline-flex;align-items:center;gap:.5rem;background:#4f89bd1a;border-radius:9999px;padding:.5rem 1.5rem;margin-bottom:1.5rem;font-size:.875rem;font-weight:500;color:var(--color-primary)}.section-title{font-size:2rem;font-weight:700;color:#4f89bd;margin-bottom:1.5rem}.section-title-gradient{background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.section-description{font-size:1.25rem;color:#2a3a4eb3;max-width:48rem;margin:0 auto}.services-grid{display:grid;grid-template-columns:1fr;gap:2rem;margin-bottom:3rem}@media (min-width: 640px){.services-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.services-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1440px){.services-grid{grid-template-columns:repeat(4,1fr)}}.service-card{display:flex;justify-content:center;text-align:center;overflow:hidden;border:none;border-radius:1rem;box-shadow:var(--shadow-lg);background:linear-gradient(135deg,var(--color-light),rgba(232,229,224,.5));-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:var(--transition-slow)}.service-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl)}.service-card-content{padding:1.5rem;position:relative;z-index:10}.service-icon-container{display:flex;justify-content:center;align-items:center;width:40px;height:40px;background:var(--gradient-primary);border-radius:50%;color:#fff;margin:0 auto 1rem;transition:var(--transition-normal)}@media (min-width: 640px){.service-icon-container{width:40px;height:40px}}@media (min-width: 1024px){.service-icon-container{width:60px;height:60px}}.service-title{font-size:1.25rem;font-weight:700;color:var(--color-primary);margin-bottom:.75rem;transition:var(--transition-normal)}.service-card:hover .service-title{color:var(--color-secondary)}.service-description{color:#2a3a4eb3;margin-bottom:1rem;line-height:1.6;font-size:1.1rem}@media (min-width: 640px){.service-description{font-size:1.2rem}}@media (min-width: 1024px){.service-description{font-size:1rem}}.service-features{display:flex;flex-direction:column;gap:.5rem}.service-feature{display:flex;align-items:center;font-size:.875rem;color:#2a3a4e99}.service-feature-icon{width:1rem;height:1rem;color:var(--color-secondary);margin-right:.5rem;flex-shrink:0}.specialties-section{padding:5rem 0;background:linear-gradient(135deg,var(--color-light),rgba(232,229,224,.3));position:relative}.specialties-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;max-width:1200px;margin:0 auto}.specialty-card{text-align:center;transition:var(--transition-slow)}.specialty-card:hover{transform:translateY(-8px)}.specialty-image-container{position:relative;width:200px;height:200px;margin:0 auto 1.5rem;border-radius:50%;overflow:hidden;box-shadow:var(--shadow-lg);transition:var(--transition-slow)}.specialty-card:hover .specialty-image-container{box-shadow:var(--shadow-xl);transform:scale(1.05)}.specialty-image{width:100%;height:100%;object-fit:cover;transition:var(--transition-slow)}.specialty-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#4f89bdcc,#2a3a4e99);display:flex;align-items:center;justify-content:center;opacity:0;transition:var(--transition-normal)}.specialty-card:hover .specialty-overlay{opacity:1}.specialty-icon{color:#fff;transform:scale(.8);transition:var(--transition-normal)}.specialty-card:hover .specialty-icon{transform:scale(1)}.specialty-content{padding:0 1rem}.specialty-title{font-size:1.4rem;font-weight:700;color:var(--color-primary);margin-bottom:.5rem;transition:var(--transition-normal)}.specialty-card:hover .specialty-title{color:var(--color-secondary)}.specialty-description{color:#2a3a4eb3;font-size:1.2rem;line-height:1.5}@media (max-width: 768px){.specialties-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}.specialty-image-container{width:150px;height:150px}.projects-grid{grid-template-columns:1fr;gap:1.5rem}}@media (max-width: 480px){.specialties-grid{grid-template-columns:1fr}.specialty-image-container{width:180px;height:180px}}.featured-projects-section{padding:5rem 0;background:linear-gradient(135deg,rgba(232,229,224,.3),var(--color-light));position:relative}.projects-gridBestWork{display:flex;justify-content:center;gap:2rem;margin-bottom:2rem;margin-left:auto;margin-right:auto}.project-cardBest{flex:0 1 300px;max-width:40rem;background:#fff;border-radius:1rem;overflow:hidden;box-shadow:var(--shadow-lg);transition:var(--transition-slow);cursor:pointer;text-align:center}.project-cardBest:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl)}.project-image-container{position:relative;height:300px;overflow:hidden}.project-image{width:100%;height:100%;object-fit:cover;transition:var(--transition-slow)}.project-cardBest:hover .project-image{transform:scale(1.1)}.project-overlayBest{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#2a3a4eed,#4f8abd86);display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;transition:var(--transition-normal)}.project-cardBest:hover .project-overlayBest{opacity:1}.project-play-button{background:#fff3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:2px solid white;border-radius:50%;width:80px;height:80px;display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:1rem;transition:var(--transition-normal)}.project-cardBest:hover .project-play-button{transform:scale(1.1);background:#ffffff4d}.project-stats{display:flex;gap:1rem;color:#fff;font-size:.875rem}.project-views,.project-duration{display:flex;align-items:center;gap:.25rem;background:#0000004d;padding:.25rem .5rem;border-radius:.5rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.project-content{padding:1.5rem}.project-title{font-size:1.125rem;font-weight:700;color:var(--color-dark);margin-bottom:.5rem;transition:var(--transition-normal)}.project-cardBest:hover .project-title{color:#fff}.project-subtitle{color:#2a3a4e99;font-size:.875rem}@media (max-width: 768px){.projects-gridBestWork{flex-direction:column;align-items:center}.project-cardBest{width:90%;max-width:none}}.process-section{padding:5rem 0;background:linear-gradient(135deg,rgba(232,229,224,.3),var(--color-light));position:relative}.process-grid{display:grid;gap:2rem}.process-step{text-align:center;position:relative}.process-step-number{width:80px;height:80px;background:var(--gradient-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;font-weight:700;margin:0 auto 1.5rem;box-shadow:var(--shadow-lg);transition:var(--transition-normal)}.process-step:hover .process-step-number{transform:scale(1.1)}.process-step-title{font-size:1.25rem;font-weight:700;color:var(--color-primary);margin-bottom:.75rem;transition:var(--transition-normal)}.process-step:hover .process-step-title{color:var(--color-secondary)}.process-step-description{color:#2a3a4eb3;line-height:1.6}.about-section{padding:5rem 0;background:linear-gradient(135deg,var(--color-primary),rgba(42,58,78,.9));color:var(--color-light);position:relative;overflow:hidden}.about-section:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;opacity:.1;background-image:radial-gradient(circle at 25% 25%,var(--color-secondary) 2px,transparent 2px),radial-gradient(circle at 75% 75%,var(--color-accent) 2px,transparent 2px);background-size:50px 50px}.section-badgeAbout{display:inline-flex;align-items:center;gap:.5rem;background:#4f89bd1a;border-radius:9999px;padding:.5rem 1.5rem;margin-bottom:1.5rem;font-size:.875rem;font-weight:500;color:#72aafe80}.about-grid{display:grid;gap:3rem;align-items:center}.about-images{position:relative}.about-images-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.about-image-container{position:relative;border-radius:1rem;overflow:hidden;box-shadow:var(--shadow-lg);transition:var(--transition-slow);margin-bottom:1rem}.about-image-container:hover{transform:scale(1.02);box-shadow:var(--shadow-xl)}.about-image-container.small{height:160px}.about-image-container.large{height:240px}.about-image{width:100%;height:100%;object-fit:cover;transition:var(--transition-slow)}.about-image-container:hover .about-image{transform:scale(1.05)}.about-image-container:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#2a3a4e1a,#4f89bd0d,#e8e5e01a);opacity:0;transition:var(--transition-normal)}.about-image-container:hover:after{opacity:1}.years-badge{position:absolute;top:1rem;left:1rem;background:var(--gradient-primary);border-radius:50%;padding:1rem;text-align:center;color:#fff;box-shadow:var(--shadow-md);z-index:10;transition:var(--transition-normal)}.about-image-container:hover .years-badge{transform:scale(1.05)}.years-number{font-size:1.5rem;font-weight:700;line-height:1}.years-text{font-size:.75rem;margin-top:.25rem;opacity:.9}@media (max-width: 768px){.about-image-container.small{height:140px}.about-image-container.large{height:200px}.years-badge{padding:.75rem}.years-number{font-size:1.25rem}.years-text{font-size:.625rem}}@media (max-width: 480px){.about-images-grid{grid-template-columns:1fr;gap:1rem}.about-image-container.small,.about-image-container.large{height:180px}}.about-content{position:relative;z-index:10}.about-subtitle{font-size:1.25rem;color:var(--color-secondary);margin-bottom:1.5rem}.about-text{color:#e8e5e0e6;margin-bottom:1.5rem;line-height:1.6}.features-grid{display:grid;gap:1.5rem}.feature{display:flex;align-items:flex-start;gap:.75rem}.feature-icon{padding:.5rem;background:var(--gradient-primary);border-radius:.5rem;color:#fff;transition:var(--transition-normal)}.feature:hover .feature-icon{transform:scale(1.1)}.feature-title{font-weight:600;color:var(--color-light);margin-bottom:.25rem;transition:var(--transition-normal)}.feature:hover .feature-title{color:var(--color-secondary)}.feature-description{color:#e8e5e0cc;font-size:.875rem}.testimonials-section{padding:5rem 0;background:linear-gradient(135deg,var(--color-light),rgba(232,229,224,.5));position:relative}.testimonial-card{max-width:64rem;margin:0 auto;border:none;border-radius:1rem;box-shadow:var(--shadow-xl);background:linear-gradient(135deg,var(--color-light),rgba(253,252,244,.8));-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);overflow:hidden;position:relative}.testimonial-content{padding:3rem;text-align:center;position:relative;z-index:10}.testimonial-quote{position:absolute;top:1.5rem;left:1.5rem;font-size:4rem;color:#4f89bd33;font-family:serif}.testimonial-stars{display:flex;justify-content:center;gap:.25rem;margin-bottom:1.5rem}.testimonial-star{width:1.5rem;height:1.5rem;color:var(--color-secondary);fill:currentColor}.testimonial-text{font-size:1.25rem;color:var(--color-primary);margin-bottom:2rem;line-height:1.6;font-weight:500}.testimonial-author{display:flex;flex-direction:column;gap:.5rem}.testimonial-author-name{font-size:1.125rem;font-weight:700;color:var(--color-primary)}.testimonial-author-location{color:#2a3a4eb3}.testimonial-author-service{display:inline-flex;align-items:center;gap:.5rem;background:#4f89bd1a;border-radius:9999px;padding:.25rem 1rem;margin-top:1rem;font-size:.875rem;color:var(--color-secondary);font-weight:500}.testimonial-dots{display:flex;justify-content:center;gap:.75rem;margin-top:2rem}.testimonial-dot{width:12px;height:12px;border-radius:50%;border:none;background:#2a3a4e4d;cursor:pointer;transition:var(--transition-normal)}.testimonial-dot:hover{background:#4f89bd80}.testimonial-dot.active{background:var(--color-secondary);transform:scale(1.25)}.contact-section{padding:5rem 0;background:linear-gradient(135deg,rgba(232,229,224,.3),var(--color-light));position:relative}.contact-grid{display:grid;gap:2rem;margin-bottom:3rem}.contact-card{text-align:center;border:none;border-radius:1rem;box-shadow:var(--shadow-lg);background:linear-gradient(135deg,var(--color-light),rgba(253,252,244,.8));-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);overflow:hidden;position:relative;transition:var(--transition-slow)}.contact-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl)}.contact-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#4f89bd00,#4f89bd0d);opacity:0;transition:var(--transition-slow)}.contact-card:hover:before{opacity:1}.contact-card-content{padding:2rem;position:relative;z-index:10}.contact-icon{display:inline-flex;padding:1rem;border-radius:50%;margin-bottom:1.5rem;transition:var(--transition-normal)}.contact-card:hover .contact-icon{transform:scale(1.1)}.contact-icon.primary{background:linear-gradient(135deg,var(--color-secondary),rgba(79,137,189,.7));color:#fff}.contact-icon.secondary{background:linear-gradient(135deg,var(--color-primary),rgba(42,58,78,.7));color:#fff}.contact-icon.accent{background:var(--gradient-warm);color:#fff}.contact-title{font-size:1.25rem;font-weight:700;color:var(--color-primary);margin-bottom:.5rem;transition:var(--transition-normal)}.contact-card:hover .contact-title{color:var(--color-secondary)}.contact-subtitle{font-size:.875rem;color:#2a3a4e99;margin-bottom:.75rem}.contact-info{font-size:1.125rem;font-weight:600;color:var(--color-primary);margin-bottom:1.5rem}.consultation-card{max-width:64rem;margin:0 auto;border:none;border-radius:1rem;box-shadow:var(--shadow-xl);background:var(--gradient-primary);color:#fff;overflow:hidden;position:relative}.consultation-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#4f89bde6,#2a3a4ee6)}.consultation-content{padding:3rem;text-align:center;position:relative;z-index:10}.consultation-title{font-size:2rem;font-weight:700;margin-bottom:1rem}.consultation-description{font-size:1.25rem;color:#ffffffe6;margin-bottom:2rem;max-width:32rem;margin-left:auto;margin-right:auto}.btn-white{background:#fff;color:var(--color-primary)}.btn-white:hover{background:#ffffffe6;transform:scale(1.05)}.footer{background:linear-gradient(135deg,var(--color-primary),rgba(42,58,78,.95));color:var(--color-light);padding:4rem 0;position:relative;overflow:hidden}.footer:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;opacity:.05;background-image:linear-gradient(45deg,var(--color-secondary) 25%,transparent 25%),linear-gradient(-45deg,var(--color-secondary) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,var(--color-secondary) 75%),linear-gradient(-45deg,transparent 75%,var(--color-secondary) 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px}.footer-container{max-width:1200px;margin:0 auto;padding:0 1rem;position:relative;z-index:10}.footer-grid{display:grid;gap:2rem;margin-bottom:3rem}.footer-brand{display:flex;justify-content:center;align-items:center;gap:.75rem;margin-bottom:1.5rem}.footer-brand-icon{width:48px;height:48px;background:var(--gradient-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.footer-brand-text{font-size:1.5rem;font-weight:700;background:var(--gradient-accent);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.footer-brand-subtitle{color:#e8e5e0cc;font-size:.875rem}.footer-description{text-align:center;color:#e8e5e0cc;font-size:.875rem;line-height:1.6;margin-bottom:1.5rem}.social-links{display:flex;justify-content:center;gap:1rem}.social-link{padding:.5rem;background:#4f89bd33;border-radius:50%;color:var(--color-secondary);cursor:pointer;transition:var(--transition-normal)}.social-link:hover{background:#4f89bd4d;transform:scale(1.1)}.footer-section h4{text-align:center;font-size:1.125rem;font-weight:600;color:var(--color-secondary);margin-bottom:1.5rem}.footer-links{list-style:none;display:flex;text-align:center;flex-direction:column;gap:.75rem}.contactFooter{display:flex;flex-direction:column;text-align:center;justify-content:center;align-items:center}.footer-links a{color:#e8e5e0cc;text-decoration:none;font-size:.875rem;transition:var(--transition-normal)}.footer-links a:hover{color:var(--color-secondary)}.footer-contact-item{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1rem}.footer-contact-icon{width:1rem;height:1rem;color:var(--color-secondary);margin-top:.25rem}.footer-contact-main{color:var(--color-light);font-size:.875rem;font-weight:500}.footer-contact-sub{color:#e8e5e099;font-size:.75rem}.footer-bottom{border-top:1px solid rgba(232,229,224,.2);padding-top:2rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.footer-copyright{font-size:.875rem;color:#e8e5e099}.footer-bottom-links{display:flex;gap:1.5rem}.footer-bottom-links a{color:#e8e5e099;text-decoration:none;font-size:.875rem;transition:var(--transition-normal)}.footer-bottom-links a:hover{color:var(--color-secondary)}:root{--color-primary: #2a3a4e;--color-secondary: #4f89bd;--color-accent: #e8e5e0;--color-neutral: #b3b1ad;--color-warm: #c0b5b0;--color-light: #fdfcf4;--gradient-primary: linear-gradient(135deg, var(--color-secondary), var(--color-primary));--gradient-accent: linear-gradient(135deg, var(--color-secondary), var(--color-accent));--gradient-warm: linear-gradient(135deg, var(--color-warm), var(--color-neutral));--shadow-sm: 0 2px 4px rgba(42, 58, 78, .1);--shadow-md: 0 4px 6px rgba(42, 58, 78, .15);--shadow-lg: 0 10px 25px rgba(42, 58, 78, .2);--shadow-xl: 0 20px 40px rgba(42, 58, 78, .3);--transition-fast: all .2s ease;--transition-normal: all .3s ease;--transition-slow: all .5s ease}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;color:var(--color-primary);background-color:var(--color-light);overflow-x:hidden}@keyframes fade-in-up{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes spin-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes bounce-slow{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse-glow{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.animate-fade-in-up{animation:fade-in-up .8s ease-out forwards}.animate-spin-slow{animation:spin-slow 20s linear infinite}.animate-bounce-slow{animation:bounce-slow 3s ease-in-out infinite}.animate-pulse-glow{animation:pulse-glow 3s ease-in-out infinite}.animate-float{animation:float 6s ease-in-out infinite}.delay-200{animation-delay:.2s}.delay-400{animation-delay:.4s}.delay-500{animation-delay:.5s}.delay-600{animation-delay:.6s}.delay-700{animation-delay:.7s}.delay-800{animation-delay:.8s}.delay-1000{animation-delay:1s}.delay-2000{animation-delay:2s}.background-elements{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.bg-blob{position:absolute;border-radius:50%;filter:blur(60px);animation:pulse-glow 4s ease-in-out infinite}.bg-blob-1{top:80px;left:40px;width:288px;height:288px;background:linear-gradient(135deg,#4f89bd1a,#2a3a4e0d)}.bg-blob-2{top:384px;right:40px;width:384px;height:384px;background:linear-gradient(135deg,#c0b5b01a,#4f89bd0d);animation-delay:1s}.bg-blob-3{bottom:80px;left:33.333%;width:320px;height:320px;background:linear-gradient(135deg,#e8e5e033,#b3b1ad1a);animation-delay:2s}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.text-center{text-align:center}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mt-4{margin-top:1rem}@media (min-width: 640px){.hero-buttons,.hero-contact{flex-direction:row}.services-grid,.process-grid{grid-template-columns:repeat(2,1fr)}.contact-grid{grid-template-columns:repeat(3,1fr)}.footer-grid{grid-template-columns:repeat(2,1fr)}.footer-bottom{flex-direction:row;justify-content:space-between}}@media (min-width: 768px){.nav,.header-contact{display:flex}.mobile-menu-btn{display:none}.hero-grid{grid-template-columns:repeat(2,1fr)}.hero-content{text-align:left}.hero-title,.section-title{font-size:3rem}.about-grid,.features-grid{grid-template-columns:repeat(2,1fr)}.footer-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1024px){.hero-title{font-size:5rem}.section-title{font-size:4rem}.services-grid,.process-grid{grid-template-columns:repeat(4,1fr)}.process-step:after{content:"";position:absolute;top:40px;left:100%;width:100%;height:2px;background:linear-gradient(to right,#4f89bd80,#2a3a4e33)}.process-step:last-child:after{display:none}}@media (min-width: 1280px){.hero-title,.section-title{font-size:4rem}}@media print{.header,.hero-decorative,.background-elements,.btn,.social-links{display:none}.hero-section{padding-top:0}*{color:#000!important;background:#fff!important}}:root{--backgroundP: #ffffff;--foregroundP: #1e293b;--cardP: #f8fafc;--cardP-foreground: #1e293b;--popoverP: #ffffff;--popoverP-foreground: #1e293b;--primaryP: #1e293b;--primaryP-foreground: #ffffff;--secondaryP: #334155;--secondaryP-foreground: #ffffff;--mutedP: #f1f5f9;--mutedP-foreground: #64748b;--accentP: #0ea5e9;--accentP-foreground: #ffffff;--destructiveP: #ef4444;--destructiveP-foreground: #ffffff;--borderP: #e2e8f0;--inputP: #f8fafc;--ringP: #1e293b;--chart-1P: #1e293b;--chart-2P: #334155;--chart-3P: #475569;--chart-4P: #64748b;--chart-5P: #0ea5e9;--radiusP: .5rem;--sidebarP: #f8fafc;--sidebarP-foreground: #1e293b;--sidebarP-primary: #ffffff;--sidebarP-primary-foreground: #1e293b;--sidebarP-accent: #0ea5e9;--sidebarP-accent-foreground: #ffffff;--sidebarP-border: #e2e8f0;--sidebarP-ring: #1e293b}.projects-page{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;color:var(--foregroundP);background:var(--backgroundP)}.heroProject{display:flex;background:linear-gradient(135deg,var(--primaryP) 0%,var(--secondaryP) 100%);color:#fff;padding:10rem 0;text-align:center;position:relative;overflow:hidden}.heroProject:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url(/assets/portada1-BnSxOCe3.jpg) center;opacity:.1;z-index:0}.heroProject-content{position:relative;z-index:1;max-width:900px;margin:0 auto;padding:0 2rem;text-align:center}.heroProject-content h1{font-size:3.5rem;margin-bottom:1.5rem;font-weight:700;background:linear-gradient(45deg,#fff,#e2e8f0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.heroProject-content p{font-size:1.3rem;opacity:.95;margin-bottom:3rem;line-height:1.7}.heroProject-stats{display:flex;justify-content:center;gap:4rem;margin-top:3rem}.stat{text-align:center}.stat-number{display:block;font-size:2.5rem;font-weight:700;color:#fff;margin-bottom:.5rem}.stat-label{font-size:.9rem;opacity:.8;text-transform:uppercase;letter-spacing:.5px}.filter-section{background:linear-gradient(135deg,var(--cardP) 0%,var(--mutedP) 100%);padding:1rem 0;border-bottom:1px solid var(--borderP)}.filter-header{text-align:center;margin-bottom:3rem}.filter-header h2{font-size:2.5rem;font-weight:700;color:var(--primaryP);margin-bottom:1rem}.filter-header p{font-size:1.1rem;color:var(--mutedP-foreground);max-width:600px;margin:0 auto}.filter-container{display:grid;grid-template-columns:1fr;gap:3rem;max-width:1000px;margin:0 auto}.search-container{width:100%}.search-wrapper{position:relative;display:flex;align-items:center;max-width:500px;margin:0 auto}.search-icon{position:absolute;left:1.25rem;width:22px;height:22px;color:var(--mutedP-foreground);z-index:1}.search-input{width:100%;padding:1.25rem 3.5rem;border:2px solid var(--borderP);border-radius:60px;font-size:1.1rem;outline:none;transition:all .3s ease;background:var(--inputP);color:var(--foregroundP);box-shadow:0 4px 6px #0000000d}.search-input:focus{border-color:var(--primaryP);box-shadow:0 0 0 4px #2c3e501a,0 4px 12px #0000001a;transform:translateY(-1px)}.search-input::placeholder{color:var(--mutedP-foreground)}.clear-search{position:absolute;right:1.25rem;background:none;border:none;cursor:pointer;padding:.5rem;border-radius:50%;transition:all .2s ease;color:var(--mutedP-foreground)}.clear-search:hover{background:var(--mutedP);color:var(--foregroundP)}.clear-search svg{width:18px;height:18px}.category-section{text-align:center}.category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.category-header h3{color:var(--primaryP);font-size:1.5rem;font-weight:600;margin:0}.results-count{background:var(--accentP);color:var(--accentP-foreground);padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500}.category-buttons{display:flex;justify-content:center;flex-wrap:wrap;gap:1rem}.category-btn{background:var(--backgroundP);border:2px solid var(--borderP);color:var(--foregroundP);padding:1rem 1.5rem;border-radius:50px;cursor:pointer;transition:all .3s ease;font-weight:500;font-size:.95rem;display:flex;align-items:center;gap:.5rem;box-shadow:0 2px 4px #0000000d;min-width:120px;justify-content:center}.category-btn:hover{background:var(--mutedP);border-color:var(--primaryP);transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.category-btn.active{background:var(--primaryP);border-color:var(--primaryP);color:var(--primaryP-foreground);transform:translateY(-1px);box-shadow:0 4px 12px #2c3e504d}.category-count{background:#fff3;padding:.25rem .5rem;border-radius:12px;font-size:.8rem;font-weight:600}.category-btn.active .category-count{background:#ffffff4d}.projects-section{background:var(--mutedP);padding:5rem 0}.container-projects{max-width:1400px;margin:0 auto;padding:0 2rem}.section-header{text-align:center;margin-bottom:4rem}.section-header h2{font-size:2.5rem;font-weight:700;color:var(--foregroundP);margin-bottom:1rem}.section-header p{font-size:1.1rem;color:var(--mutedP-foreground);max-width:600px;margin:0 auto}.projects-container{display:flex;flex-wrap:wrap;justify-content:space-around;gap:25px;margin:0 auto;width:100%;max-width:1200px;padding:1rem;border-radius:.75rem}.projects-card{background:var(--cardP);width:23vw;border-radius:16px;overflow:hidden;box-shadow:0 4px 20px #00000014;transition:all .4s ease;cursor:pointer;border:1px solid var(--borderP)}.projects-card:hover{transform:translateY(-8px);box-shadow:0 20px 40px #00000026}.image-gallery-preview{display:flex;flex-direction:column;height:320px}.main-image-container{position:relative;flex:1;overflow:hidden;border-bottom:4px solid var(--borderP)}.main-image-container img,.main-image-container video{width:100%;height:100%;object-fit:fill;border-radius:0;transition:transform .4s ease}.projects-card:hover .main-image-container img{transform:scale(1.05)}.image-count{position:absolute;top:1rem;right:1rem;background:#000c;color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:.5rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.image-count svg{width:16px;height:16px}.project-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,var(--primaryP),var(--secondaryP));opacity:0;display:flex;align-items:center;justify-content:center;transition:opacity .3s ease}.projects-card:hover .project-overlay{opacity:.9}.view-project{color:#fff;font-weight:600;font-size:1.1rem;text-transform:uppercase;letter-spacing:1px}.thumbnail-strip{display:flex;height:70px;gap:1px}.thumbnail{flex:1;overflow:hidden}.thumbnail img{width:100%;height:100%;object-fit:fill;opacity:.7;transition:opacity .3s ease}.thumbnail:hover img{opacity:1}.more-images{flex:1;background:linear-gradient(45deg,var(--primaryP),var(--secondaryP));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem}.project-info{padding:2rem}.project-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.project-header h3{font-size:1.4rem;font-weight:700;color:var(--foregroundP);margin:0;line-height:1.3}.favorite-badge{background:linear-gradient(45deg,#fbbf24,#f59e0b);color:#fff;padding:.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #fbbf244d}.favorite-badge svg{width:16px;height:16px}.favorite-badge.large{padding:.75rem}.favorite-badge.large svg{width:20px;height:20px}.project-description{color:var(--mutedP-foreground);line-height:1.6;margin-bottom:1.5rem}.project-details{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.detail{display:flex;align-items:center;gap:.75rem;color:var(--mutedP-foreground);font-size:.9rem}.detail svg{width:16px;height:16px;color:var(--primaryP)}.project-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid var(--borderP)}.status{padding:.5rem 1rem;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status.completed{background:#dcfce7;color:#166534}.status.in-progress{background:#fef3c7;color:#92400e}.budget{font-weight:700;color:var(--primaryP);font-size:1.1rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;justify-content:center;align-items:center;z-index:2000;padding:2rem;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-content{background:var(--cardP);border-radius:20px;max-width:900px;max-height:90vh;overflow-y:auto;position:relative;padding:20px;box-shadow:0 25px 50px #00000040;z-index:1000}.close-btn{position:absolute;top:1.5rem;right:1.5rem;background:var(--destructiveP);color:var(--destructiveP-foreground);border:none;border-radius:50%;width:44px;height:44px;cursor:pointer;z-index:1001;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 4px 12px #f871714d}.close-btn:hover{transform:scale(1.1);box-shadow:0 6px 16px #f8717166}.close-btn svg{width:20px;height:20px}.modal-header{padding:2.5rem 2.5rem 1.5rem;display:flex;justify-content:space-between;align-items:flex-start;border-bottom:1px solid var(--borderP)}.modal-header h2{color:var(--foregroundP);margin:0;font-size:2rem;font-weight:700}.modal-subtitle{color:var(--mutedP-foreground);margin:.5rem 0 0;font-size:1rem}.modal-gallery .main-image-container{position:relative;height:450px;margin-bottom:1.5rem;border-radius:12px;overflow:hidden;box-shadow:0 8px 25px #00000026}.modal-gallery .main-image-container img{width:100%;height:100%;object-fit:fill}.gallery-nav{position:absolute;top:50%;transform:translateY(-50%);background:#000000b3;color:#fff;border:none;width:50px;height:50px;border-radius:50%;cursor:pointer;transition:all .3s ease;z-index:10;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.gallery-nav:hover{background:#000000e6;transform:translateY(-50%) scale(1.1)}.gallery-nav svg{width:20px;height:20px}.gallery-nav.prev{left:1rem}.gallery-nav.next{right:1rem}.image-counter{position:absolute;bottom:1rem;right:1rem;background:#000c;color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:600;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.thumbnail-gallery{display:flex;gap:.75rem;overflow-x:auto;padding:.5rem 0}.thumbnail-gallery .thumbnail{flex-shrink:0;width:90px;height:70px;border-radius:8px;overflow:hidden;cursor:pointer;border:3px solid transparent;transition:all .3s ease}.thumbnail-gallery .thumbnail.active{border-color:var(--primaryP);box-shadow:0 0 0 2px #0891b233}.thumbnail-gallery .thumbnail:hover{transform:scale(1.05)}.thumbnail-gallery .thumbnail img{width:100%;height:100%;object-fit:fill}.modal-details{margin-top:2rem;padding:0 2rem 2.5rem}.project-description h3{color:var(--foregroundP);margin-bottom:1rem;font-size:1.3rem;font-weight:600}.project-description p{color:var(--mutedP-foreground);line-height:1.7;margin-bottom:2rem}.details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.detail-item{background:var(--mutedP);padding:1.5rem;border-radius:12px;border:1px solid var(--borderP)}.detail-label{display:flex;align-items:center;gap:.75rem;color:var(--mutedP-foreground);font-size:.9rem;font-weight:600;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.detail-label svg{width:18px;height:18px;color:var(--primaryP)}.detail-value{color:var(--foregroundP);font-weight:600;font-size:1.1rem}.cta-section{background:linear-gradient(135deg,var(--primaryP) 0%,var(--secondaryP) 100%);color:#fff;padding:5rem 0;text-align:center;position:relative;overflow:hidden}.cta-section:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url(/assets/portada1-BnSxOCe3.jpg) center;opacity:.1;z-index:0}.cta-content{position:relative;z-index:1;max-width:700px;margin:0 auto}.cta-content h2{font-size:2.8rem;margin-bottom:1.5rem;font-weight:700}.cta-content p{font-size:1.2rem;margin-bottom:2.5rem;opacity:.95;line-height:1.6}.cta-buttons{display:flex;justify-content:center;gap:1.5rem;flex-wrap:wrap}.cta-button{display:inline-block;padding:1rem 2.5rem;text-decoration:none;border-radius:50px;font-weight:600;font-size:1.1rem;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}.cta-button.primary{background:#fff;color:var(--primaryP);box-shadow:0 4px 15px #ffffff4d}.cta-button.primary:hover{transform:translateY(-3px);box-shadow:0 8px 25px #fff6}.cta-button.secondary{background:transparent;color:#fff;border:2px solid white}.cta-button.secondary:hover{background:#fff;color:var(--primaryP);transform:translateY(-3px)}@media (max-width: 1200px){.projects-card{width:30vw}}@media (max-width: 992px){.projects-card{width:45vw}.heroProject-content h1{font-size:3rem}.heroProject-stats{gap:2rem}}@media (max-width: 768px){.filter-container{margin:20px}.projects-container{flex-direction:column;align-items:center}.projects-card{width:90%}.image-gallery-preview{height:220px}.thumbnail-strip{height:55px}.heroProject{padding:6rem 0}.heroProject-content h1{font-size:2.2rem}.heroProject-content p{font-size:1rem}.heroProject-stats{flex-direction:column;gap:1.5rem}.filter-header h2{font-size:1.8rem}.section-header h2{font-size:2rem}.modal-gallery .main-image-container{height:300px;width:300px}.modal-gallery .main-image-container img{width:100%;height:100%;object-fit:fill;border-radius:8px}.modal-gallery .thumbnail-strip{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}.modal-gallery .thumbnail-media img{width:85px;height:85px;object-fit:fill;border-radius:6px;cursor:pointer}.details-grid{grid-template-columns:1fr}}@media (max-width: 480px){.modal-header{display:flex;flex-direction:column;gap:20px}.filter-header,.filter-container{margin:20px}.projects-section{padding-top:5px}.projects-card{width:100%}.project-info{padding:1.5rem}.project-header h3{font-size:1.2rem}.project-description{font-size:.95rem}.cta-content h2{font-size:1.8rem}.cta-content p{font-size:1rem}.cta-buttons{gap:1rem}.cta-button{font-size:1rem;padding:.8rem 2rem}.thumbnail-gallery{display:flex;gap:10px;overflow-x:auto;padding-bottom:8px;scrollbar-width:thin;-ms-overflow-style:none}.thumbnail-gallery::-webkit-scrollbar{height:6px}.thumbnail-gallery::-webkit-scrollbar-thumb{background:#0000004d;border-radius:4px}.thumbnail-gallery::-webkit-scrollbar-track{background:transparent}.thumbnail-gallery .thumbnail{flex:0 0 auto;width:120px;height:90px;border-radius:8px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:all .3s ease}.thumbnail-gallery .thumbnail.active{border-color:var(--primaryP)}.thumbnail-gallery .thumbnail img,.thumbnail-gallery .thumbnail video{width:100%;height:100%;object-fit:fill}}
