/* Hatch Code - Estilos Compartidos */
*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;font-family:'Manrope',sans-serif;background:#f6f7fb;color:#0f172a;overflow-x:hidden;}

/* ===== Header ===== */
header{position:sticky;top:0;background:rgba(255,255,255,0.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(0,0,0,0.06);z-index:1000;transition:box-shadow 0.3s ease;}
header.scrolled{box-shadow:0 4px 20px rgba(0,0,0,0.08);}
.nav{max-width:1120px;margin:auto;display:flex;justify-content:space-between;align-items:center;padding:0 20px;height:72px;}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;text-decoration:none;color:#0f172a;font-size:1.15rem;}
.brand img{height:40px;}
.menu{display:flex;gap:24px;align-items:center;}
.menu a{color:#475569;font-weight:600;text-decoration:none;position:relative;transition:color 0.3s ease;}
.menu a:not(.cta)::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:#14b8a6;transition:width 0.3s ease;}
.menu a:not(.cta):hover::after{width:100%;}
.menu a:hover{color:#0f172a;}
.cta{padding:10px 20px;border-radius:10px;background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff!important;transition:all 0.3s ease;box-shadow:0 2px 8px rgba(20,184,166,0.3);}
.cta:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(20,184,166,0.4);}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;border:none;background:none;z-index:1001;}
.hamburger span{display:block;width:24px;height:2.5px;background:#0f172a;border-radius:2px;transition:all 0.3s ease;}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.hamburger.active span:nth-child(2){opacity:0;}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}

/* ===== Hero ===== */
.hero{max-width:1120px;margin:auto;padding:80px 20px 60px;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.hero h1{font-size:clamp(34px,5vw,56px);margin:0 0 24px;font-weight:800;line-height:1.1;letter-spacing:-0.02em;}
.hero h1 .gradient-text{background:linear-gradient(135deg,#14b8a6,#0891b2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.hero p{color:#475569;font-size:1.15rem;line-height:1.7;margin:0 0 8px;}
.hero-visual{text-align:center;position:relative;}
.hero-visual img{max-width:280px;filter:drop-shadow(0 20px 40px rgba(20,184,166,0.2));animation:float 6s ease-in-out infinite;}
@keyframes float{0%,100%{transform:translateY(0);}50%{transform:translateY(-16px);}}
.actions{margin-top:28px;display:flex;gap:14px;flex-wrap:wrap;}

/* ===== Buttons ===== */
.btn{padding:14px 24px;border-radius:12px;font-weight:700;border:0;cursor:pointer;text-decoration:none;display:inline-block;transition:all 0.3s ease;font-size:0.95rem;font-family:inherit;}
.btn-primary{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff;box-shadow:0 4px 14px rgba(20,184,166,0.35);}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 25px rgba(20,184,166,0.45);}
.btn-outline{background:transparent;border:2px solid #cbd5e1;color:#0f172a;}
.btn-outline:hover{background:#0f172a;border-color:#0f172a;color:#fff;transform:translateY(-3px);}
.btn-secondary{background:#0f172a;color:#fff;box-shadow:0 4px 14px rgba(15,23,42,0.2);}
.btn-secondary:hover{background:#1e293b;transform:translateY(-3px);box-shadow:0 8px 25px rgba(15,23,42,0.3);}

/* ===== Sections ===== */
.section{padding:80px 20px;max-width:1120px;margin:auto;}
.section h2{font-size:clamp(28px,4vw,42px);font-weight:800;text-align:center;margin:0 0 16px;color:#0f172a;letter-spacing:-0.02em;}
.section>p,.section-subtitle{color:#64748b;font-size:1.1rem;text-align:center;max-width:600px;margin:0 auto 50px;line-height:1.6;}

/* Full-width section wrapper */
.full-width{max-width:none;padding:80px 0;}
.full-width .container{max-width:1120px;margin:auto;padding:0 20px;}

/* ===== Stats Bar ===== */
.stats-bar{background:#0f172a;padding:50px 20px;}
.stats-bar .container{max-width:1120px;margin:auto;display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center;}
.stat-item .stat-number{font-size:clamp(32px,4vw,48px);font-weight:800;background:linear-gradient(135deg,#14b8a6,#0891b2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.stat-item .stat-label{color:#94a3b8;font-size:0.95rem;margin-top:6px;}

/* ===== Services Grid ===== */
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:28px;margin-top:40px;}
.service-card{background:#fff;padding:36px 28px;border-radius:16px;box-shadow:0 2px 12px rgba(0,0,0,0.05);transition:all 0.4s ease;border:1px solid rgba(0,0,0,0.04);position:relative;overflow:hidden;}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#14b8a6,#0891b2);transform:scaleX(0);transition:transform 0.4s ease;transform-origin:left;}
.service-card:hover{transform:translateY(-6px);box-shadow:0 12px 35px rgba(0,0,0,0.1);}
.service-card:hover::before{transform:scaleX(1);}
.service-icon{width:56px;height:56px;background:linear-gradient(135deg,#14b8a6,#0891b2);border-radius:14px;margin:0 0 20px;display:flex;align-items:center;justify-content:center;font-size:24px;color:#fff;box-shadow:0 4px 12px rgba(20,184,166,0.25);}
.service-card h3{font-size:20px;font-weight:700;margin:0 0 12px;color:#0f172a;}
.service-card p{color:#64748b;font-size:15px;line-height:1.7;margin:0 0 16px;text-align:left;}
.service-card ul{list-style:none;padding:0;margin:0;}
.service-card ul li{color:#64748b;font-size:14px;line-height:1.6;padding:6px 0 6px 24px;position:relative;}
.service-card ul li::before{content:'';position:absolute;left:0;top:13px;width:8px;height:8px;border-radius:50%;background:linear-gradient(135deg,#14b8a6,#0891b2);}

/* ===== Projects Grid ===== */
.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:28px;margin-top:40px;}
.project-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,0.05);transition:all 0.4s ease;border:1px solid rgba(0,0,0,0.04);}
.project-card:hover{transform:translateY(-6px);box-shadow:0 12px 35px rgba(0,0,0,0.1);}
.project-image{height:200px;background:linear-gradient(135deg,#14b8a6 0%,#0891b2 50%,#0f172a 100%);display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;font-weight:600;position:relative;overflow:hidden;}
.project-image::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,0.3));pointer-events:none;}
.project-content{padding:28px;}
.project-content h3{font-size:20px;font-weight:700;margin:0 0 10px;color:#0f172a;}
.project-content p{color:#64748b;font-size:15px;line-height:1.7;margin:0 0 18px;text-align:left;}
.project-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px;}
.tag{background:linear-gradient(135deg,#f0fdfa,#e0f2fe);color:#0d9488;padding:5px 14px;border-radius:20px;font-size:12px;font-weight:600;border:1px solid rgba(20,184,166,0.15);}
.project-link{color:#14b8a6;text-decoration:none;font-weight:700;font-size:14px;display:inline-flex;align-items:center;gap:6px;transition:gap 0.3s ease;}
.project-link:hover{gap:12px;text-decoration:none;}

/* ===== Project Detail ===== */
.project-detail{max-width:860px;margin:40px auto;background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 4px 30px rgba(0,0,0,0.08);}
.project-detail-header{background:linear-gradient(135deg,#14b8a6 0%,#0891b2 50%,#0f172a 100%);color:#fff;padding:50px 40px;text-align:center;position:relative;}
.project-detail-header::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:30px;background:#fff;border-radius:20px 20px 0 0;}
.project-detail-header h1{font-size:clamp(26px,4vw,36px);font-weight:800;margin:0 0 12px;position:relative;z-index:1;}
.project-detail-header p{font-size:18px;margin:0;opacity:0.9;position:relative;z-index:1;}
.project-detail-content{padding:20px 40px 40px;}
.project-detail-content h2{font-size:24px;font-weight:700;margin:36px 0 16px;color:#0f172a;padding-bottom:10px;border-bottom:2px solid #f1f5f9;}
.project-detail-content h3{font-size:19px;font-weight:600;margin:24px 0 10px;color:#0f172a;}
.project-detail-content p{color:#64748b;font-size:16px;line-height:1.8;margin:0 0 20px;}
.project-detail-content ul{color:#64748b;font-size:16px;line-height:1.8;margin:0 0 20px;padding-left:0;list-style:none;}
.project-detail-content ul li{padding:6px 0 6px 28px;position:relative;}
.project-detail-content ul li::before{content:'';position:absolute;left:0;top:14px;width:10px;height:10px;border-radius:50%;background:linear-gradient(135deg,#14b8a6,#0891b2);}
.back-link{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,0.85);text-decoration:none;font-weight:600;margin-bottom:20px;transition:color 0.3s ease;position:relative;z-index:1;}
.back-link:hover{color:#fff;}

/* ===== Process Steps ===== */
.process-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:30px;margin-top:40px;}
.process-step{text-align:center;padding:30px 20px;position:relative;}
.process-number{width:60px;height:60px;background:linear-gradient(135deg,#14b8a6,#0891b2);border-radius:50%;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px;font-weight:700;box-shadow:0 4px 14px rgba(20,184,166,0.3);}
.process-step h3{font-size:20px;font-weight:700;margin:0 0 12px;color:#0f172a;}
.process-step p{color:#64748b;font-size:15px;line-height:1.6;margin:0;}

/* ===== Values Grid ===== */
.values-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:36px;margin-top:40px;text-align:center;}
.value-item .value-icon{width:60px;height:60px;background:linear-gradient(135deg,#14b8a6,#0891b2);border-radius:50%;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;box-shadow:0 4px 14px rgba(20,184,166,0.3);}
.value-item h3{font-size:20px;font-weight:700;margin:0 0 12px;color:#0f172a;}
.value-item p{color:#64748b;font-size:15px;line-height:1.6;margin:0;}

/* ===== Testimonials ===== */
.testimonial-card{background:#fff;border-radius:16px;padding:36px;box-shadow:0 2px 12px rgba(0,0,0,0.05);border:1px solid rgba(0,0,0,0.04);position:relative;margin-top:40px;max-width:700px;margin-left:auto;margin-right:auto;}
.testimonial-card::before{content:'\201C';position:absolute;top:16px;left:24px;font-size:64px;color:#14b8a6;opacity:0.2;font-family:Georgia,serif;line-height:1;}
.testimonial-card p{color:#475569;font-size:1.05rem;line-height:1.8;font-style:italic;margin:0 0 20px;text-align:left;}
.testimonial-author{display:flex;align-items:center;gap:14px;}
.testimonial-author .avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#14b8a6,#0891b2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:18px;}
.testimonial-author .info strong{display:block;color:#0f172a;font-size:0.95rem;}
.testimonial-author .info span{color:#94a3b8;font-size:0.85rem;}

/* ===== Contact Section ===== */
.contact-section{background:#0f172a;color:#fff;text-align:center;max-width:none;padding:80px 20px;}
.contact-section .container{max-width:1120px;margin:auto;}
.contact-section h2{color:#fff;}
.contact-section>p,.contact-section .container>p{color:#94a3b8;}
.contact-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;margin-top:40px;}
.contact-item{padding:24px;background:rgba(255,255,255,0.04);border-radius:14px;border:1px solid rgba(255,255,255,0.06);transition:all 0.3s ease;}
.contact-item:hover{background:rgba(255,255,255,0.08);transform:translateY(-3px);}
.contact-item h3{font-size:18px;font-weight:700;margin:0 0 10px;color:#fff;}
.contact-item p{color:#94a3b8;margin:0;}

/* Form styling */
form label{display:block;margin-bottom:20px;font-weight:600;font-size:0.9rem;color:#94a3b8;text-align:left;}
form input,form textarea{width:100%;padding:14px 16px;margin-top:8px;border:1px solid rgba(255,255,255,0.12);border-radius:10px;background:rgba(255,255,255,0.06);color:#fff;font-family:'Manrope',sans-serif;font-size:0.95rem;transition:all 0.3s ease;outline:none;}
form input:focus,form textarea:focus{border-color:#14b8a6;box-shadow:0 0 0 3px rgba(20,184,166,0.2);background:rgba(255,255,255,0.08);}
form input::placeholder,form textarea::placeholder{color:#64748b;}
form textarea{resize:vertical;min-height:120px;}
form button[type="submit"]{width:100%;padding:16px;font-size:1rem;}

/* ===== Footer ===== */
footer{background:#0f172a;border-top:1px solid rgba(255,255,255,0.06);padding:40px 20px;color:#94a3b8;}
.footer-content{max-width:1120px;margin:auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;}
.footer-brand{display:flex;align-items:center;gap:10px;margin-bottom:16px;}
.footer-brand img{height:32px;}
.footer-brand span{font-weight:800;color:#fff;font-size:1.1rem;}
.footer-desc{color:#64748b;font-size:0.9rem;line-height:1.7;margin:0;}
.footer-links h4{color:#fff;font-size:0.95rem;font-weight:700;margin:0 0 16px;}
.footer-links a{display:block;color:#64748b;text-decoration:none;font-size:0.9rem;padding:4px 0;transition:color 0.3s ease;}
.footer-links a:hover{color:#14b8a6;}
.footer-bottom{max-width:1120px;margin:20px auto 0;padding-top:20px;border-top:1px solid rgba(255,255,255,0.06);text-align:center;font-size:0.85rem;color:#475569;}

/* ===== WhatsApp Float ===== */
.whatsapp-float{position:fixed;bottom:28px;right:28px;width:60px;height:60px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,0.4);z-index:999;transition:all 0.3s ease;text-decoration:none;}
.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 6px 28px rgba(37,211,102,0.5);}
.whatsapp-float svg{width:32px;height:32px;fill:#fff;}

/* ===== Scroll Animations ===== */
.fade-up{opacity:0;transform:translateY(30px);transition:opacity 0.6s ease,transform 0.6s ease;}
.fade-up.visible{opacity:1;transform:translateY(0);}
.fade-up:nth-child(2){transition-delay:0.1s;}
.fade-up:nth-child(3){transition-delay:0.2s;}
.fade-up:nth-child(4){transition-delay:0.3s;}
.fade-up:nth-child(5){transition-delay:0.4s;}
.fade-up:nth-child(6){transition-delay:0.5s;}

/* ===== Tech Logos ===== */
.tech-marquee{overflow:hidden;padding:20px 0;margin-top:20px;}
.tech-track{display:flex;gap:50px;animation:marquee 30s linear infinite;width:max-content;}
.tech-track span{font-size:1rem;font-weight:600;color:#94a3b8;white-space:nowrap;padding:10px 20px;background:rgba(255,255,255,0.04);border-radius:8px;border:1px solid rgba(255,255,255,0.06);}
@keyframes marquee{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* ===== Responsive ===== */
@media(max-width:860px){
  .hero{grid-template-columns:1fr;text-align:center;padding:50px 20px 30px;gap:30px;}
  .hero .actions{justify-content:center;}
  .hero-visual img{max-width:180px;}
  .services-grid{grid-template-columns:1fr;}
  .projects-grid{grid-template-columns:1fr;}
  .project-detail-content{padding:16px 20px 30px;}
  .project-detail-header{padding:40px 20px;}
  .stats-bar .container{grid-template-columns:repeat(2,1fr);gap:20px;}
  .footer-content{grid-template-columns:1fr;gap:30px;text-align:center;}
  .menu{position:fixed;top:0;right:-100%;width:280px;height:100vh;background:#fff;flex-direction:column;justify-content:center;gap:32px;box-shadow:-4px 0 20px rgba(0,0,0,0.1);transition:right 0.4s ease;padding:20px;}
  .menu.open{right:0;}
  .menu a{font-size:1.1rem;}
  .hamburger{display:flex;}
  .contact-info{grid-template-columns:1fr 1fr;}
}
@media(max-width:480px){
  .stats-bar .container{grid-template-columns:1fr 1fr;}
  .contact-info{grid-template-columns:1fr;}
}

/* ===== Modal ===== */
.modal{position:fixed;inset:0;z-index:2000;display:none;align-items:center;justify-content:center;padding:20px;}
.modal.is-open{display:flex;}
.modal-backdrop{position:absolute;inset:0;background:rgba(15,23,42,0.6);backdrop-filter:blur(4px);}
.modal-content{position:relative;background:#fff;border-radius:16px;padding:40px;max-width:400px;width:100%;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,0.2);animation:modalIn 0.3s ease;}
@keyframes modalIn{from{opacity:0;transform:scale(0.95) translateY(-10px);}to{opacity:1;transform:scale(1) translateY(0);}}
.modal-message{font-size:1.2rem;font-weight:600;color:#0f172a;margin:0 0 24px;line-height:1.5;}
.modal-close{margin:0;}
