@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Inter:wght@300;400;500;600&display=swap');
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --navy:#0D1B2A;
  --navy2:#162234;
  --navy3:#080F18;
  --gold:#1BBCD4;
  --gold2:rgba(27,188,212,.1);
  --gold3:rgba(27,188,212,.2);
  --white:#fff;
  --bg:#F8F7F4;
  --border:#E8E4DC;
  --muted:#6B7280;
  --ink:#0D1B2A;
}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--ink)}

nav{position:fixed;top:0;left:0;right:0;z-index:100;background:var(--navy);display:flex;align-items:center;justify-content:space-between;padding:1rem 3rem}
.logo{font-family:'Playfair Display',serif;color:#fff;font-size:1.15rem;font-weight:700;letter-spacing:.02em}
.logo span{color:var(--gold)}
.nav-links{display:flex;gap:1.75rem;list-style:none}
.nav-links a{color:rgba(255,255,255,.55);font-size:.78rem;text-decoration:none;letter-spacing:.05em;text-transform:uppercase;transition:color .2s}
.nav-links a:hover{color:var(--gold)}
.nav-cta{background:var(--gold);color:var(--navy);padding:.5rem 1.25rem;font-size:.78rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;border:none;cursor:pointer;text-decoration:none;transition:opacity .2s}
.nav-cta:hover{opacity:.85}

section{padding:6rem 3rem}
.container{max-width:1100px;margin:0 auto}

.hero{background:var(--navy);padding-top:7rem;padding-bottom:5rem;border-bottom:1px solid rgba(255,255,255,.06)}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.eyebrow{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:1.25rem;font-weight:500}
.hero h1{font-family:'Playfair Display',serif;font-size:2.8rem;color:#fff;line-height:1.1;font-weight:700;margin-bottom:1.25rem}
.hero h1 em{color:var(--gold);font-style:italic}
.hero-sub{color:rgba(255,255,255,.5);font-size:.9rem;line-height:1.8;margin-bottom:2rem;font-weight:300}
.hero-btns{display:flex;gap:.75rem;flex-wrap:wrap}
.btn-primary{background:var(--gold);color:var(--navy);padding:.75rem 1.75rem;font-size:.82rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;border:none;cursor:pointer;text-decoration:none;transition:opacity .2s}
.btn-primary:hover{opacity:.85}
.btn-ghost{background:transparent;color:rgba(255,255,255,.65);padding:.75rem 1.75rem;font-size:.82rem;font-weight:400;letter-spacing:.06em;text-transform:uppercase;border:1px solid rgba(255,255,255,.18);cursor:pointer;text-decoration:none;transition:border-color .2s,color .2s}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.hero-trust{display:flex;gap:2.5rem;margin-top:2.5rem;padding-top:2.5rem;border-top:1px solid rgba(255,255,255,.09)}
.trust-item .n{font-family:'Playfair Display',serif;font-size:1.7rem;color:#fff;font-weight:700}
.trust-item .n span{color:var(--gold)}
.trust-item .l{font-size:.7rem;color:rgba(255,255,255,.35);margin-top:.15rem;letter-spacing:.04em;text-transform:uppercase}

.hero-card{background:var(--navy2);border:1px solid rgba(201,168,76,.12)}
.card-head{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.06)}
.card-icon{width:34px;height:34px;background:var(--gold2);border:1px solid var(--gold3);display:flex;align-items:center;justify-content:center}
.card-icon svg{width:15px;height:15px;stroke:var(--gold);fill:none;stroke-width:1.8}
.card-title{font-size:.85rem;font-weight:600;color:#fff}
.card-sub{font-size:.72rem;color:rgba(255,255,255,.35)}
.card-rows{display:flex;flex-direction:column;padding:.75rem 1.5rem;gap:.5rem}
.card-row{display:flex;align-items:center;justify-content:space-between;padding:.55rem .75rem;background:rgba(255,255,255,.03);border-left:2px solid var(--gold)}
.card-row-name{font-size:.8rem;color:rgba(255,255,255,.65)}
.card-row-badge{font-size:.68rem;color:var(--gold);font-weight:600;letter-spacing:.04em}
.card-footer{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid rgba(255,255,255,.06)}
.card-mini{padding:.875rem;text-align:center}
.card-mini:first-child{border-right:1px solid rgba(255,255,255,.06)}
.card-mini .v{font-family:'Playfair Display',serif;font-size:1.2rem;color:#fff;font-weight:700}
.card-mini .lb{font-size:.65rem;color:rgba(255,255,255,.3);margin-top:.1rem;letter-spacing:.04em}

.servicios{background:var(--white)}
.svc-head{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:end;margin-bottom:3rem;padding-bottom:2.5rem;border-bottom:1px solid var(--border)}
.section-title{font-family:'Playfair Display',serif;font-size:2.2rem;color:var(--navy);font-weight:700;line-height:1.15}
.section-title em{color:var(--gold);font-style:italic}
.section-desc{font-size:.875rem;color:var(--muted);line-height:1.8;font-weight:300}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border)}
.svc-card{background:var(--white);padding:1.75rem;border-top:3px solid transparent;transition:border-color .2s}
.svc-card:hover{border-top-color:var(--gold)}
.svc-num{font-family:'Playfair Display',serif;font-size:2rem;color:var(--border);font-weight:700;margin-bottom:.75rem}
.svc-name{font-size:.9rem;font-weight:600;color:var(--navy);margin-bottom:.5rem}
.svc-desc{font-size:.8rem;color:var(--muted);line-height:1.65;font-weight:300}

.nosotros{background:var(--bg)}
.nosotros-inner{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.about-values{display:flex;flex-direction:column;gap:.875rem;margin-top:2rem}
.value-row{display:flex;align-items:flex-start;gap:1rem;padding:1rem;border:1px solid var(--border);background:var(--white)}
.value-icon{width:32px;height:32px;background:var(--gold2);border:1px solid var(--gold3);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.value-icon svg{width:14px;height:14px;stroke:var(--gold);fill:none;stroke-width:1.8}
.value-title{font-size:.875rem;font-weight:600;color:var(--navy);margin-bottom:.2rem}
.value-desc{font-size:.8rem;color:var(--muted);line-height:1.6;font-weight:300}
.about-visual{background:var(--navy);padding:2.5rem;display:flex;flex-direction:column;gap:1.5rem;border-top:4px solid var(--gold)}
.about-number{font-family:'Playfair Display',serif;font-size:5rem;color:rgba(201,168,76,.12);line-height:1;font-weight:700}
.about-text{font-size:.9rem;color:rgba(255,255,255,.55);line-height:1.8;font-weight:300}
.about-highlight{color:var(--gold);font-weight:500}
.exp-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,.08)}
.exp-item{text-align:center;padding:1rem;background:var(--navy2)}
.exp-num{font-family:'Playfair Display',serif;font-size:1.7rem;font-weight:700;color:#fff}
.exp-num span{color:var(--gold)}
.exp-label{font-size:.7rem;color:rgba(255,255,255,.35);margin-top:.2rem;letter-spacing:.03em;text-transform:uppercase}

.casos{background:var(--white)}
.casos-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);margin-top:2.5rem}
.caso-card{background:var(--white);padding:1.75rem}
.caso-sector{font-size:.65rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:.75rem}
.caso-title{font-size:.925rem;font-weight:600;color:var(--navy);margin-bottom:.5rem;line-height:1.4}
.caso-desc{font-size:.8rem;color:var(--muted);line-height:1.65;margin-bottom:1rem;font-weight:300}
.caso-pills{display:flex;gap:.5rem;flex-wrap:wrap}
.caso-pill{font-size:.68rem;color:var(--navy);border:1px solid var(--gold);padding:.2rem .65rem;font-weight:500}

.contacto{background:var(--navy)}
.contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}
.contact-h{font-family:'Playfair Display',serif;font-size:2rem;color:#fff;font-weight:700;line-height:1.15;margin-bottom:1rem}
.contact-h em{color:var(--gold);font-style:italic}
.contact-p{font-size:.875rem;color:rgba(255,255,255,.45);line-height:1.8;font-weight:300;margin-bottom:2rem}
.contact-rows{display:flex;flex-direction:column;gap:1rem}
.contact-row{display:flex;align-items:center;gap:.875rem}
.c-icon{width:34px;height:34px;background:var(--gold2);border:1px solid var(--gold3);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.c-icon svg{width:15px;height:15px;stroke:var(--gold);fill:none;stroke-width:1.7}
.c-label{font-size:.68rem;color:rgba(255,255,255,.3);margin-bottom:.1rem;letter-spacing:.05em;text-transform:uppercase}
.c-val{font-size:.875rem;color:#fff;font-weight:500}
.form-box{display:flex;flex-direction:column;gap:.75rem}
.form-row2{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.f-inp{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);padding:.7rem 1rem;color:#fff;font-family:'Inter',sans-serif;font-size:.875rem;outline:none;width:100%;transition:border-color .2s}
.f-inp:focus{border-color:rgba(201,168,76,.5)}
.f-inp::placeholder{color:rgba(255,255,255,.22)}
.f-sel{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);padding:.7rem 1rem;color:rgba(255,255,255,.7);font-family:'Inter',sans-serif;font-size:.875rem;outline:none;width:100%}
.f-sel option{background:#0D1B2A;color:#fff}
.f-ta{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);padding:.7rem 1rem;color:#fff;font-family:'Inter',sans-serif;font-size:.875rem;outline:none;width:100%;min-height:95px;resize:vertical}
.f-ta::placeholder{color:rgba(255,255,255,.22)}
.f-submit{background:var(--gold);color:var(--navy);border:none;padding:.85rem;font-family:'Inter',sans-serif;font-weight:700;font-size:.875rem;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;width:100%;transition:opacity .2s}
.f-submit:hover{opacity:.85}

footer{padding:1.5rem 3rem;background:var(--navy3);border-top:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:space-between}
.footer-logo{font-family:'Playfair Display',serif;color:#fff;font-size:1rem;font-weight:700}
.footer-logo span{color:var(--gold)}
.footer-links{display:flex;gap:1.5rem}
.footer-links a{font-size:.75rem;color:rgba(255,255,255,.3);text-decoration:none;transition:color .2s}
.footer-links a:hover{color:var(--gold)}
.footer-copy{font-size:.72rem;color:rgba(255,255,255,.2)}

/* HAMBURGUESA */
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;background:none;border:none;cursor:pointer;padding:4px;z-index:200}
.hamburger span{display:block;width:24px;height:2px;background:#fff;border-radius:2px;transition:all .3s ease;transform-origin:center}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-menu{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(13,27,42,0.98);z-index:150;flex-direction:column;align-items:center;justify-content:center;gap:2rem;backdrop-filter:blur(10px)}
.mobile-menu.open{display:flex}
.mobile-menu a{color:rgba(255,255,255,.7);text-decoration:none;font-size:1.3rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;transition:color .2s;font-family:'Inter',sans-serif}
.mobile-menu a:hover{color:var(--gold)}
.mobile-menu .mobile-cta{background:var(--gold);color:var(--navy);padding:.75rem 2rem;border-radius:4px;font-size:1rem;font-weight:700;margin-top:1rem}
.mobile-menu .mobile-cta:hover{opacity:.85}
.mobile-close{position:absolute;top:1.5rem;right:1.5rem;background:none;border:none;cursor:pointer;padding:8px}
.mobile-close svg{width:24px;height:24px;stroke:rgba(255,255,255,.6);fill:none;stroke-width:2;stroke-linecap:round}

@media(max-width:900px){
  nav{padding:1rem 1.5rem}
  .nav-links{display:none}
  .nav-cta{display:none}
  .hamburger{display:flex}
  section{padding:4rem 1.5rem}
  .hero-inner,.nosotros-inner,.contact-inner{grid-template-columns:1fr;gap:2.5rem}
  .hero h1{font-size:2rem}
  .svc-head{grid-template-columns:1fr}
  .svc-grid{grid-template-columns:1fr}
  .casos-grid{grid-template-columns:1fr}
  .form-row2{grid-template-columns:1fr}
  footer{flex-direction:column;gap:1rem;text-align:center}
  .footer-links{flex-wrap:wrap;justify-content:center}
}
