:root{
  --bg:#0b0d10;
  --fg:#e9eef4;
  --muted:#9fb3c8;
  --brand:#2dd4bf;
  --card:#111418;
  --btn:#1f2937;
  --btn-hover:#374151;
  --radius:14px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;
  background:linear-gradient(180deg,#0b0d10 0%,#0f141a 100%);
  color:var(--fg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
.container{
  width:min(980px,92%);
  margin-inline:auto;
}
.site-header{
  position:sticky;top:0;backdrop-filter:saturate(180%) blur(12px);
  background:rgba(11,13,16,.6);border-bottom:1px solid rgba(255,255,255,.06);
}
.brand{display:flex;gap:14px;align-items:center;padding:14px 0}
.logo{display:block}
h1{font-size:1.4rem;margin:0}
.subtitle{margin:0;color:var(--muted);font-size:.95rem}
.section{padding:48px 0}
.hero .lead{font-size:1.15rem;color:var(--muted)}
.buttons{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin-top:18px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:14px 16px;border-radius:12px;text-decoration:none;
  background:var(--btn);color:var(--fg);border:1px solid rgba(255,255,255,.08);
  transition:transform .06s ease, background .2s ease, border-color .2s ease;
  font-weight:600
}
.btn:hover{background:var(--btn-hover);transform:translateY(-1px);border-color:rgba(255,255,255,.18)}
.about,.contact{
  background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.01));
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
}
h2{margin:0 0 12px 0;font-size:1.2rem}
p,li{line-height:1.6}
.contact-list{list-style:none;padding:0;margin:0;display:grid;gap:6px}
.site-footer{padding:32px 0;color:var(--muted)}
/* Accessibility */
:focus-visible{outline:3px solid var(--brand);outline-offset:2px;border-radius:10px}
/* Small */
@media (max-width:480px){
  .buttons{grid-template-columns:1fr}
}

/* Asegúrate de que .btn alinee contenido en fila */
.btn {
  display: inline-flex;         /* si no lo tienes ya */
  align-items: center;          /* centra verticalmente el texto y el ícono */
  gap: 10px;                    /* espacio entre icono y texto */
}

/* Tamaño del icono */
.btn__icon {
  width: 20px;
  height: 20px;
  flex: 0 0 20px;               /* evita que se deforme */
  display: inline-block;
}

/* (Opcional) Si usas PNG sobre fondo oscuro y quieres anti-aliased nítido */
.btn__icon { image-rendering: -webkit-optimize-contrast; }

/* (Opcional) Si usas SVG monocromo y quieres que tome el color del texto,
   usa SVG inline o aplica filter si es un SVG con fill fijo */
/* Accesibilidad táctil (en todo lado) */
.btn { min-height: 44px; }  /* pulgar-friendly */
.buttons { gap: 12px; }     /* aire entre botones */

/* Tablet y pantallas medianas */
@media (max-width: 1024px) {
  .section { padding: 40px 0; }
  .hero .lead { font-size: 1.05rem; }
  .buttons {
    /* Botones un poco más estrechos para que quepan 2-3 por fila */
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  }
}

/* Tablet vertical / móviles grandes */
@media (max-width: 768px) {
  .brand { padding: 12px 0; gap: 10px; }
  h1 { font-size: 1.25rem; }
  .subtitle { font-size: .9rem; }
  .section { padding: 36px 0; }
  .buttons { grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); }
  .btn { padding: 12px 14px; gap: 8px; }
  .btn__icon { width: 18px; height: 18px; flex-basis: 18px; }
}

/* Móviles chicos (ya lo tenías) */
@media (max-width: 480px){
  .buttons { grid-template-columns: 1fr; } /* 1 por fila */
  .section { padding: 28px 0; }
}
